diff --git a/indra/newview/viewer_manifest.py b/indra/newview/viewer_manifest.py index 5456c264d3c8e3ab33702e5a3a50e18f3b1c2812..73631631e0ae60453787d81d33dd769622a498ee 100755 --- a/indra/newview/viewer_manifest.py +++ b/indra/newview/viewer_manifest.py @@ -32,6 +32,7 @@ import shutil import errno import json +import plistlib import random import re import stat @@ -343,7 +344,7 @@ def _symlinkf_prep_dst(self, src, dst): # 'dst' is itself a pathname. dstdir = os.path.dirname(dst) self.cmakedirs(dstdir) - return dstdir, dst + return (dstdir, dst) def _symlinkf(self, src, dst, catch): # helper for relsymlinkf() and symlinkf() @@ -875,9 +876,6 @@ def is_packaging_viewer(self): return True def construct(self): - global plistlib - import plistlib # only import for Darwin - # These are the names of the top-level application and the embedded # applications for the VMP and for the actual viewer, respectively. # These names, without the .app suffix, determine the flyover text for @@ -914,12 +912,8 @@ def construct(self): os.path.join('$(dirname "$0")', os.pardir, 'Resources', launcher_app), "SL_Launcher", # write this file "trampoline") # flag to add to list of copied files - # Script must be executable -- but os.chmod() is pretty low-level: - # if we just chmod(stat.S_IEXEC), we end up with NOTHING BUT x! - # Have to read the existing permissions bits, then supplement with - # x for (user, group, other). - os.chmod(trampoline, stat.S_IMODE(os.stat(trampoline).st_mode) - | stat.S_IXUSR | stat.S_IXGRP | stat.S_IXOTH) + # Script must be executable + self.run_command(["chmod", "+x", trampoline]) # Make a symlink to a nested app Frameworks directory that doesn't # yet exist. We shouldn't need this; the only things that need