2010-03-01 23:39:31 +01:00
|
|
|
#!/usr/bin/env python
|
2009-09-02 20:19:52 +02:00
|
|
|
import re
|
2009-04-04 14:50:15 +02:00
|
|
|
import Options
|
2009-07-28 12:29:18 +02:00
|
|
|
import sys, os, shutil
|
2009-10-09 15:00:12 +02:00
|
|
|
from Utils import cmd_output
|
2009-04-04 14:50:15 +02:00
|
|
|
from os.path import join, dirname, abspath
|
2009-04-23 13:18:38 +02:00
|
|
|
from logging import fatal
|
|
|
|
|
2009-10-09 15:00:12 +02:00
|
|
|
cwd = os.getcwd()
|
2010-03-06 02:55:00 +01:00
|
|
|
VERSION="0.1.31"
|
2009-08-27 01:11:16 +02:00
|
|
|
APPNAME="node.js"
|
|
|
|
|
2009-04-15 10:08:28 +02:00
|
|
|
import js2c
|
|
|
|
|
2009-04-04 14:50:15 +02:00
|
|
|
srcdir = '.'
|
|
|
|
blddir = 'build'
|
|
|
|
|
|
|
|
def set_options(opt):
|
|
|
|
# the gcc module provides a --debug-level option
|
|
|
|
opt.tool_options('compiler_cxx')
|
|
|
|
opt.tool_options('compiler_cc')
|
2009-08-27 01:11:16 +02:00
|
|
|
opt.tool_options('misc')
|
2009-04-23 17:29:31 +02:00
|
|
|
opt.add_option( '--debug'
|
|
|
|
, action='store_true'
|
|
|
|
, default=False
|
|
|
|
, help='Build debug variant [Default: False]'
|
|
|
|
, dest='debug'
|
|
|
|
)
|
2009-06-16 15:47:57 +02:00
|
|
|
opt.add_option( '--efence'
|
|
|
|
, action='store_true'
|
|
|
|
, default=False
|
|
|
|
, help='Build with -lefence for debugging [Default: False]'
|
|
|
|
, dest='efence'
|
|
|
|
)
|
2009-04-04 14:50:15 +02:00
|
|
|
|
2009-07-28 12:29:18 +02:00
|
|
|
def mkdir_p(dir):
|
|
|
|
if not os.path.exists (dir):
|
|
|
|
os.makedirs (dir)
|
|
|
|
|
Copy Python's shutil.copytree into wscript.
It's broken in Python 2.4.4. One gets this message when trying to run
configure:
[...]
Checking for SYS_clock_gettime : ok
Checking for library rt : ok
Checking for function clock_gettime : ok
Checking for function nanosleep : ok
Checking for function ceil : ok
---- deps/udns ----
Traceback (most recent call last):
File "/path/to/node/tools/waf", line 148, in ?
Scripting.prepare(t, cwd, VERSION, wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 102, in prepare
prepare_impl(t,cwd,ver,wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 95, in prepare_impl
main()
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 130, in main
fun(ctx)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 168, in configure
conf.sub_config([''])
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Configure.py", line 100, in sub_config
self.recurse(k,name='configure')
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Utils.py", line 391, in recurse
f(self)
File "<string>", line 82, in configure
File "<string>", line 48, in conf_subproject
File "/usr/lib/python2.4/shutil.py", line 111, in copytree
os.mkdir(dst)
OSError: [Errno 2] No such file or directory: '/sites/rabidlabs.net/sandboxes/m/public_html/projects/0909.node/node/build/default/deps/udns'
The problem is probably this:
http://mail.python.org/pipermail/python-bugs-list/2005-January/027118.html
As a solution I am copying 2.6's version of the function in.
2009-09-28 22:39:00 +02:00
|
|
|
# Copied from Python 2.6 because 2.4.4 at least is broken by not using
|
|
|
|
# mkdirs
|
|
|
|
# http://mail.python.org/pipermail/python-bugs-list/2005-January/027118.html
|
|
|
|
def copytree(src, dst, symlinks=False, ignore=None):
|
|
|
|
names = os.listdir(src)
|
|
|
|
if ignore is not None:
|
|
|
|
ignored_names = ignore(src, names)
|
|
|
|
else:
|
|
|
|
ignored_names = set()
|
|
|
|
|
|
|
|
os.makedirs(dst)
|
|
|
|
errors = []
|
|
|
|
for name in names:
|
|
|
|
if name in ignored_names:
|
|
|
|
continue
|
2009-10-08 23:20:14 +02:00
|
|
|
srcname = join(src, name)
|
|
|
|
dstname = join(dst, name)
|
Copy Python's shutil.copytree into wscript.
It's broken in Python 2.4.4. One gets this message when trying to run
configure:
[...]
Checking for SYS_clock_gettime : ok
Checking for library rt : ok
Checking for function clock_gettime : ok
Checking for function nanosleep : ok
Checking for function ceil : ok
---- deps/udns ----
Traceback (most recent call last):
File "/path/to/node/tools/waf", line 148, in ?
Scripting.prepare(t, cwd, VERSION, wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 102, in prepare
prepare_impl(t,cwd,ver,wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 95, in prepare_impl
main()
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 130, in main
fun(ctx)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 168, in configure
conf.sub_config([''])
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Configure.py", line 100, in sub_config
self.recurse(k,name='configure')
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Utils.py", line 391, in recurse
f(self)
File "<string>", line 82, in configure
File "<string>", line 48, in conf_subproject
File "/usr/lib/python2.4/shutil.py", line 111, in copytree
os.mkdir(dst)
OSError: [Errno 2] No such file or directory: '/sites/rabidlabs.net/sandboxes/m/public_html/projects/0909.node/node/build/default/deps/udns'
The problem is probably this:
http://mail.python.org/pipermail/python-bugs-list/2005-January/027118.html
As a solution I am copying 2.6's version of the function in.
2009-09-28 22:39:00 +02:00
|
|
|
try:
|
|
|
|
if symlinks and os.path.islink(srcname):
|
|
|
|
linkto = os.readlink(srcname)
|
|
|
|
os.symlink(linkto, dstname)
|
|
|
|
elif os.path.isdir(srcname):
|
|
|
|
copytree(srcname, dstname, symlinks, ignore)
|
|
|
|
else:
|
|
|
|
shutil.copy2(srcname, dstname)
|
|
|
|
# XXX What about devices, sockets etc.?
|
|
|
|
except (IOError, os.error), why:
|
|
|
|
errors.append((srcname, dstname, str(why)))
|
|
|
|
# catch the Error from the recursive copytree so that we can
|
|
|
|
# continue with other files
|
|
|
|
except Error, err:
|
|
|
|
errors.extend(err.args[0])
|
|
|
|
try:
|
|
|
|
shutil.copystat(src, dst)
|
|
|
|
except OSError, why:
|
|
|
|
if WindowsError is not None and isinstance(why, WindowsError):
|
|
|
|
# Copying file access times may fail on Windows
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
errors.extend((src, dst, str(why)))
|
|
|
|
if errors:
|
|
|
|
raise Error, errors
|
|
|
|
|
2009-07-28 12:29:18 +02:00
|
|
|
def conf_subproject (conf, subdir, command=None):
|
|
|
|
print("---- %s ----" % subdir)
|
|
|
|
src = join(conf.srcdir, subdir)
|
2009-12-09 13:36:12 +01:00
|
|
|
if not os.path.exists (src): conf.fatal("no such subproject " + subdir)
|
2009-07-28 12:29:18 +02:00
|
|
|
|
|
|
|
default_tgt = join(conf.blddir, "default", subdir)
|
|
|
|
|
|
|
|
if not os.path.exists(default_tgt):
|
Copy Python's shutil.copytree into wscript.
It's broken in Python 2.4.4. One gets this message when trying to run
configure:
[...]
Checking for SYS_clock_gettime : ok
Checking for library rt : ok
Checking for function clock_gettime : ok
Checking for function nanosleep : ok
Checking for function ceil : ok
---- deps/udns ----
Traceback (most recent call last):
File "/path/to/node/tools/waf", line 148, in ?
Scripting.prepare(t, cwd, VERSION, wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 102, in prepare
prepare_impl(t,cwd,ver,wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 95, in prepare_impl
main()
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 130, in main
fun(ctx)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 168, in configure
conf.sub_config([''])
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Configure.py", line 100, in sub_config
self.recurse(k,name='configure')
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Utils.py", line 391, in recurse
f(self)
File "<string>", line 82, in configure
File "<string>", line 48, in conf_subproject
File "/usr/lib/python2.4/shutil.py", line 111, in copytree
os.mkdir(dst)
OSError: [Errno 2] No such file or directory: '/sites/rabidlabs.net/sandboxes/m/public_html/projects/0909.node/node/build/default/deps/udns'
The problem is probably this:
http://mail.python.org/pipermail/python-bugs-list/2005-January/027118.html
As a solution I am copying 2.6's version of the function in.
2009-09-28 22:39:00 +02:00
|
|
|
copytree(src, default_tgt, True)
|
2009-07-28 12:29:18 +02:00
|
|
|
|
|
|
|
if command:
|
2010-02-10 11:21:54 +01:00
|
|
|
if os.system("cd \"%s\" && %s" % (default_tgt, command)) != 0:
|
2009-12-09 13:36:12 +01:00
|
|
|
conf.fatal("Configuring %s failed." % (subdir))
|
2009-07-28 12:29:18 +02:00
|
|
|
|
|
|
|
debug_tgt = join(conf.blddir, "debug", subdir)
|
|
|
|
|
|
|
|
if not os.path.exists(debug_tgt):
|
Copy Python's shutil.copytree into wscript.
It's broken in Python 2.4.4. One gets this message when trying to run
configure:
[...]
Checking for SYS_clock_gettime : ok
Checking for library rt : ok
Checking for function clock_gettime : ok
Checking for function nanosleep : ok
Checking for function ceil : ok
---- deps/udns ----
Traceback (most recent call last):
File "/path/to/node/tools/waf", line 148, in ?
Scripting.prepare(t, cwd, VERSION, wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 102, in prepare
prepare_impl(t,cwd,ver,wafdir)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 95, in prepare_impl
main()
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 130, in main
fun(ctx)
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Scripting.py", line 168, in configure
conf.sub_config([''])
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Configure.py", line 100, in sub_config
self.recurse(k,name='configure')
File "/path/to/node/tools/.waf-1.5.8-3e327cd9534c48e6762f56fdb1332663/wafadmin/Utils.py", line 391, in recurse
f(self)
File "<string>", line 82, in configure
File "<string>", line 48, in conf_subproject
File "/usr/lib/python2.4/shutil.py", line 111, in copytree
os.mkdir(dst)
OSError: [Errno 2] No such file or directory: '/sites/rabidlabs.net/sandboxes/m/public_html/projects/0909.node/node/build/default/deps/udns'
The problem is probably this:
http://mail.python.org/pipermail/python-bugs-list/2005-January/027118.html
As a solution I am copying 2.6's version of the function in.
2009-09-28 22:39:00 +02:00
|
|
|
copytree(default_tgt, debug_tgt, True)
|
2009-07-28 12:29:18 +02:00
|
|
|
|
2009-04-04 14:50:15 +02:00
|
|
|
def configure(conf):
|
|
|
|
conf.check_tool('compiler_cxx')
|
2010-01-12 01:43:10 +01:00
|
|
|
if not conf.env.CXX: conf.fatal('c++ compiler not found')
|
2009-04-04 14:50:15 +02:00
|
|
|
conf.check_tool('compiler_cc')
|
2010-01-12 01:43:10 +01:00
|
|
|
if not conf.env.CC: conf.fatal('c compiler not found')
|
2009-04-23 13:18:38 +02:00
|
|
|
|
2009-04-23 19:26:56 +02:00
|
|
|
conf.env["USE_DEBUG"] = Options.options.debug
|
2009-04-04 14:50:15 +02:00
|
|
|
|
2009-06-20 15:07:10 +02:00
|
|
|
conf.check(lib='dl', uselib_store='DL')
|
2010-01-20 00:38:20 +01:00
|
|
|
if not sys.platform.startswith("sunos"):
|
|
|
|
conf.env.append_value("CCFLAGS", "-rdynamic")
|
|
|
|
conf.env.append_value("LINKFLAGS_DL", "-rdynamic")
|
2009-08-31 11:14:34 +02:00
|
|
|
|
2010-01-07 08:37:27 +01:00
|
|
|
if sys.platform.startswith("freebsd"):
|
|
|
|
conf.check(lib='kvm', uselib_store='KVM')
|
|
|
|
|
2009-09-01 14:15:29 +02:00
|
|
|
#if Options.options.debug:
|
|
|
|
# conf.check(lib='profiler', uselib_store='PROFILER')
|
2009-06-16 15:47:57 +02:00
|
|
|
|
2010-01-27 03:34:42 +01:00
|
|
|
if Options.options.efence:
|
|
|
|
conf.check(lib='efence', libpath=['/usr/lib', '/usr/local/lib'], uselib_store='EFENCE')
|
2009-05-27 16:29:55 +02:00
|
|
|
|
2009-10-10 11:58:36 +02:00
|
|
|
if not conf.check(lib="execinfo", libpath=['/usr/lib', '/usr/local/lib'], uselib_store="EXECINFO"):
|
2009-12-15 23:37:49 +01:00
|
|
|
# Note on Darwin/OS X: This will fail, but will still be used as the
|
|
|
|
# execinfo stuff are part of the standard library.
|
2009-10-10 11:58:36 +02:00
|
|
|
if sys.platform.startswith("freebsd"):
|
2009-12-09 13:36:12 +01:00
|
|
|
conf.fatal("Install the libexecinfo port from /usr/ports/devel/libexecinfo.")
|
2009-05-27 16:29:55 +02:00
|
|
|
|
2009-11-22 03:58:08 +01:00
|
|
|
if conf.check_cfg(package='gnutls',
|
|
|
|
args='--cflags --libs',
|
2009-11-28 15:25:10 +01:00
|
|
|
atleast_version='2.5.0',
|
2009-11-22 03:58:08 +01:00
|
|
|
#libpath=['/usr/lib', '/usr/local/lib'],
|
|
|
|
uselib_store='GNUTLS'):
|
|
|
|
if conf.check(lib='gpg-error',
|
2010-02-17 22:56:44 +01:00
|
|
|
libpath=['/usr/lib', '/usr/local/lib', '/opt/local/lib'],
|
2009-11-22 03:58:08 +01:00
|
|
|
uselib_store='GPGERROR'):
|
|
|
|
conf.env.append_value("CCFLAGS", "-DEVCOM_HAVE_GNUTLS=1")
|
|
|
|
conf.env.append_value("CXXFLAGS", "-DEVCOM_HAVE_GNUTLS=1")
|
|
|
|
|
2010-01-20 00:38:20 +01:00
|
|
|
if sys.platform.startswith("sunos"):
|
|
|
|
if not conf.check(lib='socket', uselib_store="SOCKET"):
|
|
|
|
conf.fatal("Cannot find socket library")
|
|
|
|
if not conf.check(lib='nsl', uselib_store="NSL"):
|
|
|
|
conf.fatal("Cannot find nsl library")
|
|
|
|
|
2009-04-04 14:50:15 +02:00
|
|
|
conf.sub_config('deps/libeio')
|
|
|
|
conf.sub_config('deps/libev')
|
|
|
|
|
2010-01-20 00:38:20 +01:00
|
|
|
if sys.platform.startswith("sunos"):
|
|
|
|
conf_subproject(conf, 'deps/udns', 'LIBS="-lsocket -lnsl" ./configure')
|
|
|
|
else:
|
|
|
|
conf_subproject(conf, 'deps/udns', './configure')
|
2009-07-28 12:29:18 +02:00
|
|
|
|
2009-04-04 14:50:15 +02:00
|
|
|
conf.define("HAVE_CONFIG_H", 1)
|
2009-04-22 19:55:08 +02:00
|
|
|
|
2009-12-30 09:01:28 +01:00
|
|
|
conf.env.append_value("CCFLAGS", "-DX_STACKSIZE=%d" % (1024*64))
|
2009-05-14 13:16:45 +02:00
|
|
|
|
2009-10-27 12:05:38 +01:00
|
|
|
# LFS
|
|
|
|
conf.env.append_value('CCFLAGS', '-D_LARGEFILE_SOURCE')
|
|
|
|
conf.env.append_value('CXXFLAGS', '-D_LARGEFILE_SOURCE')
|
|
|
|
conf.env.append_value('CCFLAGS', '-D_FILE_OFFSET_BITS=64')
|
|
|
|
conf.env.append_value('CXXFLAGS', '-D_FILE_OFFSET_BITS=64')
|
|
|
|
|
2009-11-03 00:21:00 +01:00
|
|
|
# platform
|
|
|
|
platform_def = '-DPLATFORM=' + sys.platform
|
|
|
|
conf.env.append_value('CCFLAGS', platform_def)
|
|
|
|
conf.env.append_value('CXXFLAGS', platform_def)
|
|
|
|
|
2009-04-18 15:35:42 +02:00
|
|
|
# Split off debug variant before adding variant specific defines
|
2009-04-16 11:37:44 +02:00
|
|
|
debug_env = conf.env.copy()
|
|
|
|
conf.set_env_name('debug', debug_env)
|
2009-04-18 15:35:42 +02:00
|
|
|
|
|
|
|
# Configure debug variant
|
2009-04-16 11:37:44 +02:00
|
|
|
conf.setenv('debug')
|
2009-04-18 15:35:42 +02:00
|
|
|
debug_env.set_variant('debug')
|
2009-09-02 20:19:52 +02:00
|
|
|
debug_env.append_value('CCFLAGS', ['-DDEBUG', '-g', '-O0', '-Wall', '-Wextra'])
|
|
|
|
debug_env.append_value('CXXFLAGS', ['-DDEBUG', '-g', '-O0', '-Wall', '-Wextra'])
|
2009-04-18 15:35:42 +02:00
|
|
|
conf.write_config_header("config.h")
|
2009-04-16 11:37:44 +02:00
|
|
|
|
2009-04-18 15:35:42 +02:00
|
|
|
# Configure default variant
|
|
|
|
conf.setenv('default')
|
2009-09-02 20:19:52 +02:00
|
|
|
conf.env.append_value('CCFLAGS', ['-DNDEBUG', '-O3'])
|
|
|
|
conf.env.append_value('CXXFLAGS', ['-DNDEBUG', '-O3'])
|
2009-04-18 15:35:42 +02:00
|
|
|
conf.write_config_header("config.h")
|
2009-04-15 10:08:28 +02:00
|
|
|
|
2009-07-28 12:29:18 +02:00
|
|
|
def build_udns(bld):
|
|
|
|
default_build_dir = bld.srcnode.abspath(bld.env_of_name("default"))
|
|
|
|
|
|
|
|
default_dir = join(default_build_dir, "deps/udns")
|
|
|
|
|
|
|
|
static_lib = bld.env["staticlib_PATTERN"] % "udns"
|
2009-04-04 14:50:15 +02:00
|
|
|
|
2010-02-10 11:21:54 +01:00
|
|
|
rule = 'cd "%s" && make'
|
2009-07-28 12:29:18 +02:00
|
|
|
|
|
|
|
default = bld.new_task_gen(
|
|
|
|
target= join("deps/udns", static_lib),
|
|
|
|
rule= rule % default_dir,
|
|
|
|
before= "cxx",
|
|
|
|
install_path= None
|
|
|
|
)
|
|
|
|
|
|
|
|
bld.env["CPPPATH_UDNS"] = "deps/udns"
|
2009-10-27 22:50:46 +01:00
|
|
|
t = join(bld.srcnode.abspath(bld.env_of_name("default")), default.target)
|
|
|
|
bld.env_of_name('default')["LINKFLAGS_UDNS"] = [t]
|
2009-07-28 12:29:18 +02:00
|
|
|
|
|
|
|
if bld.env["USE_DEBUG"]:
|
|
|
|
debug_build_dir = bld.srcnode.abspath(bld.env_of_name("debug"))
|
|
|
|
debug_dir = join(debug_build_dir, "deps/udns")
|
|
|
|
debug = default.clone("debug")
|
|
|
|
debug.rule = rule % debug_dir
|
2009-10-27 22:50:46 +01:00
|
|
|
t = join(bld.srcnode.abspath(bld.env_of_name("debug")), debug.target)
|
|
|
|
bld.env_of_name('debug')["LINKFLAGS_UDNS"] = [t]
|
2010-01-20 00:38:20 +01:00
|
|
|
|
2009-10-03 22:42:03 +02:00
|
|
|
bld.install_files('${PREFIX}/include/node/', 'deps/udns/udns.h')
|
2009-07-28 12:29:18 +02:00
|
|
|
|
2009-10-08 23:20:14 +02:00
|
|
|
def v8_cmd(bld, variant):
|
|
|
|
scons = join(cwd, 'tools/scons/scons.py')
|
2009-04-04 14:50:15 +02:00
|
|
|
deps_src = join(bld.path.abspath(),"deps")
|
|
|
|
v8dir_src = join(deps_src,"v8")
|
2009-10-08 23:20:14 +02:00
|
|
|
|
2009-10-02 14:10:40 +02:00
|
|
|
# NOTE: We want to compile V8 to export its symbols. I.E. Do not want
|
|
|
|
# -fvisibility=hidden. When using dlopen() it seems that the loaded DSO
|
|
|
|
# cannot see symbols in the executable which are hidden, even if the
|
|
|
|
# executable is statically linked together...
|
2009-09-02 20:19:52 +02:00
|
|
|
|
2009-10-26 22:27:52 +01:00
|
|
|
# XXX Remove this when v8 defaults x86_64 to native builds
|
2009-10-09 00:34:39 +02:00
|
|
|
arch = ""
|
2009-10-26 22:27:52 +01:00
|
|
|
if bld.env['DEST_CPU'] == 'x86_64':
|
2009-10-09 00:34:39 +02:00
|
|
|
arch = "arch=x64"
|
|
|
|
|
|
|
|
if variant == "default":
|
|
|
|
mode = "release"
|
|
|
|
else:
|
|
|
|
mode = "debug"
|
2009-04-23 13:18:38 +02:00
|
|
|
|
2010-02-10 11:21:54 +01:00
|
|
|
cmd_R = 'python "%s" -C "%s" -Y "%s" visibility=default mode=%s %s library=static snapshot=on'
|
2009-10-08 23:20:14 +02:00
|
|
|
|
|
|
|
cmd = cmd_R % ( scons
|
|
|
|
, bld.srcnode.abspath(bld.env_of_name(variant))
|
|
|
|
, v8dir_src
|
|
|
|
, mode
|
|
|
|
, arch
|
|
|
|
)
|
|
|
|
return cmd
|
|
|
|
|
|
|
|
|
|
|
|
def build_v8(bld):
|
2009-04-04 14:50:15 +02:00
|
|
|
v8 = bld.new_task_gen(
|
2009-10-09 12:49:48 +02:00
|
|
|
source = 'deps/v8/SConstruct '
|
|
|
|
+ bld.path.ant_glob('v8/include/*')
|
|
|
|
+ bld.path.ant_glob('v8/src/*'),
|
2009-10-08 23:20:14 +02:00
|
|
|
target = bld.env["staticlib_PATTERN"] % "v8",
|
|
|
|
rule = v8_cmd(bld, "default"),
|
|
|
|
before = "cxx",
|
|
|
|
install_path = None
|
2009-04-04 14:50:15 +02:00
|
|
|
)
|
2009-10-10 11:58:36 +02:00
|
|
|
v8.uselib = "EXECINFO"
|
2009-04-04 14:50:15 +02:00
|
|
|
bld.env["CPPPATH_V8"] = "deps/v8/include"
|
2009-10-27 22:50:46 +01:00
|
|
|
t = join(bld.srcnode.abspath(bld.env_of_name("default")), v8.target)
|
2010-01-20 00:38:20 +01:00
|
|
|
if sys.platform.startswith("sunos"):
|
|
|
|
bld.env_of_name('default')["LINKFLAGS_V8"] = ["-mt", t]
|
|
|
|
else:
|
|
|
|
bld.env_of_name('default')["LINKFLAGS_V8"] = ["-pthread", t]
|
2009-04-23 13:18:38 +02:00
|
|
|
|
|
|
|
### v8 debug
|
2009-04-23 17:29:31 +02:00
|
|
|
if bld.env["USE_DEBUG"]:
|
|
|
|
v8_debug = v8.clone("debug")
|
2009-10-08 23:20:14 +02:00
|
|
|
v8_debug.rule = v8_cmd(bld, "debug")
|
|
|
|
v8_debug.target = bld.env["staticlib_PATTERN"] % "v8_g"
|
2009-10-10 11:58:36 +02:00
|
|
|
v8_debug.uselib = "EXECINFO"
|
2009-10-27 22:50:46 +01:00
|
|
|
t = join(bld.srcnode.abspath(bld.env_of_name("debug")), v8_debug.target)
|
2010-01-20 00:38:20 +01:00
|
|
|
if sys.platform.startswith("sunos"):
|
|
|
|
bld.env_of_name('debug')["LINKFLAGS_V8"] = ["-mt", t]
|
|
|
|
else:
|
|
|
|
bld.env_of_name('debug')["LINKFLAGS_V8"] = ["-pthread", t]
|
2009-04-04 14:50:15 +02:00
|
|
|
|
2009-10-08 23:20:14 +02:00
|
|
|
bld.install_files('${PREFIX}/include/node/', 'deps/v8/include/*.h')
|
2009-06-20 15:07:10 +02:00
|
|
|
|
2009-07-28 12:29:18 +02:00
|
|
|
def build(bld):
|
|
|
|
bld.add_subdirs('deps/libeio deps/libev')
|
|
|
|
|
|
|
|
build_udns(bld)
|
|
|
|
build_v8(bld)
|
|
|
|
|
2009-07-25 17:52:21 +02:00
|
|
|
### evcom
|
2009-10-27 22:26:53 +01:00
|
|
|
evcom = bld.new_task_gen("cc")
|
2009-07-25 17:52:21 +02:00
|
|
|
evcom.source = "deps/evcom/evcom.c"
|
|
|
|
evcom.includes = "deps/evcom/ deps/libev/"
|
|
|
|
evcom.name = "evcom"
|
|
|
|
evcom.target = "evcom"
|
2009-11-22 03:58:08 +01:00
|
|
|
evcom.uselib = "GPGERROR GNUTLS"
|
2009-07-25 17:52:21 +02:00
|
|
|
evcom.install_path = None
|
2009-04-23 17:29:31 +02:00
|
|
|
if bld.env["USE_DEBUG"]:
|
2009-07-25 17:52:21 +02:00
|
|
|
evcom.clone("debug")
|
2009-10-03 22:42:03 +02:00
|
|
|
bld.install_files('${PREFIX}/include/node/', 'deps/evcom/evcom.h')
|
2009-04-04 14:50:15 +02:00
|
|
|
|
2009-05-03 14:09:16 +02:00
|
|
|
### http_parser
|
2009-10-27 22:26:53 +01:00
|
|
|
http_parser = bld.new_task_gen("cc")
|
2009-05-03 14:09:16 +02:00
|
|
|
http_parser.source = "deps/http_parser/http_parser.c"
|
|
|
|
http_parser.includes = "deps/http_parser/"
|
|
|
|
http_parser.name = "http_parser"
|
|
|
|
http_parser.target = "http_parser"
|
|
|
|
http_parser.install_path = None
|
2009-04-23 17:29:31 +02:00
|
|
|
if bld.env["USE_DEBUG"]:
|
2009-05-03 14:09:16 +02:00
|
|
|
http_parser.clone("debug")
|
2009-04-04 14:50:15 +02:00
|
|
|
|
2009-08-24 20:25:24 +02:00
|
|
|
### coupling
|
2009-10-27 22:26:53 +01:00
|
|
|
coupling = bld.new_task_gen("cc")
|
2009-08-24 20:25:24 +02:00
|
|
|
coupling.source = "deps/coupling/coupling.c"
|
|
|
|
coupling.includes = "deps/coupling/"
|
|
|
|
coupling.name = "coupling"
|
|
|
|
coupling.target = "coupling"
|
|
|
|
coupling.install_path = None
|
|
|
|
if bld.env["USE_DEBUG"]:
|
|
|
|
coupling.clone("debug")
|
|
|
|
|
2009-04-15 10:08:28 +02:00
|
|
|
### src/native.cc
|
|
|
|
def javascript_in_c(task):
|
|
|
|
env = task.env
|
|
|
|
source = map(lambda x: x.srcpath(env), task.inputs)
|
|
|
|
targets = map(lambda x: x.srcpath(env), task.outputs)
|
|
|
|
js2c.JS2C(source, targets)
|
|
|
|
|
|
|
|
native_cc = bld.new_task_gen(
|
2009-11-07 14:37:22 +01:00
|
|
|
source='src/node.js',
|
2009-10-08 23:20:14 +02:00
|
|
|
target="src/node_natives.h",
|
2009-04-15 10:08:28 +02:00
|
|
|
before="cxx"
|
|
|
|
)
|
2009-04-23 19:26:56 +02:00
|
|
|
native_cc.install_path = None
|
Add work-around for configure --debug with Python 2.4.3
This is the error that was encountered:
: make
Waf: Entering directory `/dcs/06/csugds/node/ry-node-cfe5876/build'
Traceback (most recent call last):
File "tools/waf-light", line 148, in ?
Scripting.prepare(t, cwd, VERSION, wafdir)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 142, in prepare
prepare_impl(t, cwd, ver, wafdir)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 132, in prepare_impl
main()
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 185, in main
fun(ctx)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 382, in build
return build_impl(bld)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 395, in build_impl
bld.add_subdirs([os.path.split(Utils.g_module.root_path)[0]])
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Build.py", line 924, in add_subdirs
self.recurse(dirs, 'build')
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Utils.py", line 599, in recurse
f(self)
File "<string>", line 312, in build
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/TaskGen.py", line 297, in clone
setattr(newobj, x, copy.copy(getattr(self, x)))
File "/usr/lib/python2.4/copy.py", line 108, in copy
return _reconstruct(x, rv, 0)
File "/usr/lib/python2.4/copy.py", line 336, in _reconstruct
y = callable(*args)
File "/usr/lib/python2.4/copy_reg.py", line 92, in __newobj__
return cls.__new__(cls, *args)
TypeError: function() takes at least 2 arguments (0 given)
make: *** [all] Error 1
2009-10-16 22:53:44 +02:00
|
|
|
|
|
|
|
# Add the rule /after/ cloning the debug
|
|
|
|
# This is a work around for an error had in python 2.4.3 (I'll paste the
|
|
|
|
# error that was had into the git commit meessage. git-blame to find out
|
|
|
|
# where.)
|
2009-04-23 17:29:31 +02:00
|
|
|
if bld.env["USE_DEBUG"]:
|
Add work-around for configure --debug with Python 2.4.3
This is the error that was encountered:
: make
Waf: Entering directory `/dcs/06/csugds/node/ry-node-cfe5876/build'
Traceback (most recent call last):
File "tools/waf-light", line 148, in ?
Scripting.prepare(t, cwd, VERSION, wafdir)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 142, in prepare
prepare_impl(t, cwd, ver, wafdir)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 132, in prepare_impl
main()
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 185, in main
fun(ctx)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 382, in build
return build_impl(bld)
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Scripting.py", line 395, in build_impl
bld.add_subdirs([os.path.split(Utils.g_module.root_path)[0]])
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Build.py", line 924, in add_subdirs
self.recurse(dirs, 'build')
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/Utils.py", line 599, in recurse
f(self)
File "<string>", line 312, in build
File "/dcs/06/csugds/node/ry-node-cfe5876/tools/wafadmin/TaskGen.py", line 297, in clone
setattr(newobj, x, copy.copy(getattr(self, x)))
File "/usr/lib/python2.4/copy.py", line 108, in copy
return _reconstruct(x, rv, 0)
File "/usr/lib/python2.4/copy.py", line 336, in _reconstruct
y = callable(*args)
File "/usr/lib/python2.4/copy_reg.py", line 92, in __newobj__
return cls.__new__(cls, *args)
TypeError: function() takes at least 2 arguments (0 given)
make: *** [all] Error 1
2009-10-16 22:53:44 +02:00
|
|
|
native_cc_debug = native_cc.clone("debug")
|
|
|
|
native_cc_debug.rule = javascript_in_c
|
|
|
|
native_cc.rule = javascript_in_c
|
2009-04-15 10:08:28 +02:00
|
|
|
|
2009-06-20 15:07:10 +02:00
|
|
|
### node lib
|
2009-09-01 14:15:29 +02:00
|
|
|
node = bld.new_task_gen("cxx", "program")
|
|
|
|
node.name = "node"
|
|
|
|
node.target = "node"
|
|
|
|
node.source = """
|
2009-04-04 14:50:15 +02:00
|
|
|
src/node.cc
|
2009-12-13 08:42:45 +01:00
|
|
|
src/node_buffer.cc
|
2010-01-24 20:21:45 +01:00
|
|
|
src/node_http_parser.cc
|
2010-01-28 00:40:09 +01:00
|
|
|
src/node_net2.cc
|
2009-12-13 15:43:58 +01:00
|
|
|
src/node_io_watcher.cc
|
2009-10-27 11:46:58 +01:00
|
|
|
src/node_child_process.cc
|
|
|
|
src/node_constants.cc
|
|
|
|
src/node_dns.cc
|
|
|
|
src/node_events.cc
|
|
|
|
src/node_file.cc
|
|
|
|
src/node_http.cc
|
|
|
|
src/node_net.cc
|
|
|
|
src/node_signal_handler.cc
|
2009-11-17 14:07:48 +01:00
|
|
|
src/node_stat.cc
|
2009-08-24 20:25:24 +02:00
|
|
|
src/node_stdio.cc
|
2009-10-27 11:46:58 +01:00
|
|
|
src/node_timer.cc
|
2010-01-18 19:12:04 +01:00
|
|
|
src/node_idle_watcher.cc
|
2009-04-04 14:50:15 +02:00
|
|
|
"""
|
2009-09-01 14:15:29 +02:00
|
|
|
node.includes = """
|
2009-04-04 14:50:15 +02:00
|
|
|
src/
|
|
|
|
deps/v8/include
|
|
|
|
deps/libev
|
2009-07-28 12:29:18 +02:00
|
|
|
deps/udns
|
2009-04-04 14:50:15 +02:00
|
|
|
deps/libeio
|
2009-07-25 17:52:21 +02:00
|
|
|
deps/evcom
|
2009-05-03 14:09:16 +02:00
|
|
|
deps/http_parser
|
2009-08-24 20:25:24 +02:00
|
|
|
deps/coupling
|
2009-04-04 14:50:15 +02:00
|
|
|
"""
|
2009-10-27 22:26:53 +01:00
|
|
|
node.add_objects = 'ev eio evcom http_parser coupling'
|
|
|
|
node.uselib_local = ''
|
2010-01-27 03:34:42 +01:00
|
|
|
node.uselib = 'GNUTLS GPGERROR UDNS V8 EXECINFO DL KVM SOCKET NSL EFENCE'
|
2009-11-22 03:58:08 +01:00
|
|
|
|
2009-09-01 14:15:29 +02:00
|
|
|
node.install_path = '${PREFIX}/lib'
|
2009-04-23 19:26:56 +02:00
|
|
|
node.install_path = '${PREFIX}/bin'
|
|
|
|
node.chmod = 0755
|
|
|
|
|
2009-08-27 01:11:16 +02:00
|
|
|
def subflags(program):
|
2009-10-09 15:00:12 +02:00
|
|
|
if os.path.exists(join(cwd, ".git")):
|
2009-10-09 16:16:27 +02:00
|
|
|
actual_version=cmd_output("git describe").strip()
|
2009-10-09 15:00:12 +02:00
|
|
|
else:
|
|
|
|
actual_version=VERSION
|
|
|
|
|
2009-08-27 02:15:11 +02:00
|
|
|
x = { 'CCFLAGS' : " ".join(program.env["CCFLAGS"])
|
|
|
|
, 'CPPFLAGS' : " ".join(program.env["CPPFLAGS"])
|
|
|
|
, 'LIBFLAGS' : " ".join(program.env["LIBFLAGS"])
|
2009-10-09 15:00:12 +02:00
|
|
|
, 'VERSION' : actual_version
|
2009-08-27 02:15:11 +02:00
|
|
|
, 'PREFIX' : program.env["PREFIX"]
|
2009-08-27 01:11:16 +02:00
|
|
|
}
|
2009-10-03 22:42:03 +02:00
|
|
|
return x
|
2009-08-27 01:11:16 +02:00
|
|
|
|
2009-08-27 02:15:11 +02:00
|
|
|
# process file.pc.in -> file.pc
|
2009-10-09 15:00:12 +02:00
|
|
|
|
2009-08-27 02:15:11 +02:00
|
|
|
node_version = bld.new_task_gen('subst', before="cxx")
|
|
|
|
node_version.source = 'src/node_version.h.in'
|
|
|
|
node_version.target = 'src/node_version.h'
|
|
|
|
node_version.dict = subflags(node)
|
2009-08-31 11:14:34 +02:00
|
|
|
node_version.install_path = '${PREFIX}/include/node'
|
2009-08-27 01:11:16 +02:00
|
|
|
|
2009-04-23 17:29:31 +02:00
|
|
|
if bld.env["USE_DEBUG"]:
|
2009-06-20 15:07:10 +02:00
|
|
|
node_g = node.clone("debug")
|
|
|
|
node_g.target = "node_g"
|
2009-08-27 01:11:16 +02:00
|
|
|
|
2009-08-27 02:15:11 +02:00
|
|
|
node_version_g = node_version.clone("debug")
|
|
|
|
node_version_g.dict = subflags(node_g)
|
2009-08-31 11:14:34 +02:00
|
|
|
node_version_g.install_path = None
|
|
|
|
|
2009-08-27 01:11:16 +02:00
|
|
|
|
2009-08-31 11:14:34 +02:00
|
|
|
bld.install_files('${PREFIX}/include/node/', """
|
|
|
|
config.h
|
|
|
|
src/node.h
|
2009-10-27 20:17:03 +01:00
|
|
|
src/node_object_wrap.h
|
|
|
|
src/node_events.h
|
|
|
|
src/node_net.h
|
2009-10-03 22:42:03 +02:00
|
|
|
""")
|
|
|
|
|
|
|
|
# Only install the man page if it exists.
|
|
|
|
# Do 'make doc install' to build and install it.
|
|
|
|
if os.path.exists('doc/node.1'):
|
|
|
|
bld.install_files('${PREFIX}/share/man/man1/', 'doc/node.1')
|
|
|
|
|
|
|
|
bld.install_files('${PREFIX}/bin/', 'bin/*', chmod=0755)
|
2009-10-03 19:08:05 +02:00
|
|
|
|
|
|
|
# Why am I using two lines? Because WAF SUCKS.
|
2009-10-03 22:42:03 +02:00
|
|
|
bld.install_files('${PREFIX}/lib/node/wafadmin', 'tools/wafadmin/*.py')
|
|
|
|
bld.install_files('${PREFIX}/lib/node/wafadmin/Tools', 'tools/wafadmin/Tools/*.py')
|
2009-10-03 19:08:05 +02:00
|
|
|
|
2009-10-03 22:42:03 +02:00
|
|
|
bld.install_files('${PREFIX}/lib/node/libraries/', 'lib/*.js')
|
2009-10-27 18:11:07 +01:00
|
|
|
|
|
|
|
def shutdown():
|
|
|
|
Options.options.debug
|
|
|
|
# HACK to get binding.node out of build directory.
|
|
|
|
# better way to do this?
|
|
|
|
if not Options.commands['clean']:
|
|
|
|
if os.path.exists('build/default/node') and not os.path.exists('node'):
|
|
|
|
os.symlink('build/default/node', 'node')
|
|
|
|
if os.path.exists('build/debug/node_g') and not os.path.exists('node_g'):
|
|
|
|
os.symlink('build/debug/node_g', 'node_g')
|
|
|
|
else:
|
|
|
|
if os.path.exists('node'): os.unlink('node')
|
|
|
|
if os.path.exists('node_g'): os.unlink('node_g')
|