From b8b8e45c01d4f91c2a2db0df57eda005821d1cad Mon Sep 17 00:00:00 2001 From: Stephen Gallagher Date: Tue, 19 Mar 2019 23:22:40 -0400 Subject: [PATCH 1/2] build: add --libdir flag to configure This will allow distribution packages to select an alternative location for the unofficial libnode.so. For example, on Fedora it will install into /usr/lib64 on 64-bit systems. Signed-off-by: Stephen Gallagher --- configure.py | 9 +++++++++ tools/install.py | 4 ++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/configure.py b/configure.py index 9f00c3c426ee48..fe2e868170c9ab 100755 --- a/configure.py +++ b/configure.py @@ -706,6 +706,14 @@ help='compile shared library for embedding node in another project. ' + '(This mode is not officially supported for regular applications)') +parser.add_argument('--libdir', + action='store', + dest='libdir', + default='lib', + help='a directory to install the shared library into relative to the ' + 'prefix. This is a no-op if --shared is not specified. ' + + '(This mode is not officially supported for regular applications)') + parser.add_argument('--without-v8-platform', action='store_true', dest='without_v8_platform', @@ -1323,6 +1331,7 @@ def configure_node(o): o['variables']['node_no_browser_globals'] = b(options.no_browser_globals) o['variables']['node_shared'] = b(options.shared) + o['variables']['libdir'] = options.libdir node_module_version = getmoduleversion.get_version() if options.dest_os == 'android': diff --git a/tools/install.py b/tools/install.py index ebf4b8afbf9dc6..053e5240b58dcd 100755 --- a/tools/install.py +++ b/tools/install.py @@ -169,14 +169,14 @@ def files(action): # install libnode.version.so so_name = 'libnode.' + re.sub(r'\.x$', '.so', variables.get('shlib_suffix')) - action([output_prefix + so_name], 'lib/' + so_name) + action([output_prefix + so_name], variables.get('libdir') + '/' + output_lib) # create symlink of libnode.so -> libnode.version.so (C++ addons compat) link_path = abspath(install_path, 'lib/libnode.so') try_symlink(so_name, link_path) else: output_lib = 'libnode.' + variables.get('shlib_suffix') - action([output_prefix + output_lib], 'lib/' + output_lib) + action([output_prefix + output_lib], variables.get('libdir') + '/' + output_lib) action(['deps/v8/tools/gdbinit'], 'share/doc/node/') action(['deps/v8/tools/lldb_commands.py'], 'share/doc/node/') From e4028d5bc4f550e6533d1c3087749be6a9217efa Mon Sep 17 00:00:00 2001 From: Stephen Gallagher Date: Tue, 23 Aug 2022 12:42:51 -0400 Subject: [PATCH 2/2] fix output_lib / so_name Bad copy-paste Co-authored-by: mscdex --- tools/install.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/install.py b/tools/install.py index 053e5240b58dcd..4b01d67da54e1f 100755 --- a/tools/install.py +++ b/tools/install.py @@ -169,7 +169,7 @@ def files(action): # install libnode.version.so so_name = 'libnode.' + re.sub(r'\.x$', '.so', variables.get('shlib_suffix')) - action([output_prefix + so_name], variables.get('libdir') + '/' + output_lib) + action([output_prefix + so_name], variables.get('libdir') + '/' + so_name) # create symlink of libnode.so -> libnode.version.so (C++ addons compat) link_path = abspath(install_path, 'lib/libnode.so')