Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(132)

Side by Side Diff: chrome/tools/build/mac/keystone_install.sh

Issue 353007: Drop the com.apple.quarantine attribute after an update is applied (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 11 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/bin/bash 1 #!/bin/bash
2 2
3 # Copyright (c) 2009 The Chromium Authors. All rights reserved. 3 # Copyright (c) 2009 The Chromium Authors. All rights reserved.
4 # Use of this source code is governed by a BSD-style license that can be 4 # Use of this source code is governed by a BSD-style license that can be
5 # found in the LICENSE file. 5 # found in the LICENSE file.
6 6
7 # Called by the Keystone system to update the installed application with a new 7 # Called by the Keystone system to update the installed application with a new
8 # version from a disk image. 8 # version from a disk image.
9 9
10 # Return values: 10 # Return values:
(...skipping 289 matching lines...) Expand 10 before | Expand all | Expand 10 after
300 fi 300 fi
301 else 301 else
302 chown -Rh root:wheel "${DEST}" >& /dev/null 302 chown -Rh root:wheel "${DEST}" >& /dev/null
303 fi 303 fi
304 304
305 chmod -R "${CHMOD_MODE}" "${DEST}" >& /dev/null 305 chmod -R "${CHMOD_MODE}" "${DEST}" >& /dev/null
306 306
307 # On the Mac, or at least on HFS+, symbolic link permissions are significant, 307 # On the Mac, or at least on HFS+, symbolic link permissions are significant,
308 # but chmod -R and -h can't be used together on the Mac. Do another pass to 308 # but chmod -R and -h can't be used together on the Mac. Do another pass to
309 # fix the permissions on any symbolic links. 309 # fix the permissions on any symbolic links.
310 find "${DEST}" -type l -exec chmod -h "${CHMOD_MODE}" {} \; >& /dev/null 310 find "${DEST}" -type l -exec chmod -h "${CHMOD_MODE}" {} + >& /dev/null
311
312 # Host OS version check, to be able to take advantage of features on newer
313 # systems and fall back to slow ways of doing things on older systems.
314 OS_VERSION=$(sw_vers -productVersion)
315 OS_MAJOR=$(sed -Ene 's/^([0-9]+).*/\1/p' <<< ${OS_VERSION})
316 OS_MINOR=$(sed -Ene 's/^([0-9]+)\.([0-9]+).*/\2/p' <<< ${OS_VERSION})
317
318 # If an update is triggered from within the application itself, the update
319 # process inherits the quarantine bit (LSFileQuarantineEnabled). Any files or
320 # directories created during the update will be quarantined in that case,
321 # which may cause Launch Services to display quarantine UI. That's bad,
322 # especially if it happens when the outer .app launches a quarantined inner
323 # helper. If the application is already on the system and is being updated,
324 # then it can be assumed that it should not be quarantined. Use xattr to drop
325 # the quarantine attribute.
326 #
327 # TODO(mark): Instead of letting the quarantine attribute be set and then
328 # dropping it here, figure out a way to get the update process to run without
329 # LSFileQuarantineEnabled even when triggering an update from within the
330 # application.
331 QUARANTINE_ATTR=com.apple.quarantine
332 if [ ${OS_MAJOR} -gt 10 ] ||
333 ([ ${OS_MAJOR} -eq 10 ] && [ ${OS_MINOR} -ge 6 ]) ; then
334 # On 10.6, xattr supports -r for recursive operation.
335 xattr -d -r "${QUARANTINE_ATTR}" "${DEST}" >& /dev/null
336 else
337 # On earlier systems, xattr doesn't support -r, so run xattr via find.
338 find "${DEST}" -exec xattr -d "${QUARANTINE_ATTR}" {} + >& /dev/null
339 fi
311 340
312 # Great success! 341 # Great success!
313 exit 0 342 exit 0
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698