summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--SConstruct48
-rwxr-xr-xbuildscripts/errorcodes.py53
-rw-r--r--buildscripts/utils.py41
3 files changed, 98 insertions, 44 deletions
diff --git a/SConstruct b/SConstruct
index 2dd8ce37355..88e09fddd75 100644
--- a/SConstruct
+++ b/SConstruct
@@ -772,46 +772,6 @@ except OSError:
# --- check system ---
-def getGitBranch():
- if not os.path.exists( ".git" ):
- return None
-
- version = open( ".git/HEAD" ,'r' ).read().strip()
- if not version.startswith( "ref: " ):
- return version
- version = version.split( "/" )
- version = version[len(version)-1]
- return version
-
-def getGitBranchString( prefix="" , postfix="" ):
- t = re.compile( '[/\\\]' ).split( os.getcwd() )
- if len(t) > 2 and t[len(t)-1] == "mongo":
- par = t[len(t)-2]
- m = re.compile( ".*_([vV]\d+\.\d+)$" ).match( par )
- if m is not None:
- return prefix + m.group(1).lower() + postfix
- if par.find("Nightly") > 0:
- return ""
-
-
- b = getGitBranch()
- if b == None or b == "master":
- return ""
- return prefix + b + postfix
-
-def getGitVersion():
- if not os.path.exists( ".git" ):
- return "nogitversion"
-
- version = open( ".git/HEAD" ,'r' ).read().strip()
- if not version.startswith( "ref: " ):
- return version
- version = version[5:]
- f = ".git/" + version
- if not os.path.exists( f ):
- return version
- return open( f , 'r' ).read().strip()
-
def getSysInfo():
if windows:
return "windows " + str( sys.getwindowsversion() )
@@ -824,7 +784,7 @@ def add_exe(target):
return target
def setupBuildInfoFile( outFile ):
- version = getGitVersion()
+ version = utils.getGitVersion()
if len(moduleNames) > 0:
version = version + " modules: " + ','.join( moduleNames )
sysInfo = getSysInfo()
@@ -1387,7 +1347,7 @@ def recordPerformance( env, target, source ):
sub = { "benchmark": { "project": "http://github.com/mongodb/mongo", "description": "" }, "trial": {} }
sub[ "benchmark" ][ "name" ] = name
sub[ "benchmark" ][ "tags" ] = [ "c++", re.match( "(.*)__", name ).group( 1 ) ]
- sub[ "trial" ][ "server_hash" ] = getGitVersion()
+ sub[ "trial" ][ "server_hash" ] = utils.getGitVersion()
sub[ "trial" ][ "client_hash" ] = ""
sub[ "trial" ][ "result" ] = val
try:
@@ -1468,7 +1428,7 @@ def getDistName( sofar ):
return version
- return getGitBranchString( "" , "-" ) + today.strftime( "%Y-%m-%d" )
+ return utils.getGitBranchString( "" , "-" ) + today.strftime( "%Y-%m-%d" )
if distBuild:
@@ -1600,7 +1560,7 @@ def s3push( localName , remoteName=None , remotePrefix=None , fixName=True , pla
if remotePrefix is None:
if distName is None:
- remotePrefix = getGitBranchString( "-" ) + "-latest"
+ remotePrefix = utils.getGitBranchString( "-" ) + "-latest"
else:
remotePrefix = "-" + distName
diff --git a/buildscripts/errorcodes.py b/buildscripts/errorcodes.py
index a9243128c5a..d87b7adc520 100755
--- a/buildscripts/errorcodes.py
+++ b/buildscripts/errorcodes.py
@@ -3,6 +3,7 @@
import os
import sys
import re
+import utils
def getAllSourceFiles( arr=None , prefix="." ):
if arr is None:
@@ -43,6 +44,8 @@ def assignErrorCodes():
out.close()
+codes = []
+
def readErrorCodes( callback ):
ps = [ re.compile( "([um]asser(t|ted)) *\( *(\d+)" ) ,
re.compile( "(User|Msg)Exceptio(n)\( *(\d+)" )
@@ -52,6 +55,7 @@ def readErrorCodes( callback ):
for line in open( x ):
for p in ps:
for m in p.findall( line ):
+ codes.append( ( x , lineNum , line , m[2] ) )
callback( x , lineNum , line , m[2] )
lineNum = lineNum + 1
@@ -78,8 +82,57 @@ def checkErrorCodes():
readErrorCodes( checkDups )
return len( errors ) == 0
+def getBestMessage( err , start ):
+ err = err.partition( start )[2]
+ if not err:
+ return ""
+ err = err.partition( "\"" )[2]
+ if not err:
+ return ""
+ err = err.rpartition( "\"" )[0]
+ if not err:
+ return ""
+ return err
+
+def genErrorOutput():
+
+ g = utils.getGitVersion()
+
+ if os.path.exists( "docs/errors.md" ):
+ i = open( "docs/errors.md" , "r" )
+
+
+ out = open( "docs/errors.md" , 'w' )
+ out.write( "MongoDB Error Codes\n==========\n\n\n" )
+
+ prev = ""
+ seen = {}
+
+ codes.sort( key=lambda x: x[0]+"-"+x[3] )
+ for f,l,line,num in codes:
+ if num in seen:
+ continue
+ seen[num] = True
+
+ if f.startswith( "./" ):
+ f = f[2:]
+
+ if f != prev:
+ out.write( "\n\n" )
+ out.write( f + "\n----\n" )
+ prev = f
+
+ url = "http://github.com/mongodb/mongo/blob/" + g + "/" + f + "#L" + str(l)
+
+ out.write( "* " + str(num) + " [code](" + url + ") " + getBestMessage( line , str(num) ) + "\n" )
+
+ out.write( "\n" )
+ out.close()
+
if __name__ == "__main__":
ok = checkErrorCodes()
print( "ok:" + str( ok ) )
print( "next: " + str( getNextCode() ) )
+ if ok:
+ genErrorOutput()
diff --git a/buildscripts/utils.py b/buildscripts/utils.py
index faf48b21d41..1ca2fdd345f 100644
--- a/buildscripts/utils.py
+++ b/buildscripts/utils.py
@@ -5,6 +5,47 @@ import time
import os
# various utilities that are handy
+def getGitBranch():
+ if not os.path.exists( ".git" ):
+ return None
+
+ version = open( ".git/HEAD" ,'r' ).read().strip()
+ if not version.startswith( "ref: " ):
+ return version
+ version = version.split( "/" )
+ version = version[len(version)-1]
+ return version
+
+def getGitBranchString( prefix="" , postfix="" ):
+ t = re.compile( '[/\\\]' ).split( os.getcwd() )
+ if len(t) > 2 and t[len(t)-1] == "mongo":
+ par = t[len(t)-2]
+ m = re.compile( ".*_([vV]\d+\.\d+)$" ).match( par )
+ if m is not None:
+ return prefix + m.group(1).lower() + postfix
+ if par.find("Nightly") > 0:
+ return ""
+
+
+ b = getGitBranch()
+ if b == None or b == "master":
+ return ""
+ return prefix + b + postfix
+
+def getGitVersion():
+ if not os.path.exists( ".git" ):
+ return "nogitversion"
+
+ version = open( ".git/HEAD" ,'r' ).read().strip()
+ if not version.startswith( "ref: " ):
+ return version
+ version = version[5:]
+ f = ".git/" + version
+ if not os.path.exists( f ):
+ return version
+ return open( f , 'r' ).read().strip()
+
+
def execsys( args ):
import subprocess
if isinstance( args , str ):