2015-03-25 17:22:41 +00:00
|
|
|
# Copyright 2015 Google Inc.
|
|
|
|
#
|
|
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
|
|
# found in the LICENSE file.
|
Add nanomsg to third_party, with some demos.
This isn't something I want to make part of Skia, but just a substrate to build cross-process demos on top of. If I client were to use Skia cross-process, they'd drop their own IPC system in here.
If you're not familiar, nanomsg (nanomsg.org) is the next-gen zeromq (zeromq.org), from the same author, righting all his design wrongs from zeromq.
It's a lot like the lower half of mojo, dealing with making the connections and getting messages reliably from A to B. Think, better sockets, and it spans nicely across in-process (with zero-copy), inter-process, and TCP.
BUG=skia:
R=bsalomon@google.com, mtklein@google.com
Author: mtklein@chromium.org
Review URL: https://codereview.chromium.org/294873004
2014-06-17 03:21:06 +00:00
|
|
|
{
|
|
|
|
'variables': {
|
|
|
|
'skia_warnings_as_errors': 0,
|
|
|
|
},
|
|
|
|
'targets': [{
|
|
|
|
# Draws pictures cross-process.
|
|
|
|
'target_name': 'nanomsg_picture_demo',
|
|
|
|
'type': 'executable',
|
|
|
|
'dependencies': [
|
|
|
|
'skia_lib.gyp:skia_lib',
|
|
|
|
'flags.gyp:flags',
|
|
|
|
'libnanomsg',
|
|
|
|
],
|
|
|
|
'sources': [ '../experimental/nanomsg/picture_demo.cpp' ],
|
|
|
|
},{
|
|
|
|
'target_name': 'libnanomsg',
|
|
|
|
'type': 'static_library',
|
|
|
|
|
|
|
|
# Clients can include nanomsg public header foo.h with #include "nanomsg/src/foo.h"
|
|
|
|
'direct_dependent_settings': {
|
|
|
|
'include_dirs': [ '../third_party/externals' ]
|
|
|
|
},
|
|
|
|
|
|
|
|
'sources': [
|
2016-08-02 21:28:26 +00:00
|
|
|
'<!@(python find.py "*.c" ../third_party/externals/nanomsg/src)'
|
Add nanomsg to third_party, with some demos.
This isn't something I want to make part of Skia, but just a substrate to build cross-process demos on top of. If I client were to use Skia cross-process, they'd drop their own IPC system in here.
If you're not familiar, nanomsg (nanomsg.org) is the next-gen zeromq (zeromq.org), from the same author, righting all his design wrongs from zeromq.
It's a lot like the lower half of mojo, dealing with making the connections and getting messages reliably from A to B. Think, better sockets, and it spans nicely across in-process (with zero-copy), inter-process, and TCP.
BUG=skia:
R=bsalomon@google.com, mtklein@google.com
Author: mtklein@chromium.org
Review URL: https://codereview.chromium.org/294873004
2014-06-17 03:21:06 +00:00
|
|
|
],
|
|
|
|
|
|
|
|
# TODO(mtklein): Support Windows?
|
|
|
|
# To refresh: cd third_party/externals/nanomsg; ./autogen.sh; ./configure; copy from Makefile.
|
|
|
|
'conditions': [
|
|
|
|
['skia_os == "linux"', {
|
2014-08-04 20:11:19 +00:00
|
|
|
'cflags': [ '-w' ],
|
2014-08-04 16:36:45 +00:00
|
|
|
'libraries': [
|
|
|
|
'-lpthread',
|
|
|
|
'-lanl', # Provides getaddrinfo_a and co.
|
|
|
|
],
|
Add nanomsg to third_party, with some demos.
This isn't something I want to make part of Skia, but just a substrate to build cross-process demos on top of. If I client were to use Skia cross-process, they'd drop their own IPC system in here.
If you're not familiar, nanomsg (nanomsg.org) is the next-gen zeromq (zeromq.org), from the same author, righting all his design wrongs from zeromq.
It's a lot like the lower half of mojo, dealing with making the connections and getting messages reliably from A to B. Think, better sockets, and it spans nicely across in-process (with zero-copy), inter-process, and TCP.
BUG=skia:
R=bsalomon@google.com, mtklein@google.com
Author: mtklein@chromium.org
Review URL: https://codereview.chromium.org/294873004
2014-06-17 03:21:06 +00:00
|
|
|
'direct_dependent_settings': {
|
2014-08-04 16:36:45 +00:00
|
|
|
'libraries': [ '-lpthread', '-lanl' ],
|
Add nanomsg to third_party, with some demos.
This isn't something I want to make part of Skia, but just a substrate to build cross-process demos on top of. If I client were to use Skia cross-process, they'd drop their own IPC system in here.
If you're not familiar, nanomsg (nanomsg.org) is the next-gen zeromq (zeromq.org), from the same author, righting all his design wrongs from zeromq.
It's a lot like the lower half of mojo, dealing with making the connections and getting messages reliably from A to B. Think, better sockets, and it spans nicely across in-process (with zero-copy), inter-process, and TCP.
BUG=skia:
R=bsalomon@google.com, mtklein@google.com
Author: mtklein@chromium.org
Review URL: https://codereview.chromium.org/294873004
2014-06-17 03:21:06 +00:00
|
|
|
},
|
|
|
|
'defines=': [ # equals sign throws away most Skia defines (just noise)
|
|
|
|
'HAVE_ACCEPT4',
|
|
|
|
'HAVE_ARPA_INET_H',
|
|
|
|
'HAVE_CLOCK_GETTIME',
|
|
|
|
'HAVE_DLFCN_H',
|
|
|
|
'HAVE_EPOLL_CREATE',
|
|
|
|
'HAVE_EVENTFD',
|
|
|
|
'HAVE_GETIFADDRS',
|
|
|
|
'HAVE_INTTYPES_H',
|
|
|
|
'HAVE_MEMORY_H',
|
|
|
|
'HAVE_NETDB_H',
|
|
|
|
'HAVE_NETINET_IN_H',
|
|
|
|
'HAVE_PIPE',
|
|
|
|
'HAVE_PIPE2',
|
|
|
|
'HAVE_POLL',
|
|
|
|
'HAVE_PTHREAD_PRIO_INHERIT',
|
|
|
|
'HAVE_STDINT_H',
|
|
|
|
'HAVE_STDLIB_H',
|
|
|
|
'HAVE_STRINGS_H',
|
|
|
|
'HAVE_STRING_H',
|
|
|
|
'HAVE_SYS_IOCTL_H',
|
|
|
|
'HAVE_SYS_SOCKET_H',
|
|
|
|
'HAVE_SYS_STAT_H',
|
|
|
|
'HAVE_SYS_TYPES_H',
|
|
|
|
'HAVE_UNISTD_H',
|
|
|
|
'HAVE_UNISTD_H',
|
|
|
|
'NN_HAVE_ACCEPT4',
|
|
|
|
'NN_HAVE_CLANG',
|
|
|
|
'NN_HAVE_EVENTFD',
|
|
|
|
'NN_HAVE_GCC',
|
|
|
|
'NN_HAVE_GETADDRINFO_A',
|
|
|
|
'NN_HAVE_LINUX',
|
|
|
|
'NN_HAVE_PIPE',
|
|
|
|
'NN_HAVE_PIPE2',
|
|
|
|
'NN_HAVE_POLL',
|
|
|
|
'NN_HAVE_SEMAPHORE',
|
|
|
|
'NN_HAVE_SOCKETPAIR',
|
|
|
|
'NN_USE_EPOLL',
|
|
|
|
'NN_USE_EVENTFD',
|
|
|
|
'NN_USE_IFADDRS',
|
|
|
|
'STDC_HEADERS',
|
|
|
|
'_GNU_SOURCE',
|
|
|
|
],
|
|
|
|
}],
|
|
|
|
['skia_os == "mac"', {
|
2014-12-15 20:24:46 +00:00
|
|
|
'xcode_settings': {
|
|
|
|
'WARNING_CFLAGS': [ '-w' ],
|
|
|
|
},
|
Add nanomsg to third_party, with some demos.
This isn't something I want to make part of Skia, but just a substrate to build cross-process demos on top of. If I client were to use Skia cross-process, they'd drop their own IPC system in here.
If you're not familiar, nanomsg (nanomsg.org) is the next-gen zeromq (zeromq.org), from the same author, righting all his design wrongs from zeromq.
It's a lot like the lower half of mojo, dealing with making the connections and getting messages reliably from A to B. Think, better sockets, and it spans nicely across in-process (with zero-copy), inter-process, and TCP.
BUG=skia:
R=bsalomon@google.com, mtklein@google.com
Author: mtklein@chromium.org
Review URL: https://codereview.chromium.org/294873004
2014-06-17 03:21:06 +00:00
|
|
|
'defines=': [ # equals sign throws away most Skia defines (just noise)
|
|
|
|
'HAVE_ARPA_INET_H',
|
|
|
|
'HAVE_DLFCN_H',
|
|
|
|
'HAVE_GETIFADDRS',
|
|
|
|
'HAVE_INTTYPES_H',
|
|
|
|
'HAVE_KQUEUE',
|
|
|
|
'HAVE_MEMORY_H',
|
|
|
|
'HAVE_NETDB_H',
|
|
|
|
'HAVE_NETINET_IN_H',
|
|
|
|
'HAVE_PIPE',
|
|
|
|
'HAVE_POLL',
|
|
|
|
'HAVE_PTHREAD_PRIO_INHERIT',
|
|
|
|
'HAVE_STDINT_H',
|
|
|
|
'HAVE_STDLIB_H',
|
|
|
|
'HAVE_STRINGS_H',
|
|
|
|
'HAVE_STRING_H',
|
|
|
|
'HAVE_SYS_IOCTL_H',
|
|
|
|
'HAVE_SYS_SOCKET_H',
|
|
|
|
'HAVE_SYS_STAT_H',
|
|
|
|
'HAVE_SYS_TYPES_H',
|
|
|
|
'HAVE_UNISTD_H',
|
|
|
|
'NN_HAVE_CLANG',
|
|
|
|
'NN_HAVE_GCC',
|
|
|
|
'NN_HAVE_OSX',
|
|
|
|
'NN_HAVE_PIPE',
|
|
|
|
'NN_HAVE_POLL',
|
|
|
|
'NN_HAVE_SEMAPHORE',
|
|
|
|
'NN_HAVE_SOCKETPAIR',
|
|
|
|
'NN_USE_IFADDRS',
|
|
|
|
'NN_USE_KQUEUE',
|
|
|
|
'NN_USE_PIPE',
|
|
|
|
'STDC_HEADERS',
|
|
|
|
'_THREAD_SAFE',
|
|
|
|
],
|
|
|
|
}],
|
|
|
|
]
|
|
|
|
}]
|
|
|
|
}
|