diff options
| author | Merov Linden <merov@lindenlab.com> | 2014-02-05 15:06:51 -0800 | 
|---|---|---|
| committer | Merov Linden <merov@lindenlab.com> | 2014-02-05 15:06:51 -0800 | 
| commit | f217aa7c8bce0d3fe3a98625a1dd5eabdefd9d21 (patch) | |
| tree | 2f99dc2bfb3586a8cbf3af787c1b407edc583abb | |
| parent | a355659513a29f5b36207a57351797d18023966d (diff) | |
| parent | cec62b7872db7a9ca52e3872b96bf36f6e271f77 (diff) | |
ACME-1299 : Pull merge Oz changes to viewer-manifest.py to pass Mac Build
| -rwxr-xr-x | indra/newview/viewer_manifest.py | 28 | 
1 files changed, 22 insertions, 6 deletions
| diff --git a/indra/newview/viewer_manifest.py b/indra/newview/viewer_manifest.py index 6f811ecb6d..dcff9163e0 100755 --- a/indra/newview/viewer_manifest.py +++ b/indra/newview/viewer_manifest.py @@ -38,7 +38,7 @@ viewer_dir = os.path.dirname(__file__)  # Put it FIRST because some of our build hosts have an ancient install of  # indra.util.llmanifest under their system Python!  sys.path.insert(0, os.path.join(viewer_dir, os.pardir, "lib", "python")) -from indra.util.llmanifest import LLManifest, main, proper_windows_path, path_ancestors, CHANNEL_VENDOR_BASE, RELEASE_CHANNEL +from indra.util.llmanifest import LLManifest, main, proper_windows_path, path_ancestors, CHANNEL_VENDOR_BASE, RELEASE_CHANNEL, ManifestError  try:      from llbase import llsd  except ImportError: @@ -821,11 +821,27 @@ class Darwin_i386_Manifest(ViewerManifest):                  keychain_pwd = open(keychain_pwd_path).read().rstrip()                  self.run_command('security unlock-keychain -p "%s" "%s/Library/Keychains/viewer.keychain"' % ( keychain_pwd, home_path ) ) -                self.run_command('codesign --verbose --force --keychain "%(home_path)s/Library/Keychains/viewer.keychain" --sign %(identity)r %(bundle)r' % { -                                 'home_path' : home_path, -                                 'identity': identity, -                                 'bundle': self.get_dst_prefix() -                }) +                signed=False +                sign_attempts=3 +                sign_retry_wait=15 +                while (not signed) and (sign_attempts > 0): +                    try: +                        sign_attempts-=1; +                        self.run_command( +                           'codesign --verbose --force --keychain "%(home_path)s/Library/Keychains/viewer.keychain" --sign %(identity)r %(bundle)r' % { +                               'home_path' : home_path, +                               'identity': identity, +                               'bundle': self.get_dst_prefix() +                               }) +                        signed=True # if no exception was raised, the codesign worked +                    except ManifestError, err: +                        if sign_attempts: +                            print >> sys.stderr, "codesign failed, waiting %d seconds before retrying" % sign_retry_wait +                            time.sleep(sign_retry_wait) +                            sign_retry_wait*=2 +                        else: +                            print >> sys.stderr, "Maximum codesign attempts exceeded; giving up" +                            raise          imagename="SecondLife_" + '_'.join(self.args['version']) | 
