Update CEF Automation Tool for Mac support (issue #373).

git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@312 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
Marshall Greenblatt 2011-10-12 09:30:29 +00:00
parent 20c129038f
commit 58b3d51bce
2 changed files with 48 additions and 24 deletions

View File

@ -24,22 +24,33 @@ def run(command_line, working_dir, depot_tools_dir=None):
sys.stdout.write('-------- Running "'+command_line+'" in "'+\ sys.stdout.write('-------- Running "'+command_line+'" in "'+\
working_dir+'"...'+"\n") working_dir+'"...'+"\n")
args = shlex.split(command_line.replace('\\', '\\\\')) args = shlex.split(command_line.replace('\\', '\\\\'))
return subprocess.check_call(args, cwd=working_dir, env=env, shell=True) return subprocess.check_call(args, cwd=working_dir, env=env,
shell=(sys.platform == 'win32'))
def check_url(url):
""" Check the URL and raise an exception if invalid. """
if ':' in url[:7]:
parts = url.split(':', 1)
if (parts[0] == 'http' or parts[0] == 'https') and \
parts[1] == urllib.quote(parts[1]):
return url
sys.stderr.write('Invalid URL: '+url+"\n")
raise Exception('Invalid URL: '+url)
def get_svn_info(path): def get_svn_info(path):
""" Retrieves the URL and revision from svn info. """ """ Retrieves the URL and revision from svn info. """
url = None; url = 'None'
rev = None; rev = 'None'
if path[0:4] == 'http' or os.path.exists(path): if path[0:4] == 'http' or os.path.exists(path):
try: try:
stream = os.popen('svn info '+path); stream = os.popen('svn info '+path)
for line in stream: for line in stream:
if line[0:4] == "URL:": if line[0:4] == "URL:":
url = line[5:-1]; url = check_url(line[5:-1])
elif line[0:9] == "Revision:": elif line[0:9] == "Revision:":
rev = line[10:-1]; rev = str(int(line[10:-1]))
except IOError, (errno, strerror): except IOError, (errno, strerror):
sys.stderr.write('Failed to read revision from "svn info": ' + strerror) sys.stderr.write('Failed to read svn info: '+strerror+"\n")
raise raise
return {'url': url, 'revision': rev} return {'url': url, 'revision': rev}
@ -100,7 +111,7 @@ script_dir = os.path.dirname(__file__)
if not options.url is None: if not options.url is None:
# set the CEF URL # set the CEF URL
cef_url = options.url cef_url = check_url(options.url)
if not options.revision is None: if not options.revision is None:
# set the CEF revision # set the CEF revision
@ -109,6 +120,9 @@ else:
# retrieve the CEF revision from the remote repo # retrieve the CEF revision from the remote repo
info = get_svn_info(cef_url) info = get_svn_info(cef_url)
cef_rev = info['revision'] cef_rev = info['revision']
if cef_rev == 'None':
sys.stderr.write('No SVN info for: '+cef_url+"\n")
raise Exception('No SVN info for: '+cef_url)
# Retrieve the Chromium URL and revision from the CEF repo # Retrieve the Chromium URL and revision from the CEF repo
compat_url = cef_url + "/CHROMIUM_BUILD_COMPATIBILITY.txt?r="+cef_rev compat_url = cef_url + "/CHROMIUM_BUILD_COMPATIBILITY.txt?r="+cef_rev
@ -127,8 +141,8 @@ try:
if not 'chromium_revision' in config: if not 'chromium_revision' in config:
raise Exception("Missing chromium_revision value") raise Exception("Missing chromium_revision value")
chromium_url = config['chromium_url'] chromium_url = check_url(config['chromium_url'])
chromium_rev = config['chromium_revision'] chromium_rev = str(int(config['chromium_revision']))
except Exception, e: except Exception, e:
sys.stderr.write('Failed to read URL and revision information from '+ \ sys.stderr.write('Failed to read URL and revision information from '+ \
compat_url+"\n") compat_url+"\n")
@ -139,24 +153,17 @@ if not os.path.exists(download_dir):
# create the download directory # create the download directory
os.makedirs(download_dir) os.makedirs(download_dir)
# check the operating system # set the expected script extension
platform = '';
script_ext = '';
if sys.platform == 'win32': if sys.platform == 'win32':
platform = 'windows'
script_ext = '.bat' script_ext = '.bat'
elif sys.platform == 'darwin': else:
platform = 'macosx'
script_ext = '.sh'
elif sys.platform == 'linux2':
platform = 'linux'
script_ext = '.sh' script_ext = '.sh'
# check if the "depot_tools" directory exists # check if the "depot_tools" directory exists
depot_tools_dir = os.path.join(download_dir, 'depot_tools') depot_tools_dir = os.path.join(download_dir, 'depot_tools')
if not os.path.exists(depot_tools_dir): if not os.path.exists(depot_tools_dir):
# checkout depot_tools # checkout depot_tools
run('svn checkout '+depot_tools_url+' '+depot_tools_dir, download_dir); run('svn checkout '+depot_tools_url+' '+depot_tools_dir, download_dir)
# check if the "chromium" directory exists # check if the "chromium" directory exists
chromium_dir = os.path.join(download_dir, 'chromium') chromium_dir = os.path.join(download_dir, 'chromium')
@ -263,18 +270,22 @@ elif cef_rev_changed or options.forceupdate:
if any_changed or options.forceupdate: if any_changed or options.forceupdate:
# create CEF projects # create CEF projects
run('cef_create_projects'+script_ext, cef_src_dir, depot_tools_dir) path = os.path.join(cef_src_dir, 'cef_create_projects'+script_ext)
run(path, cef_src_dir, depot_tools_dir)
if any_changed or options.forcebuild: if any_changed or options.forcebuild:
path = os.path.join(cef_tools_dir, 'build_projects'+script_ext)
if not options.nodebugbuild: if not options.nodebugbuild:
# make CEF Debug build # make CEF Debug build
run('build_projects'+script_ext+' Debug', cef_tools_dir, depot_tools_dir) run(path+' Debug', cef_tools_dir, depot_tools_dir)
if not options.noreleasebuild: if not options.noreleasebuild:
# make CEF Release build # make CEF Release build
run('build_projects'+script_ext+' Release', cef_tools_dir, depot_tools_dir) run(path+' Release', cef_tools_dir, depot_tools_dir)
if any_changed or options.forcedistrib: if any_changed or options.forcedistrib:
if not options.nodistrib: if not options.nodistrib:
# make CEF binary distribution # make CEF binary distribution
run('make_distrib'+script_ext, cef_tools_dir, depot_tools_dir) path = os.path.join(cef_tools_dir, 'make_distrib'+script_ext)
run(path, cef_tools_dir, depot_tools_dir)

13
tools/build_projects.sh Executable file
View File

@ -0,0 +1,13 @@
#!/bin/sh
if [ -z "$1" ]; then
echo "ERROR: Please specify a build target: Debug or Release"
else
if [ -z "$2" ]; then
PROJECT_NAME='cefclient'
else
PROJECT_NAME=$2
fi
xcodebuild -project ../cef.xcodeproj -configuration $1 -target $PROJECT_NAME
fi