summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xnative_client_sdk/src/tools/create_nmf.py33
-rwxr-xr-xnative_client_sdk/src/tools/tests/create_nmf_test.py26
-rw-r--r--ppapi/ppapi_nacl.gyp10
-rw-r--r--ppapi/ppapi_nacl_test_common.gypi9
4 files changed, 39 insertions, 39 deletions
diff --git a/native_client_sdk/src/tools/create_nmf.py b/native_client_sdk/src/tools/create_nmf.py
index dc7e552..de72408 100755
--- a/native_client_sdk/src/tools/create_nmf.py
+++ b/native_client_sdk/src/tools/create_nmf.py
@@ -466,16 +466,15 @@ def ParseExtraFiles(encoded_list, err):
def GetSDKRoot():
- """Returns the root directory of the NaCl SDK.
+ """Determine current NACL_SDK_ROOT, either via the environment variable
+ itself, or by attempting to derive it from the location of this script.
"""
- # This script should be installed in NACL_SDK_ROOT/tools. Assert that
- # the 'toolchain' folder exists within this directory in case, for
- # example, this script is moved to a different location.
- # During the Chrome build this script is sometimes run outside of
- # of an SDK but in these cases it should always be run with --objdump=
- # and --no-default-libpath which avoids the need to call this function.
- sdk_root = os.path.dirname(SCRIPT_DIR)
- assert(os.path.exists(os.path.join(sdk_root, 'toolchain')))
+ sdk_root = os.environ.get('NACL_SDK_ROOT')
+ if not sdk_root:
+ sdk_root = os.path.dirname(SCRIPT_DIR)
+ if not os.path.exists(os.path.join(sdk_root, 'toolchain')):
+ return None
+
return sdk_root
@@ -483,8 +482,12 @@ def FindObjdumpExecutable():
"""Derive path to objdump executable to use for determining shared
object dependencies.
"""
+ sdk_root = GetSDKRoot()
+ if not sdk_root:
+ return None
+
osname = getos.GetPlatform()
- toolchain = os.path.join(GetSDKRoot(), 'toolchain', '%s_x86_glibc' % osname)
+ toolchain = os.path.join(sdk_root, 'toolchain', '%s_x86_glibc' % osname)
objdump = os.path.join(toolchain, 'bin', 'x86_64-nacl-objdump')
if osname == 'win':
objdump += '.exe'
@@ -505,6 +508,10 @@ def GetDefaultLibPath(config):
"""
assert(config in ('Debug', 'Release'))
sdk_root = GetSDKRoot()
+ if not sdk_root:
+ # TOOD(sbc): output a warning here? We would also need to suppress
+ # the warning when run from the chromium build.
+ return []
osname = getos.GetPlatform()
libpath = [
@@ -573,8 +580,8 @@ def main(args):
help='Rename FOO as BAR',
action='append', default=[], metavar='FOO,BAR')
parser.add_argument('-x', '--extra-files',
- help='Add extra key:file tuple to the "files"'
- ' section of the .nmf',
+ help=('Add extra key:file tuple to the "files"' +
+ ' section of the .nmf'),
action='append', default=[], metavar='FILE')
parser.add_argument('-O', '--pnacl-optlevel',
help='Set the optimization level to N in PNaCl manifests',
@@ -662,7 +669,7 @@ def main(args):
pnacl_debug_optlevel=pnacl_debug_optlevel,
nmf_root=nmf_root)
- if options.output is None:
+ if not options.output:
sys.stdout.write(nmf.GetJson())
else:
with open(options.output, 'w') as output:
diff --git a/native_client_sdk/src/tools/tests/create_nmf_test.py b/native_client_sdk/src/tools/tests/create_nmf_test.py
index d71bee9..86a89a2 100755
--- a/native_client_sdk/src/tools/tests/create_nmf_test.py
+++ b/native_client_sdk/src/tools/tests/create_nmf_test.py
@@ -14,19 +14,17 @@ import unittest
SCRIPT_DIR = os.path.dirname(os.path.abspath(__file__))
TOOLS_DIR = os.path.dirname(SCRIPT_DIR)
DATA_DIR = os.path.join(TOOLS_DIR, 'lib', 'tests', 'data')
-BUILD_TOOLS_DIR = os.path.join(os.path.dirname(TOOLS_DIR), 'build_tools')
CHROME_SRC = os.path.dirname(os.path.dirname(os.path.dirname(TOOLS_DIR)))
MOCK_DIR = os.path.join(CHROME_SRC, 'third_party', 'pymock')
# For the mock library
sys.path.append(MOCK_DIR)
sys.path.append(TOOLS_DIR)
-sys.path.append(BUILD_TOOLS_DIR)
import build_paths
import create_nmf
import getos
-from mock import patch, Mock
+import mock
TOOLCHAIN_OUT = os.path.join(build_paths.OUT_DIR, 'sdk_tests', 'toolchain')
NACL_X86_GLIBC_TOOLCHAIN = os.path.join(TOOLCHAIN_OUT,
@@ -63,18 +61,24 @@ class TestPosixRelPath(unittest.TestCase):
class TestDefaultLibpath(unittest.TestCase):
- def setUp(self):
- patcher = patch('create_nmf.GetSDKRoot', Mock(return_value='/dummy/path'))
- patcher.start()
- self.addCleanup(patcher.stop)
-
- def testUsesSDKRoot(self):
- paths = create_nmf.GetDefaultLibPath('Debug')
+ def testWithoutNaClSDKRoot(self):
+ """GetDefaultLibPath wihtout NACL_SDK_ROOT set
+
+ In the absence of NACL_SDK_ROOT GetDefaultLibPath should
+ return the empty list."""
+ with mock.patch.dict('os.environ', clear=True):
+ paths = create_nmf.GetDefaultLibPath('Debug')
+ self.assertEqual(paths, [])
+
+ def testHonorNaClSDKRoot(self):
+ with mock.patch.dict('os.environ', {'NACL_SDK_ROOT': '/dummy/path'}):
+ paths = create_nmf.GetDefaultLibPath('Debug')
for path in paths:
self.assertTrue(path.startswith('/dummy/path'))
def testIncludesNaClPorts(self):
- paths = create_nmf.GetDefaultLibPath('Debug')
+ with mock.patch.dict('os.environ', {'NACL_SDK_ROOT': '/dummy/path'}):
+ paths = create_nmf.GetDefaultLibPath('Debug')
self.assertTrue(any(os.path.join('ports', 'lib') in p for p in paths),
"naclports libpath missing: %s" % str(paths))
diff --git a/ppapi/ppapi_nacl.gyp b/ppapi/ppapi_nacl.gyp
index aab96ef..bbad955 100644
--- a/ppapi/ppapi_nacl.gyp
+++ b/ppapi/ppapi_nacl.gyp
@@ -139,10 +139,6 @@
'--strip-all',
],
'create_nmf': '<(DEPTH)/native_client_sdk/src/tools/create_nmf.py',
- 'create_nmf_flags': [
- '--no-default-libpath',
- '--objdump=>(nacl_glibc_tc_root)/bin/x86_64-nacl-objdump',
- ],
'create_nonsfi_test_nmf': 'tests/create_nonsfi_test_nmf.py',
},
'conditions': [
@@ -153,6 +149,7 @@
# doesn't work on Windows.
'libdir_glibc64': '>(nacl_glibc_tc_root)/x86_64-nacl/lib',
'libdir_glibc32': '>(nacl_glibc_tc_root)/x86_64-nacl/lib32',
+ 'nacl_objdump': '>(nacl_glibc_tc_root)/bin/x86_64-nacl-objdump',
'nmf_glibc%': '<(PRODUCT_DIR)/>(nexe_target)_glibc.nmf',
},
'actions': [
@@ -168,7 +165,7 @@
'action': [
'python',
'>@(_inputs)',
- '>@(create_nmf_flags)',
+ '--objdump=>(nacl_objdump)',
'--output=>(nmf_glibc)',
'--stage-dependencies=<(PRODUCT_DIR)',
],
@@ -221,7 +218,6 @@
'action': [
'python',
'>@(_inputs)',
- '>@(create_nmf_flags)',
'--output=>(nmf_pnacl)',
],
'conditions': [
@@ -310,7 +306,6 @@
'action': [
'python',
'>@(_inputs)',
- '>@(create_nmf_flags)',
'--output=>(nmf_pnacl)',
],
},
@@ -334,7 +329,6 @@
'action': [
'python',
'>@(_inputs)',
- '>@(create_nmf_flags)',
'--output=>(nmf_pnacl)',
],
},
diff --git a/ppapi/ppapi_nacl_test_common.gypi b/ppapi/ppapi_nacl_test_common.gypi
index c5e8a6f..ea61327 100644
--- a/ppapi/ppapi_nacl_test_common.gypi
+++ b/ppapi/ppapi_nacl_test_common.gypi
@@ -110,10 +110,6 @@
'create_nmf': '<(DEPTH)/native_client_sdk/src/tools/create_nmf.py',
'create_nmf_args_portable%': [],
'create_nonsfi_test_nmf': '<(DEPTH)/ppapi/tests/create_nonsfi_test_nmf.py',
- 'create_nmf_args': [
- '--no-default-libpath',
- '--objdump=>(nacl_glibc_tc_root)/bin/x86_64-nacl-objdump',
- ],
},
'target_conditions': [
['generate_nmf==1 and build_newlib==1', {
@@ -125,7 +121,6 @@
'action': [
'python',
'>(create_nmf)',
- '>@(create_nmf_args)',
'--output=>(nmf_newlib)',
'>@(create_nmf_args_portable)',
],
@@ -156,6 +151,7 @@
# doesn't work on Windows.
'libdir_glibc64': '>(nacl_glibc_tc_root)/x86_64-nacl/lib',
'libdir_glibc32': '>(nacl_glibc_tc_root)/x86_64-nacl/lib32',
+ 'nacl_objdump': '>(nacl_glibc_tc_root)/bin/x86_64-nacl-objdump',
},
'actions': [
{
@@ -168,7 +164,7 @@
'action': [
'python',
'>@(_inputs)',
- '>@(create_nmf_args)',
+ '--objdump=>(nacl_objdump)',
'--output=>(nmf_glibc)',
'--path-prefix=>(nexe_target)_libs',
'--stage-dependencies=<(nacl_glibc_out_dir)',
@@ -205,7 +201,6 @@
'action': [
'python',
'>(create_nmf)',
- '>@(create_nmf_args)',
'--output=>(nmf_pnacl_newlib)',
'>(out_pnacl_newlib)',
'>@(create_nmf_args_portable)',