diff options
| -rwxr-xr-x | tests/runner.py | 35 | ||||
| -rw-r--r-- | tools/file_packager.py | 40 | 
2 files changed, 60 insertions, 15 deletions
| diff --git a/tests/runner.py b/tests/runner.py index e7434479..04baf47b 100755 --- a/tests/runner.py +++ b/tests/runner.py @@ -11822,6 +11822,9 @@ elif 'browser' in str(sys.argv):      def test_preload_file(self):        absolute_src_path = os.path.join(self.get_dir(), 'somefile.txt').replace('\\', '/')        open(absolute_src_path, 'w').write('''load me right before running the code please''') + +      absolute_src_path2 = os.path.join(self.get_dir(), '.somefile.txt').replace('\\', '/') +      open(absolute_src_path2, 'w').write('''load me right before running the code please''')        def make_main(path):          print path @@ -11846,6 +11849,7 @@ elif 'browser' in str(sys.argv):        test_cases = [         # (source preload-file string, file on target FS to load)          ("somefile.txt", "somefile.txt"), +        (".somefile.txt@somefile.txt", "somefile.txt"),          ("./somefile.txt", "somefile.txt"),          ("somefile.txt@file.txt", "file.txt"),          ("./somefile.txt@file.txt", "file.txt"), @@ -11874,11 +11878,13 @@ elif 'browser' in str(sys.argv):        # Test subdirectory handling with asset packaging.        os.makedirs(os.path.join(self.get_dir(), 'assets/sub/asset1/').replace('\\', '/')) +      os.makedirs(os.path.join(self.get_dir(), 'assets/sub/asset1/.git').replace('\\', '/')) # Test adding directory that shouldn't exist.        os.makedirs(os.path.join(self.get_dir(), 'assets/sub/asset2/').replace('\\', '/'))        open(os.path.join(self.get_dir(), 'assets/sub/asset1/file1.txt'), 'w').write('''load me right before running the code please''') +      open(os.path.join(self.get_dir(), 'assets/sub/asset1/.git/shouldnt_be_embedded.txt'), 'w').write('''this file should not get embedded''')        open(os.path.join(self.get_dir(), 'assets/sub/asset2/file2.txt'), 'w').write('''load me right before running the code please''')        absolute_assets_src_path = os.path.join(self.get_dir(), 'assets').replace('\\', '/') -      def make_main_two_files(path1, path2): +      def make_main_two_files(path1, path2, nonexistingpath):          open(os.path.join(self.get_dir(), 'main.cpp'), 'w').write(self.with_report_result(r'''            #include <stdio.h>            #include <string.h> @@ -11897,24 +11903,29 @@ elif 'browser' in str(sys.argv):              if (f == NULL)                result = 0;              fclose(f); +             +            f = fopen("%s", "r"); +            if (f != NULL) +              result = 0; +              REPORT_RESULT();              return 0;            } -        ''' % (path1, path2))) +        ''' % (path1, path2, nonexistingpath)))        test_cases = [ -       # (source directory to embed, file1 on target FS to load, file2 on target FS to load) -        ("assets", "assets/sub/asset1/file1.txt", "assets/sub/asset2/file2.txt"), -        ("assets/", "assets/sub/asset1/file1.txt", "assets/sub/asset2/file2.txt"), -        ("assets@/", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt"), -        ("assets/@/", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt"), -        ("assets@./", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt"), -        (absolute_assets_src_path + "@/", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt"), -        (absolute_assets_src_path + "@/assets", "/assets/sub/asset1/file1.txt", "/assets/sub/asset2/file2.txt")] +       # (source directory to embed, file1 on target FS to load, file2 on target FS to load, name of a file that *shouldn't* exist on VFS) +        ("assets", "assets/sub/asset1/file1.txt", "assets/sub/asset2/file2.txt", "assets/sub/asset1/.git/shouldnt_be_embedded.txt"), +        ("assets/", "assets/sub/asset1/file1.txt", "assets/sub/asset2/file2.txt", "assets/sub/asset1/.git/shouldnt_be_embedded.txt"), +        ("assets@/", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt", "/sub/asset1/.git/shouldnt_be_embedded.txt"), +        ("assets/@/", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt", "/sub/asset1/.git/shouldnt_be_embedded.txt"), +        ("assets@./", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt", "/sub/asset1/.git/shouldnt_be_embedded.txt"), +        (absolute_assets_src_path + "@/", "/sub/asset1/file1.txt", "/sub/asset2/file2.txt", "/sub/asset1/.git/shouldnt_be_embedded.txt"), +        (absolute_assets_src_path + "@/assets", "/assets/sub/asset1/file1.txt", "/assets/sub/asset2/file2.txt", "assets/sub/asset1/.git/shouldnt_be_embedded.txt")]        for test in test_cases: -        (srcpath, dstpath1, dstpath2) = test -        make_main_two_files(dstpath1, dstpath2) +        (srcpath, dstpath1, dstpath2, nonexistingpath) = test +        make_main_two_files(dstpath1, dstpath2, nonexistingpath)          print srcpath          Popen([PYTHON, EMCC, os.path.join(self.get_dir(), 'main.cpp'), '--preload-file', srcpath, '-o', 'page.html']).communicate()          self.run_browser('page.html', 'You should see |load me right before|.', '/report_result?1') diff --git a/tools/file_packager.py b/tools/file_packager.py index 1443d165..99180b93 100644 --- a/tools/file_packager.py +++ b/tools/file_packager.py @@ -39,7 +39,7 @@ TODO:        You can also provide .crn files yourself, pre-crunched. With this o               to dds files in the browser, exactly the same as if this tool compressed them.  ''' -import os, sys, shutil, random, uuid +import os, sys, shutil, random, uuid, ctypes  import shared  from shared import Compression, execute, suffix, unsuffixed @@ -50,6 +50,8 @@ if len(sys.argv) == 1:  See the source for more details.'''    sys.exit(0) +DEBUG = os.environ.get('EMCC_DEBUG') +  data_target = sys.argv[1]  IMAGE_SUFFIXES = ('.jpg', '.png', '.bmp') @@ -150,6 +152,32 @@ function assert(check, msg) {  }  ''' +# Win32 code to test whether the given file has the hidden property set. +def has_hidden_attribute(filepath): +  if sys.platform != 'win32': +    return False +     +  try: +    attrs = ctypes.windll.kernel32.GetFileAttributesW(unicode(filepath)) +    assert attrs != -1 +    result = bool(attrs & 2) +  except (AttributeError, AssertionError): +    result = False +  return result + +# The packager should never preload/embed any directories that have a component starting with '.' in them, +# or if the file is hidden (Win32). Note that this filter ONLY applies to directories. Explicitly specified single files +# are always preloaded/embedded, even if they start with a '.'. +def should_ignore(filename): +  if has_hidden_attribute(filename): +    return True +     +  components = filename.replace('\\\\', '/').replace('\\', '/').split('/') +  for c in components: +    if c.startswith('.'): +      return True +  return False +  # Expand directories into individual files  def add(arg, dirname, names):    # rootpathsrc: The path name of the root directory on the local FS we are adding to emscripten virtual FS. @@ -158,8 +186,12 @@ def add(arg, dirname, names):    for name in names:      fullname = os.path.join(dirname, name)      if not os.path.isdir(fullname): -      dstpath = os.path.join(rootpathdst, os.path.relpath(fullname, rootpathsrc)) # Convert source filename relative to root directory of target FS. -      data_files.append({ 'srcpath': fullname, 'dstpath': dstpath, 'mode': mode }) +      if should_ignore(fullname): +        if DEBUG: +          print >> sys.stderr, 'Skipping hidden file "' + fullname + '" from inclusion in the emscripten virtual file system.' +      else: +        dstpath = os.path.join(rootpathdst, os.path.relpath(fullname, rootpathsrc)) # Convert source filename relative to root directory of target FS. +        data_files.append({ 'srcpath': fullname, 'dstpath': dstpath, 'mode': mode })  for file_ in data_files:    if os.path.isdir(file_['srcpath']): @@ -171,6 +203,8 @@ for file_ in data_files:    if file_['dstpath'].endswith('/'): # If user has submitted a directory name as the destination but omitted the destination filename, use the filename from source file      file_['dstpath'] = file_['dstpath'] + os.path.basename(file_['srcpath'])    if file_['dstpath'].startswith('./'): file_['dstpath'] = file_['dstpath'][2:] # remove redundant ./ prefix +  if DEBUG: +    print >> sys.stderr, 'Packaging file "' + file_['srcpath'] + '" to VFS in path "' + file_['dstpath'] + '".'  # Remove duplicates (can occur naively, for example preload dir/, preload dir/subdir/)  seen = {} | 
