Esempio n. 1
0
 def get_cef_commit_components(self):
     """ Returns CEF commit components. """
     if not bool(self._cef_commit):
         hash = git.get_hash(self.cef_path)
         number = git.get_commit_number(self.cef_path)
         self._cef_commit = {'HASH': hash, 'NUMBER': number}
     return self._cef_commit
Esempio n. 2
0
# script directory
script_dir = os.path.dirname(__file__)

# CEF root directory
cef_dir = os.path.abspath(os.path.join(script_dir, os.pardir))

# src directory
src_dir = os.path.abspath(os.path.join(cef_dir, os.pardir))

if not git.is_checkout(cef_dir):
    raise Exception('Not a valid checkout: %s' % (cef_dir))

# retrieve information for CEF
cef_url = git.get_url(cef_dir)
cef_rev = git.get_hash(cef_dir)
cef_commit_number = git.get_commit_number(cef_dir)

if not git.is_checkout(src_dir):
    raise Exception('Not a valid checkout: %s' % (src_dir))

# retrieve information for Chromium
chromium_url = git.get_url(src_dir)
chromium_rev = git.get_hash(src_dir)

date = get_date()

# Read and parse the version file (key=value pairs, one per line)
args = {}
read_version_file(os.path.join(cef_dir, 'VERSION'), args)
read_version_file(os.path.join(cef_dir, '../chrome/VERSION'), args)
Esempio n. 3
0
def write_version_header(header, chrome_version, cef_version, cpp_header_dir):
    """ Creates the header file for the current revision and Chrome version information
       if the information has changed or if the file doesn't already exist. """

    if not path_exists(chrome_version):
      raise Exception('Chrome version file '+chrome_version+' does not exist.')
    if not path_exists(cef_version):
      raise Exception('CEF version file '+cef_version+' does not exist.')

    args = {}
    read_version_file(chrome_version, args)
    read_version_file(cef_version, args)

    if path_exists(header):
        oldcontents = read_file(header)
    else:
        oldcontents = ''

    year = get_year()

    # if not git.is_checkout('.'):
    #    raise Exception('Not a valid checkout')

    commit_number = git.get_commit_number()
    commit_hash = git.get_hash()
    version = '%s.%s.%s.g%s' % (args['CEF_MAJOR'], args['BUILD'], commit_number, commit_hash[:7])

    # calculate api hashes
    api_hash_calculator = cef_api_hash(cpp_header_dir, verbose = False)
    api_hashes = api_hash_calculator.calculate()

    newcontents = '// Copyright (c) '+year+' Marshall A. Greenblatt. All rights reserved.\n'+\
                  '//\n'+\
                  '// Redistribution and use in source and binary forms, with or without\n'+\
                  '// modification, are permitted provided that the following conditions are\n'+\
                  '// met:\n'+\
                  '//\n'+\
                  '//    * Redistributions of source code must retain the above copyright\n'+\
                  '// notice, this list of conditions and the following disclaimer.\n'+\
                  '//    * Redistributions in binary form must reproduce the above\n'+\
                  '// copyright notice, this list of conditions and the following disclaimer\n'+\
                  '// in the documentation and/or other materials provided with the\n'+\
                  '// distribution.\n'+\
                  '//    * Neither the name of Google Inc. nor the name Chromium Embedded\n'+\
                  '// Framework nor the names of its contributors may be used to endorse\n'+\
                  '// or promote products derived from this software without specific prior\n'+\
                  '// written permission.\n'+\
                  '//\n'+\
                  '// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n'+\
                  '// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n'+\
                  '// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n'+\
                  '// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\n'+\
                  '// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\n'+\
                  '// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n'+\
                  '// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n'+\
                  '// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY\n'+\
                  '// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n'+\
                  '// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n'+\
                  '// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n'+\
                  '//\n'+\
                  '// ---------------------------------------------------------------------------\n'+\
                  '//\n'+\
                  '// This file is generated by the make_version_header.py tool.\n'+\
                  '//\n\n'+\
                  '#ifndef CEF_INCLUDE_CEF_VERSION_H_\n'+\
                  '#define CEF_INCLUDE_CEF_VERSION_H_\n\n'+\
                  '#define CEF_VERSION "' + version + '"\n'+\
                  '#define CEF_VERSION_MAJOR ' + args['CEF_MAJOR'] + '\n'+\
                  '#define CEF_COMMIT_NUMBER ' + commit_number + '\n'+\
                  '#define CEF_COMMIT_HASH "' + commit_hash + '"\n'+\
                  '#define COPYRIGHT_YEAR ' + year + '\n\n'+\
                  '#define CHROME_VERSION_MAJOR ' + args['MAJOR'] + '\n'+\
                  '#define CHROME_VERSION_MINOR ' + args['MINOR'] + '\n'+\
                  '#define CHROME_VERSION_BUILD ' + args['BUILD'] + '\n'+\
                  '#define CHROME_VERSION_PATCH ' + args['PATCH'] + '\n\n'+\
                  '#define DO_MAKE_STRING(p) #p\n'+\
                  '#define MAKE_STRING(p) DO_MAKE_STRING(p)\n\n'+\
                  '#ifndef APSTUDIO_HIDDEN_SYMBOLS\n\n'\
                  '#include "include/internal/cef_export.h"\n\n'+\
                  '#ifdef __cplusplus\n'+\
                  'extern "C" {\n'+\
                  '#endif\n\n'+\
                  '// The API hash is created by analyzing CEF header files for C API type\n'+\
                  '// definitions. The hash value will change when header files are modified\n'+\
                  '// in a way that may cause binary incompatibility with other builds. The\n'+\
                  '// universal hash value will change if any platform is affected whereas the\n'+\
                  '// platform hash values will change only if that particular platform is\n'+\
                  '// affected.\n'+\
                  '#define CEF_API_HASH_UNIVERSAL "' + api_hashes['universal'] + '"\n'+\
                  '#if defined(OS_WIN)\n'+\
                  '#define CEF_API_HASH_PLATFORM "' + api_hashes['windows'] + '"\n'+\
                  '#elif defined(OS_MACOSX)\n'+\
                  '#define CEF_API_HASH_PLATFORM "' + api_hashes['macosx'] + '"\n'+\
                  '#elif defined(OS_LINUX)\n'+\
                  '#define CEF_API_HASH_PLATFORM "' + api_hashes['linux'] + '"\n'+\
                  '#elif defined(OS_ANDROID)\n'+\
                  '#define CEF_API_HASH_PLATFORM "' + api_hashes['android'] + '"\n'+\
                  '#endif\n\n'+\
                  '// Returns CEF version information for the libcef library. The |entry|\n'+\
                  '// parameter describes which version component will be returned:\n'+\
                  '// 0 - CEF_VERSION_MAJOR\n'+\
                  '// 1 - CEF_COMMIT_NUMBER\n'+\
                  '// 2 - CHROME_VERSION_MAJOR\n'+\
                  '// 3 - CHROME_VERSION_MINOR\n'+\
                  '// 4 - CHROME_VERSION_BUILD\n'+\
                  '// 5 - CHROME_VERSION_PATCH\n'+\
                  '///\n'+\
                  'CEF_EXPORT int cef_version_info(int entry);\n\n'+\
                  '///\n'+\
                  '// Returns CEF API hashes for the libcef library. The returned string is owned\n'+\
                  '// by the library and should not be freed. The |entry| parameter describes which\n'+\
                  '// hash value will be returned:\n'+\
                  '// 0 - CEF_API_HASH_PLATFORM\n'+\
                  '// 1 - CEF_API_HASH_UNIVERSAL\n'+\
                  '// 2 - CEF_COMMIT_HASH\n'+\
                  '///\n'+\
                  'CEF_EXPORT const char* cef_api_hash(int entry);\n\n'+\
                  '#ifdef __cplusplus\n'+\
                  '}\n'+\
                  '#endif\n\n'+\
                  '#endif  // APSTUDIO_HIDDEN_SYMBOLS\n\n'+\
                  '#endif  // CEF_INCLUDE_CEF_VERSION_H_\n'
    if newcontents != oldcontents:
        write_file(header, newcontents)
        return True

    return False
Esempio n. 4
0
  cef_url = cef_info['url']
  cef_rev = cef_info['revision']
elif git.is_checkout(cef_dir):
  cef_url = git.get_url(cef_dir)
  cef_rev = git.get_svn_revision(cef_dir)
else:
  raise Exception('Not a valid checkout: %s' % (cef_dir))

# retrieve url and revision information for Chromium
if svn.is_checkout(src_dir):
  chromium_info = svn.get_svn_info(src_dir)
  chromium_url = chromium_info['url']
  chromium_rev = chromium_info['revision']
elif git.is_checkout(src_dir):
  chromium_url = git.get_url(src_dir)
  chromium_rev = git.get_hash(src_dir)
else:
  raise Exception('Not a valid checkout: %s' % (src_dir))

date = get_date()

# Read and parse the version file (key=value pairs, one per line)
args = {}
read_version_file(os.path.join(cef_dir, 'VERSION'), args)
read_version_file(os.path.join(cef_dir, '../chrome/VERSION'), args)

cef_ver = args['CEF_MAJOR']+'.'+args['BUILD']+'.'+cef_rev
chromium_ver = args['MAJOR']+'.'+args['MINOR']+'.'+args['BUILD']+'.'+args['PATCH']

# list of output directories to be archived
archive_dirs = []
Esempio n. 5
0
def write_svn_header(header):
    """ Creates the header file for the current revision
       if the information has changed or if the file doesn't already exist. """

    if path_exists(header):
        oldcontents = read_file(header)
    else:
        oldcontents = ''

    if not git.is_checkout(jcef_dir):
        raise Exception('Not a valid checkout')

    commit_number = git.get_commit_number(jcef_dir)
    commit_hash = git.get_hash(jcef_dir)

    year = get_year()

    # Read and parse the CEF version file.
    args = {}
    read_readme_file(os.path.join(options.cefpath, 'README.txt'), args)

    version = '%s.%s.%s.g%s' % (args['CEF_MAJOR'], args['CEF_BUILD'],
                                commit_number, commit_hash[:7])

    newcontents = '// Copyright (c) '+year+' The Chromium Embedded Framework Authors. All rights\n'+\
                  '// reserved. Use of this source code is governed by a BSD-style license that\n'+\
                  '// can be found in the LICENSE file.\n'+\
                  '//\n'+\
                  '// Redistribution and use in source and binary forms, with or without\n'+\
                  '// modification, are permitted provided that the following conditions are\n'+\
                  '// met:\n'+\
                  '//\n'+\
                  '//    * Redistributions of source code must retain the above copyright\n'+\
                  '// notice, this list of conditions and the following disclaimer.\n'+\
                  '//    * Redistributions in binary form must reproduce the above\n'+\
                  '// copyright notice, this list of conditions and the following disclaimer\n'+\
                  '// in the documentation and/or other materials provided with the\n'+\
                  '// distribution.\n'+\
                  '//    * Neither the name of Google Inc. nor the name Chromium Embedded\n'+\
                  '// Framework nor the names of its contributors may be used to endorse\n'+\
                  '// or promote products derived from this software without specific prior\n'+\
                  '// written permission.\n'+\
                  '//\n'+\
                  '// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n'+\
                  '// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n'+\
                  '// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n'+\
                  '// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\n'+\
                  '// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\n'+\
                  '// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n'+\
                  '// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n'+\
                  '// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY\n'+\
                  '// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n'+\
                  '// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n'+\
                  '// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n'+\
                  '//\n'+\
                  '// ---------------------------------------------------------------------------\n'+\
                  '//\n'+\
                  '// This file is generated by the make_version_header.py tool.\n'+\
                  '//\n\n'+\
                  '#ifndef JCEF_INCLUDE_JCEF_VERSION_H_\n'+\
                  '#define JCEF_INCLUDE_JCEF_VERSION_H_\n\n'+\
                  '#define JCEF_VERSION "' + version + '"\n'+\
                  '#define JCEF_COMMIT_NUMBER ' + commit_number + '\n'+\
                  '#define JCEF_COMMIT_HASH "' + commit_hash + '"\n'+\
                  '#define JCEF_COPYRIGHT_YEAR ' + year + '\n\n'+\
                  '#define DO_MAKE_STRING(p) #p\n'+\
                  '#define MAKE_STRING(p) DO_MAKE_STRING(p)\n\n'+\
                  '#endif  // JCEF_INCLUDE_JCEF_VERSION_H_\n'
    if newcontents != oldcontents:
        write_file(header, newcontents)
        return True

    return False
Esempio n. 6
0
def write_svn_header(header):
  """ Creates the header file for the current revision
       if the information has changed or if the file doesn't already exist. """

  if path_exists(header):
    oldcontents = read_file(header)
  else:
    oldcontents = ''

  if not git.is_checkout(jcef_dir):
    raise Exception('Not a valid checkout')

  commit_number = git.get_commit_number(jcef_dir)
  commit_hash = git.get_hash(jcef_dir)

  year = get_year()

  # Read and parse the CEF version file.
  args = {}
  read_readme_file(os.path.join(options.cefpath, 'README.txt'), args)

  version = '%s.%s.%s.g%s' % (args['CEF_MAJOR'], args['CEF_BUILD'],
                              commit_number, commit_hash[:7])

  newcontents = '// Copyright (c) '+year+' The Chromium Embedded Framework Authors. All rights\n'+\
                '// reserved. Use of this source code is governed by a BSD-style license that\n'+\
                '// can be found in the LICENSE file.\n'+\
                '//\n'+\
                '// Redistribution and use in source and binary forms, with or without\n'+\
                '// modification, are permitted provided that the following conditions are\n'+\
                '// met:\n'+\
                '//\n'+\
                '//    * Redistributions of source code must retain the above copyright\n'+\
                '// notice, this list of conditions and the following disclaimer.\n'+\
                '//    * Redistributions in binary form must reproduce the above\n'+\
                '// copyright notice, this list of conditions and the following disclaimer\n'+\
                '// in the documentation and/or other materials provided with the\n'+\
                '// distribution.\n'+\
                '//    * Neither the name of Google Inc. nor the name Chromium Embedded\n'+\
                '// Framework nor the names of its contributors may be used to endorse\n'+\
                '// or promote products derived from this software without specific prior\n'+\
                '// written permission.\n'+\
                '//\n'+\
                '// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n'+\
                '// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n'+\
                '// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n'+\
                '// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\n'+\
                '// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\n'+\
                '// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n'+\
                '// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n'+\
                '// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY\n'+\
                '// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n'+\
                '// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n'+\
                '// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n'+\
                '//\n'+\
                '// ---------------------------------------------------------------------------\n'+\
                '//\n'+\
                '// This file is generated by the make_version_header.py tool.\n'+\
                '//\n\n'+\
                '#ifndef JCEF_INCLUDE_JCEF_VERSION_H_\n'+\
                '#define JCEF_INCLUDE_JCEF_VERSION_H_\n\n'+\
                '#define JCEF_VERSION "' + version + '"\n'+\
                '#define JCEF_COMMIT_NUMBER ' + commit_number + '\n'+\
                '#define JCEF_COMMIT_HASH "' + commit_hash + '"\n'+\
                '#define JCEF_COPYRIGHT_YEAR ' + year + '\n\n'+\
                '#define DO_MAKE_STRING(p) #p\n'+\
                '#define MAKE_STRING(p) DO_MAKE_STRING(p)\n\n'+\
                '#endif  // JCEF_INCLUDE_JCEF_VERSION_H_\n'
  if newcontents != oldcontents:
    write_file(header, newcontents)
    return True

  return False
Esempio n. 7
0
# script directory
script_dir = os.path.dirname(__file__)

# JCEF root directory
jcef_dir = os.path.abspath(os.path.join(script_dir, os.pardir))

# Read and parse the CEF version file.
args = {}
read_readme_file(os.path.join(jcef_dir, 'jcef_build', 'README.txt'), args)

# retrieve url and revision information for CEF
if not git.is_checkout(jcef_dir):
    raise Exception('Not a valid checkout: %s' % (jcef_dir))

jcef_commit_number = git.get_commit_number(jcef_dir)
jcef_commit_hash = git.get_hash(jcef_dir)
jcef_url = git.get_url(jcef_dir)
jcef_ver = '%s.%s.%s.%s+g%s' % (args['CEF_MAJOR'], args['CEF_MINOR'],
                                args['CEF_PATCH'], jcef_commit_number,
                                jcef_commit_hash[:7])

date = get_date()

cef_ver = args['CEF_VER']
cef_url = args['CEF_URL']
chromium_ver = args['CHROMIUM_VER']
chromium_url = args['CHROMIUM_URL']

# create the README.TXT file
create_readme()
Esempio n. 8
0
  cef_url = cef_info['url']
  cef_rev = cef_info['revision']
elif git.is_checkout(cef_dir):
  cef_url = git.get_url(cef_dir)
  cef_rev = git.get_svn_revision(cef_dir)
else:
  raise Exception('Not a valid checkout: %s' % (cef_dir))

# retrieve url and revision information for Chromium
if svn.is_checkout(src_dir):
  chromium_info = svn.get_svn_info(src_dir)
  chromium_url = cef_info['url']
  chromium_rev = cef_info['revision']
elif git.is_checkout(src_dir):
  chromium_url = git.get_url(src_dir)
  chromium_rev = git.get_hash(src_dir, 'HEAD')
else:
  raise Exception('Not a valid checkout: %s' % (src_dir))

date = get_date()

# Read and parse the version file (key=value pairs, one per line)
args = {}
read_version_file(os.path.join(cef_dir, 'VERSION'), args)
read_version_file(os.path.join(cef_dir, '../chrome/VERSION'), args)

cef_ver = args['CEF_MAJOR']+'.'+args['BUILD']+'.'+cef_rev
chromium_ver = args['MAJOR']+'.'+args['MINOR']+'.'+args['BUILD']+'.'+args['PATCH']

# list of output directories to be archived
archive_dirs = []
Esempio n. 9
0
  sys.exit()

# script directory
script_dir = os.path.dirname(__file__)

# JCEF root directory
jcef_dir = os.path.abspath(os.path.join(script_dir, os.pardir, os.pardir))

# Read and parse the CEF version file.
args = {}
read_readme_file(os.path.join(jcef_dir, 'src/third_party/cef/'+platform+'/README.txt'), args)

# retrieve url and revision information for CEF
if not git.is_checkout(jcef_dir):
  raise Exception('Not a valid checkout: %s' % (cef_dir))

jcef_commit_number = git.get_commit_number(jcef_dir)
jcef_commit_hash = git.get_hash(jcef_dir)
jcef_url = git.get_url(jcef_dir)
jcef_ver = '%s.%s.%s.g%s' % (args['CEF_MAJOR'], args['CEF_BUILD'], jcef_commit_number, jcef_commit_hash[:7])

date = get_date()

cef_ver = args['CEF_VER']
cef_url = args['CEF_URL']
chromium_ver = args['CHROMIUM_VER']
chromium_url = args['CHROMIUM_URL']

# create the README.TXT file
create_readme()
Esempio n. 10
0
def write_version_header(header, chrome_version, cef_version, cpp_header_dir):
    """ Creates the header file for the current revision and Chrome version information
       if the information has changed or if the file doesn't already exist. """

    if not path_exists(chrome_version):
        raise Exception('Chrome version file ' + chrome_version +
                        ' does not exist.')
    if not path_exists(cef_version):
        raise Exception('CEF version file ' + cef_version + ' does not exist.')

    args = {}
    read_version_file(chrome_version, args)
    read_version_file(cef_version, args)

    if path_exists(header):
        oldcontents = read_file(header)
    else:
        oldcontents = ''

    year = get_year()

    if not git.is_checkout('.'):
        raise Exception('Not a valid checkout')

    commit_number = git.get_commit_number()
    commit_hash = git.get_hash()
    version = '%s.%s.%s.g%s' % (args['CEF_MAJOR'], args['BUILD'],
                                commit_number, commit_hash[:7])

    # calculate api hashes
    api_hash_calculator = cef_api_hash(cpp_header_dir, verbose=False)
    api_hashes = api_hash_calculator.calculate()

    newcontents = '// Copyright (c) '+year+' Marshall A. Greenblatt. All rights reserved.\n'+\
                  '//\n'+\
                  '// Redistribution and use in source and binary forms, with or without\n'+\
                  '// modification, are permitted provided that the following conditions are\n'+\
                  '// met:\n'+\
                  '//\n'+\
                  '//    * Redistributions of source code must retain the above copyright\n'+\
                  '// notice, this list of conditions and the following disclaimer.\n'+\
                  '//    * Redistributions in binary form must reproduce the above\n'+\
                  '// copyright notice, this list of conditions and the following disclaimer\n'+\
                  '// in the documentation and/or other materials provided with the\n'+\
                  '// distribution.\n'+\
                  '//    * Neither the name of Google Inc. nor the name Chromium Embedded\n'+\
                  '// Framework nor the names of its contributors may be used to endorse\n'+\
                  '// or promote products derived from this software without specific prior\n'+\
                  '// written permission.\n'+\
                  '//\n'+\
                  '// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n'+\
                  '// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n'+\
                  '// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n'+\
                  '// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\n'+\
                  '// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\n'+\
                  '// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n'+\
                  '// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n'+\
                  '// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY\n'+\
                  '// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n'+\
                  '// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n'+\
                  '// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n'+\
                  '//\n'+\
                  '// ---------------------------------------------------------------------------\n'+\
                  '//\n'+\
                  '// This file is generated by the make_version_header.py tool.\n'+\
                  '//\n\n'+\
                  '#ifndef CEF_INCLUDE_CEF_VERSION_H_\n'+\
                  '#define CEF_INCLUDE_CEF_VERSION_H_\n\n'+\
                  '#define CEF_VERSION "' + version + '"\n'+\
                  '#define CEF_VERSION_MAJOR ' + args['CEF_MAJOR'] + '\n'+\
                  '#define CEF_COMMIT_NUMBER ' + commit_number + '\n'+\
                  '#define CEF_COMMIT_HASH "' + commit_hash + '"\n'+\
                  '#define COPYRIGHT_YEAR ' + year + '\n\n'+\
                  '#define CHROME_VERSION_MAJOR ' + args['MAJOR'] + '\n'+\
                  '#define CHROME_VERSION_MINOR ' + args['MINOR'] + '\n'+\
                  '#define CHROME_VERSION_BUILD ' + args['BUILD'] + '\n'+\
                  '#define CHROME_VERSION_PATCH ' + args['PATCH'] + '\n\n'+\
                  '#define DO_MAKE_STRING(p) #p\n'+\
                  '#define MAKE_STRING(p) DO_MAKE_STRING(p)\n\n'+\
                  '#ifndef APSTUDIO_HIDDEN_SYMBOLS\n\n'\
                  '#include "include/internal/cef_export.h"\n\n'+\
                  '#ifdef __cplusplus\n'+\
                  'extern "C" {\n'+\
                  '#endif\n\n'+\
                  '// The API hash is created by analyzing CEF header files for C API type\n'+\
                  '// definitions. The hash value will change when header files are modified\n'+\
                  '// in a way that may cause binary incompatibility with other builds. The\n'+\
                  '// universal hash value will change if any platform is affected whereas the\n'+\
                  '// platform hash values will change only if that particular platform is\n'+\
                  '// affected.\n'+\
                  '#define CEF_API_HASH_UNIVERSAL "' + api_hashes['universal'] + '"\n'+\
                  '#if defined(OS_WIN)\n'+\
                  '#define CEF_API_HASH_PLATFORM "' + api_hashes['windows'] + '"\n'+\
                  '#elif defined(OS_MACOSX)\n'+\
                  '#define CEF_API_HASH_PLATFORM "' + api_hashes['macosx'] + '"\n'+\
                  '#elif defined(OS_LINUX)\n'+\
                  '#define CEF_API_HASH_PLATFORM "' + api_hashes['linux'] + '"\n'+\
                  '#endif\n\n'+\
                  '// Returns CEF version information for the libcef library. The |entry|\n'+\
                  '// parameter describes which version component will be returned:\n'+\
                  '// 0 - CEF_VERSION_MAJOR\n'+\
                  '// 1 - CEF_COMMIT_NUMBER\n'+\
                  '// 2 - CHROME_VERSION_MAJOR\n'+\
                  '// 3 - CHROME_VERSION_MINOR\n'+\
                  '// 4 - CHROME_VERSION_BUILD\n'+\
                  '// 5 - CHROME_VERSION_PATCH\n'+\
                  '///\n'+\
                  'CEF_EXPORT int cef_version_info(int entry);\n\n'+\
                  '///\n'+\
                  '// Returns CEF API hashes for the libcef library. The returned string is owned\n'+\
                  '// by the library and should not be freed. The |entry| parameter describes which\n'+\
                  '// hash value will be returned:\n'+\
                  '// 0 - CEF_API_HASH_PLATFORM\n'+\
                  '// 1 - CEF_API_HASH_UNIVERSAL\n'+\
                  '// 2 - CEF_COMMIT_HASH\n'+\
                  '///\n'+\
                  'CEF_EXPORT const char* cef_api_hash(int entry);\n\n'+\
                  '#ifdef __cplusplus\n'+\
                  '}\n'+\
                  '#endif\n\n'+\
                  '#endif  // APSTUDIO_HIDDEN_SYMBOLS\n\n'+\
                  '#endif  // CEF_INCLUDE_CEF_VERSION_H_\n'
    if newcontents != oldcontents:
        write_file(header, newcontents)
        return True

    return False
Esempio n. 11
0
  cef_url = cef_info['url']
  cef_rev = cef_info['revision']
elif git.is_checkout(cef_dir):
  cef_url = git.get_url(cef_dir)
  cef_rev = git.get_svn_revision(cef_dir)
else:
  raise Exception('Not a valid checkout: %s' % (cef_dir))

# retrieve url and revision information for Chromium
if svn.is_checkout(src_dir):
  chromium_info = svn.get_svn_info(src_dir)
  chromium_url = cef_info['url']
  chromium_rev = cef_info['revision']
elif git.is_checkout(src_dir):
  chromium_url = git.get_url(src_dir)
  chromium_rev = git.get_hash(src_dir, 'HEAD')
else:
  raise Exception('Not a valid checkout: %s' % (src_dir))

date = get_date()

# Read and parse the version file (key=value pairs, one per line)
args = {}
read_version_file(os.path.join(cef_dir, 'VERSION'), args)
read_version_file(os.path.join(cef_dir, '../chrome/VERSION'), args)

cef_ver = args['CEF_MAJOR']+'.'+args['BUILD']+'.'+cef_rev
chromium_ver = args['MAJOR']+'.'+args['MINOR']+'.'+args['BUILD']+'.'+args['PATCH']

# list of output directories to be archived
archive_dirs = []