From db1bf679d8047e661b31ffcbd1418da335246413 Mon Sep 17 00:00:00 2001 From: Ryan Dahl Date: Mon, 8 Aug 2011 12:11:48 -0700 Subject: Move GYP file to the project root --- node.gyp | 276 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 276 insertions(+) create mode 100644 node.gyp (limited to 'node.gyp') diff --git a/node.gyp b/node.gyp new file mode 100644 index 000000000..8a4d7e76a --- /dev/null +++ b/node.gyp @@ -0,0 +1,276 @@ +{ + 'target_defaults': { + 'default_configuration': 'Debug', + 'configurations': { + # TODO: hoist these out and put them somewhere common, because + # RuntimeLibrary MUST MATCH across the entire project + 'Debug': { + 'defines': [ 'DEBUG', '_DEBUG' ], + 'msvs_settings': { + 'VCCLCompilerTool': { + 'RuntimeLibrary': 1, # static debug + 'Optimization': 0, # /Od, no optimization + }, + }, + }, + 'Release': { + 'defines': [ 'NDEBUG' ], + 'msvs_settings': { + 'VCCLCompilerTool': { + 'RuntimeLibrary': 0, # static release + 'Optimization': 3, # /Ox, full optimization + 'FavorSizeOrSpeed': 1, # /Ot, favour speed over size + 'InlineFunctionExpansion': 2, # /Ob2, inline anything eligible + 'WholeProgramOptimization': 'true', # /GL, whole program optimization, needed for LTCG + }, + 'VCLinkerTool': { + 'LinkTimeCodeGeneration': 1, # link-time code generation + }, + }, + } + }, + 'msvs_settings': { + 'VCCLCompilerTool': { + 'StringPooling': 'true', # pool string literals + 'DebugInformationFormat': 3, # Generate a PDB + 'AdditionalOptions': [ + '/MP', # compile across multiple CPUs, VC2008 setting + ], + 'MultiProcessorCompilation': 'true', # compile across multiple CPUs, VC2010 setting + }, + 'VCLibrarianTool': { + }, + 'VCLinkerTool': { + 'GenerateDebugInformation': 'true', + }, + }, + 'conditions': [ + ['OS == "win"', { + 'defines': [ + 'WIN32', + # we don't really want VC++ warning us about + # how dangerous C functions are... + '_CRT_SECURE_NO_DEPRECATE', + # ... or that C implementations shouldn't use + # POSIX names + '_CRT_NONSTDC_NO_DEPRECATE', + ], + }] + ], + }, + + 'variables': { + 'v8_use_snapshot': 'true', + 'target_arch': 'ia32', + 'node_use_dtrace': 'false', + 'node_use_openssl': 'true' + }, + + 'targets': [ + { + 'target_name': 'node', + 'type': 'executable', + + 'dependencies': [ + 'deps/http_parser/http_parser.gyp:http_parser', + 'deps/v8/tools/gyp/v8.gyp:v8', + 'deps/uv/build/all.gyp:uv', + 'node_js2c#host', + ], + + 'include_dirs': [ + 'src', + 'deps/uv/src/ares', + '<(SHARED_INTERMEDIATE_DIR)' # for node_natives.h + ], + + 'sources': [ + 'src/cares_wrap.cc', + 'src/handle_wrap.cc', + 'src/node.cc', + 'src/node_buffer.cc', + 'src/node_constants.cc', + 'src/node_dtrace.cc', + 'src/node_extensions.cc', + 'src/node_file.cc', + 'src/node_http_parser.cc', + 'src/node_javascript.cc', + 'src/node_main.cc', + 'src/node_os.cc', + 'src/node_script.cc', + 'src/node_string.cc', + 'src/pipe_wrap.cc', + 'src/stdio_wrap.cc', + 'src/stream_wrap.cc', + 'src/tcp_wrap.cc', + 'src/timer_wrap.cc', + 'src/process_wrap.cc', + ], + + 'defines': [ + 'ARCH="<(target_arch)"', + 'PLATFORM="<(OS)"', + '_LARGEFILE_SOURCE', + '_FILE_OFFSET_BITS=64', + ], + + 'conditions': [ + [ 'node_use_openssl=="true"', { + 'libraries': [ '-lssl', '-lcrypto' ], + 'defines': [ 'HAVE_OPENSSL=1' ], + 'sources': [ 'src/node_crypto.cc' ], + }, { + 'defines': [ 'HAVE_OPENSSL=0' ] + }], + + [ 'OS=="win"', { + 'dependencies': [ + 'deps/uv/deps/pthread-win32/build/all.gyp:pthread-win32', + ], + # openssl is not built using gyp, and needs to be + # built separately and placed outside the hierarchy. + # the dependencies aren't set up yet to put it in + # place, so I'm going to force it off indiscrimately + # for the time being. Because the above condition has + # already kicked in, it's not enough simply to turn + # 'node_use_openssl' off; I need to undo its effects + 'node_use_openssl': 'false', + 'defines!': [ 'HAVE_OPENSSL=1' ], + 'defines': [ 'HAVE_OPENSSL=0' ], + 'libraries!': [ '-lssl', '-lcrypto' ], + 'sources!': [ 'src/node_crypto.cc' ], + 'sources': [ + 'src/platform_win32.cc', + 'src/node_stdio_win32.cc', + # file operations depend on eio to link. uv contains eio in unix builds, but not win32. So we need to compile it here instead. + 'deps/uv/src/eio/eio.c', + ], + 'defines': [ + 'PTW32_STATIC_LIB', + 'FD_SETSIZE=1024', + # we need to use node's preferred "win32" rather than gyp's preferred "win" + 'PLATFORM="win32"', + ], + 'libraries': [ + '-lws2_32.lib', + '-lwinmm.lib', + ], + 'msvs_settings': { + 'VCCLCompilerTool': { + 'WarningLevel': '3', + }, + }, + },{ # POSIX + 'defines': [ '__POSIX__' ], + 'sources': [ + 'src/node_cares.cc', + 'src/node_net.cc', + 'src/node_signal_watcher.cc', + 'src/node_stat_watcher.cc', + 'src/node_io_watcher.cc', + 'src/node_stdio.cc', + 'src/node_child_process.cc', + 'src/node_timer.cc' + ] + }], + [ 'OS=="mac"', { + 'sources': [ 'src/platform_darwin.cc' ], + 'libraries': [ '-framework Carbon' ], + }] + ] + }, + + { + 'target_name': 'node_js2c', + 'type': 'none', + 'toolsets': ['host'], + 'variables': { + 'library_files': [ + 'src/node.js', + 'lib/_debugger.js', + 'lib/_linklist.js', + 'lib/assert.js', + 'lib/buffer.js', + 'lib/buffer_ieee754.js', + 'lib/child_process_legacy.js', + 'lib/child_process_uv.js', + 'lib/console.js', + 'lib/constants.js', + 'lib/crypto.js', + 'lib/dgram.js', + 'lib/dns_legacy.js', + 'lib/dns_uv.js', + 'lib/events.js', + 'lib/freelist.js', + 'lib/fs.js', + 'lib/http.js', + 'lib/http2.js', + 'lib/https.js', + 'lib/https2.js', + 'lib/module.js', + 'lib/net_legacy.js', + 'lib/net_uv.js', + 'lib/os.js', + 'lib/path.js', + 'lib/punycode.js', + 'lib/querystring.js', + 'lib/readline.js', + 'lib/repl.js', + 'lib/stream.js', + 'lib/string_decoder.js', + 'lib/sys.js', + 'lib/timers_legacy.js', + 'lib/timers_uv.js', + 'lib/tls.js', + 'lib/tty.js', + 'lib/tty_posix.js', + 'lib/tty_win32.js', + 'lib/url.js', + 'lib/util.js', + 'lib/vm.js', + ], + }, + + 'actions': [ + + { + 'action_name': 'node_js2c', + + 'inputs': [ + './tools/js2c.py', + '<@(library_files)', + ], + + 'outputs': [ + '<(SHARED_INTERMEDIATE_DIR)/node_natives.h', + ], + + # FIXME can the following conditions be shorted by just setting + # macros.py into some variable which then gets included in the + # action? + + 'conditions': [ + [ 'node_use_dtrace=="true"', { + 'action': [ + 'python', + 'tools/js2c.py', + '<@(_outputs)', + '<@(library_files)' + ], + }, { # No Dtrace + 'action': [ + 'python', + 'tools/js2c.py', + '<@(_outputs)', + '<@(library_files)', + 'src/macros.py' + ], + }] + ], + 'msvs_cygwin_shell': 0, + }, + ], + }, # end node_js2c + ] # end targets +} + -- cgit v1.2.1