forked from catchorg/Catch2
		
	
		
			
				
	
	
		
			157 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from  __future__ import  print_function
 | 
						|
 | 
						|
import os
 | 
						|
import sys
 | 
						|
import re
 | 
						|
import datetime
 | 
						|
import string
 | 
						|
 | 
						|
from scriptCommon import catchPath
 | 
						|
 | 
						|
versionParser = re.compile( r'(\s*Version\slibraryVersion)\s*\(\s*(.*)\s*,\s*(.*)\s*,\s*(.*)\s*,\s*\"(.*)\"\s*\).*' )
 | 
						|
includesParser = re.compile( r'\s*#include\s*"(.*)"' )
 | 
						|
guardParser = re.compile( r'\s*#.*TWOBLUECUBES_CATCH_.*_INCLUDED')
 | 
						|
defineParser = re.compile( r'\s*#define')
 | 
						|
ifParser = re.compile( r'\s*#ifndef TWOBLUECUBES_CATCH_.*_INCLUDED')
 | 
						|
endIfParser = re.compile( r'\s*#endif // TWOBLUECUBES_CATCH_.*_INCLUDED')
 | 
						|
ifImplParser = re.compile( r'\s*#ifdef CATCH_CONFIG_RUNNER' )
 | 
						|
commentParser1 = re.compile( r'^\s*/\*')
 | 
						|
commentParser2 = re.compile( r'^\s*\*')
 | 
						|
blankParser = re.compile( r'^\s*$')
 | 
						|
seenHeaders = set([])
 | 
						|
rootPath = os.path.join( catchPath, 'include/' )
 | 
						|
versionPath = os.path.join( rootPath, "internal/catch_version.hpp" )
 | 
						|
readmePath = os.path.join( catchPath, "README.md" )
 | 
						|
outputPath = os.path.join( catchPath, 'single_include/catch.hpp' )
 | 
						|
 | 
						|
bumpVersion = True
 | 
						|
includeImpl = True
 | 
						|
 | 
						|
for arg in sys.argv[1:]:
 | 
						|
    arg = string.lower(arg)
 | 
						|
    if arg == "nobump":
 | 
						|
        bumpVersion = False
 | 
						|
        print( "Not bumping version number" )
 | 
						|
    elif arg == "noimpl":
 | 
						|
        includeImpl = False
 | 
						|
        bumpVersion = False
 | 
						|
        print( "Not including impl code (and not bumping version)" )
 | 
						|
    else:
 | 
						|
        print( "\n** Unrecognised argument: " + arg + " **\n" )
 | 
						|
        exit(1)
 | 
						|
 | 
						|
out = open( outputPath, 'w' )
 | 
						|
ifdefs = 0
 | 
						|
implIfDefs = -1
 | 
						|
 | 
						|
def write( line ):
 | 
						|
    if includeImpl or implIfDefs == -1:
 | 
						|
        out.write( line )
 | 
						|
 | 
						|
def parseFile( path, filename ):
 | 
						|
    global ifdefs
 | 
						|
    global implIfDefs
 | 
						|
 | 
						|
    f = open( path + filename, 'r' )
 | 
						|
    blanks = 0
 | 
						|
    for line in f:
 | 
						|
        if ifParser.match( line ):
 | 
						|
            ifdefs = ifdefs + 1
 | 
						|
        elif endIfParser.match( line ):
 | 
						|
            ifdefs = ifdefs - 1
 | 
						|
            if ifdefs == implIfDefs:
 | 
						|
                implIfDefs = -1
 | 
						|
        m = includesParser.match( line )
 | 
						|
        if m:
 | 
						|
            header = m.group(1)
 | 
						|
            headerPath, sep, headerFile = header.rpartition( "/" )
 | 
						|
            if not headerFile in seenHeaders:
 | 
						|
                if headerFile != "tbc_text_format.h" and headerFile != "clara.h":
 | 
						|
                    seenHeaders.add( headerFile )
 | 
						|
                write( "// #included from: {0}\n".format( header ) )
 | 
						|
                if( headerPath == "internal" and path.endswith( "internal/" ) ):
 | 
						|
                    headerPath = ""
 | 
						|
                    sep = ""
 | 
						|
                if os.path.exists( path + headerPath + sep + headerFile ):
 | 
						|
                    parseFile( path + headerPath + sep, headerFile )
 | 
						|
                else:
 | 
						|
                    parseFile( rootPath + headerPath + sep, headerFile )
 | 
						|
        else:
 | 
						|
            if ifImplParser.match(line):
 | 
						|
                implIfDefs = ifdefs
 | 
						|
            if (not guardParser.match( line ) or defineParser.match( line ) ) and not commentParser1.match( line )and not commentParser2.match( line ):
 | 
						|
                if blankParser.match( line ):
 | 
						|
                    blanks = blanks + 1
 | 
						|
                else:
 | 
						|
                    blanks = 0
 | 
						|
                if blanks < 2:
 | 
						|
                    write( line.rstrip() + "\n" )
 | 
						|
 | 
						|
class Version:
 | 
						|
    def __init__(self):
 | 
						|
        f = open( versionPath, 'r' )
 | 
						|
        for line in f:
 | 
						|
            m = versionParser.match( line )
 | 
						|
            if m:
 | 
						|
                self.variableDecl = m.group(1)
 | 
						|
                self.majorVersion = int(m.group(2))
 | 
						|
                self.minorVersion = int(m.group(3))
 | 
						|
                self.buildNumber = int(m.group(4))
 | 
						|
                self.branchName = m.group(5)
 | 
						|
        f.close()
 | 
						|
 | 
						|
    def incrementBuildNumber(self):
 | 
						|
        self.buildNumber = self.buildNumber+1
 | 
						|
 | 
						|
    def updateVersionFile(self):
 | 
						|
        f = open( versionPath, 'r' )
 | 
						|
        lines = []
 | 
						|
        for line in f:
 | 
						|
            m = versionParser.match( line )
 | 
						|
            if m:
 | 
						|
                lines.append( '{0}( {1}, {2}, {3}, "{4}" );'.format( self.variableDecl, self.majorVersion, self.minorVersion, self.buildNumber, self.branchName ) )
 | 
						|
            else:
 | 
						|
                lines.append( line.rstrip() )
 | 
						|
        f.close()
 | 
						|
        f = open( versionPath, 'w' )
 | 
						|
        for line in lines:
 | 
						|
            f.write( line + "\n" )
 | 
						|
 | 
						|
    def updateReadmeFile(self):
 | 
						|
        f = open( readmePath, 'r' )
 | 
						|
        lines = []
 | 
						|
        for line in f:
 | 
						|
            lines.append( line.rstrip() )
 | 
						|
        f.close()
 | 
						|
        f = open( readmePath, 'w' )
 | 
						|
        for line in lines:
 | 
						|
            if line.startswith( "*v" ):
 | 
						|
                f.write( '*v{0}.{1} build {2} ({3} branch)*\n'.format( self.majorVersion, self.minorVersion, self.buildNumber, self.branchName ) )
 | 
						|
            else:
 | 
						|
                f.write( line + "\n" )
 | 
						|
 | 
						|
def generateSingleInclude():
 | 
						|
    v = Version()
 | 
						|
    if bumpVersion:
 | 
						|
        v.incrementBuildNumber()
 | 
						|
        v.updateVersionFile()
 | 
						|
        v.updateReadmeFile()
 | 
						|
    out.write( "/*\n" )
 | 
						|
    out.write( " *  CATCH v{0}.{1} build {2} ({3} branch)\n".format( v.majorVersion, v.minorVersion, v.buildNumber, v.branchName ) )
 | 
						|
    out.write( " *  Generated: {0}\n".format( datetime.datetime.now() ) )
 | 
						|
    out.write( " *  ----------------------------------------------------------\n" )
 | 
						|
    out.write( " *  This file has been merged from multiple headers. Please don't edit it directly\n" )
 | 
						|
    out.write( " *  Copyright (c) 2012 Two Blue Cubes Ltd. All rights reserved.\n" )
 | 
						|
    out.write( " *\n" )
 | 
						|
    out.write( " *  Distributed under the Boost Software License, Version 1.0. (See accompanying\n" )
 | 
						|
    out.write( " *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)\n" )
 | 
						|
    out.write( " */\n" )
 | 
						|
    out.write( "#ifndef TWOBLUECUBES_SINGLE_INCLUDE_CATCH_HPP_INCLUDED\n" )
 | 
						|
    out.write( "#define TWOBLUECUBES_SINGLE_INCLUDE_CATCH_HPP_INCLUDED\n" )
 | 
						|
 | 
						|
    parseFile( rootPath, 'catch.hpp' )
 | 
						|
 | 
						|
    out.write( "#endif // TWOBLUECUBES_SINGLE_INCLUDE_CATCH_HPP_INCLUDED\n\n" )
 | 
						|
 | 
						|
generateSingleInclude()
 |