2006-08-27 04:21:27 +00:00
|
|
|
'
|
|
|
|
' Contributor(s):
|
|
|
|
' Michael Jerris <mike@jerris.com>
|
|
|
|
' David A. Horner http://dave.thehorners.com
|
|
|
|
'----------------------------------------------
|
|
|
|
|
2006-08-17 19:58:55 +00:00
|
|
|
'On Error Resume Next
|
|
|
|
' **************
|
|
|
|
' Initialization
|
|
|
|
' **************
|
|
|
|
|
|
|
|
Set WshShell = CreateObject("WScript.Shell")
|
|
|
|
Set FSO = CreateObject("Scripting.FileSystemObject")
|
|
|
|
Set WshSysEnv = WshShell.Environment("SYSTEM")
|
|
|
|
Set xml = CreateObject("Microsoft.XMLHTTP")
|
2006-08-27 04:21:27 +00:00
|
|
|
Dim UseWgetEXE
|
|
|
|
|
|
|
|
On Error Resume Next
|
2006-08-17 19:58:55 +00:00
|
|
|
Set oStream = CreateObject("Adodb.Stream")
|
2006-08-27 04:21:27 +00:00
|
|
|
On Error Goto 0
|
|
|
|
|
|
|
|
If Not IsObject(oStream) Then
|
|
|
|
wscript.echo("Failed to create Adodb.Stream, using alternative download method.")
|
|
|
|
UseWgetEXE=true
|
|
|
|
Else
|
|
|
|
UseWgetEXE=false
|
|
|
|
End If
|
2006-08-28 02:01:41 +00:00
|
|
|
Randomize
|
2006-08-17 19:58:55 +00:00
|
|
|
Set objArgs = WScript.Arguments
|
|
|
|
quote=Chr(34)
|
|
|
|
ScriptDir=Left(WScript.ScriptFullName,Len(WScript.ScriptFullName)-Len(WScript.ScriptName))
|
|
|
|
UtilsDir=Showpath(ScriptDir)
|
2009-07-02 02:06:15 +00:00
|
|
|
ToolsBase="http://files.freeswitch.org/downloads/win32/"
|
2006-08-17 19:58:55 +00:00
|
|
|
|
2006-08-27 04:21:27 +00:00
|
|
|
If UseWgetEXE Then
|
|
|
|
GetWgetEXE UtilsDir
|
|
|
|
End If
|
2006-08-17 19:58:55 +00:00
|
|
|
|
|
|
|
GetCompressionTools UtilsDir
|
|
|
|
|
|
|
|
|
|
|
|
If objArgs.Count >=3 Then
|
|
|
|
Select Case objArgs(0)
|
|
|
|
Case "Get"
|
|
|
|
Wget objArgs(1), Showpath(objArgs(2))
|
|
|
|
Case "GetUnzip"
|
|
|
|
WgetUnCompress objArgs(1), Showpath(objArgs(2))
|
2009-12-03 19:43:38 +00:00
|
|
|
Case "GetUnzipSounds"
|
|
|
|
WgetSounds objArgs(1), objArgs(2), Showpath(objArgs(3)), objArgs(4)
|
2006-08-27 20:37:01 +00:00
|
|
|
Case "Version"
|
|
|
|
'CreateVersion(tmpFolder, VersionDir, includebase, includedest)
|
|
|
|
CreateVersion Showpath(objArgs(1)), Showpath(objArgs(2)), objArgs(3), objArgs(4)
|
2006-08-17 19:58:55 +00:00
|
|
|
End Select
|
|
|
|
End If
|
|
|
|
|
|
|
|
|
|
|
|
' *******************
|
|
|
|
' Utility Subroutines
|
|
|
|
' *******************
|
|
|
|
|
2009-12-03 19:43:38 +00:00
|
|
|
Sub WgetSounds(PrimaryName, Freq, DestFolder, VersionFile)
|
|
|
|
BaseURL = "http://files.freeswitch.org/freeswitch-sounds"
|
|
|
|
Set objFSO = CreateObject("Scripting.FileSystemObject")
|
|
|
|
Set objTextFile = objFSO.OpenTextFile(VersionFile,1)
|
|
|
|
Do Until objTextFile.AtEndOfStream
|
|
|
|
strLine = objTextFile.Readline
|
2009-12-03 20:11:40 +00:00
|
|
|
if Len(strLine) > 2 then
|
|
|
|
versionPos = InstrRev(strLine, " ", -1, 1)
|
|
|
|
name = Left(strLine, versionPos-1)
|
|
|
|
if name = PrimaryName Then
|
|
|
|
version = Right(strLine, Len(strLine) - versionPos)
|
|
|
|
Wscript.Echo "Sound name: " & name & " Version " & version
|
|
|
|
URL = BaseURL & "-" & name & "-" & Freq &"-" & version & ".tar.gz"
|
|
|
|
Wscript.Echo "URL: " & URL
|
|
|
|
WgetUnCompress URL, Showpath(DestFolder)
|
|
|
|
End If
|
|
|
|
End if
|
2009-12-03 19:43:38 +00:00
|
|
|
Loop
|
|
|
|
End Sub
|
2006-08-17 19:58:55 +00:00
|
|
|
|
|
|
|
Sub WgetUnCompress(URL, DestFolder)
|
|
|
|
If Right(DestFolder, 1) <> "\" Then DestFolder = DestFolder & "\" End If
|
|
|
|
StartPos = InstrRev(URL, "/", -1, 1)
|
|
|
|
strlength = Len(URL)
|
|
|
|
filename=Right(URL,strlength-StartPos)
|
|
|
|
NameEnd = InstrRev(filename, ".",-1, 1)
|
|
|
|
filestrlength = Len(filename)
|
|
|
|
filebase = Left(filename,NameEnd)
|
|
|
|
fileext = Right(filename, Len(filename) - NameEnd)
|
|
|
|
Wget URL, DestFolder
|
|
|
|
If fileext = "zip" Then
|
|
|
|
UnCompress Destfolder & filename, DestFolder & filebase
|
|
|
|
Else
|
|
|
|
UnCompress Destfolder & filename, DestFolder
|
|
|
|
End If
|
|
|
|
End Sub
|
|
|
|
|
|
|
|
Sub GetCompressionTools(DestFolder)
|
|
|
|
Dim oExec
|
2013-01-02 22:11:34 +00:00
|
|
|
Dim tries
|
|
|
|
|
2006-08-17 19:58:55 +00:00
|
|
|
If Right(DestFolder, 1) <> "\" Then DestFolder = DestFolder & "\" End If
|
2013-01-02 22:11:34 +00:00
|
|
|
tries = 0
|
|
|
|
While Not FSO.FileExists(DestFolder & "7za.exe") And tries < 2
|
|
|
|
WScript.Sleep(Int(10000*Rnd))
|
|
|
|
If Not FSO.FileExists(DestFolder & "7za.tag") And Not FSO.FileExists(DestFolder & "7za.exe") Then
|
2006-09-28 17:45:45 +00:00
|
|
|
Set MyFile = fso.CreateTextFile(DestFolder & "7za.tag", True)
|
|
|
|
MyFile.WriteLine("This file marks a pending download for 7za.exe so we don't download it twice at the same time")
|
|
|
|
MyFile.Close
|
|
|
|
|
|
|
|
Wget ToolsBase & "7za.exe", DestFolder
|
|
|
|
|
|
|
|
FSO.DeleteFile DestFolder & "7za.tag" ,true
|
|
|
|
Else
|
|
|
|
WScript.Sleep(5000)
|
2013-01-02 22:11:34 +00:00
|
|
|
tries = tries + 1
|
2006-09-28 17:45:45 +00:00
|
|
|
End If
|
2013-01-02 22:11:34 +00:00
|
|
|
WEnd
|
2006-08-17 19:58:55 +00:00
|
|
|
End Sub
|
|
|
|
|
2006-08-27 04:21:27 +00:00
|
|
|
Sub GetWgetEXE(DestFolder)
|
|
|
|
Dim oExec
|
|
|
|
If Right(DestFolder, 1) <> "\" Then DestFolder = DestFolder & "\" End If
|
|
|
|
If Not FSO.FileExists(DestFolder & "wget.exe") Then
|
|
|
|
Slow_Wget ToolsBase & "wget.exe", DestFolder
|
|
|
|
End If
|
|
|
|
End Sub
|
|
|
|
|
2013-01-04 19:53:05 +00:00
|
|
|
Function Strip(Str)
|
|
|
|
Set oRE = New Regexp
|
|
|
|
oRE.Pattern = "[\W_]"
|
|
|
|
oRE.Global = True
|
|
|
|
Strip=oRE.Replace(Str, "")
|
|
|
|
End Function
|
|
|
|
|
2006-08-17 19:58:55 +00:00
|
|
|
Sub UnCompress(Archive, DestFolder)
|
2013-01-04 19:53:05 +00:00
|
|
|
batname = "tmp" & Strip(Archive) & CStr(Int(10000*Rnd)) & ".bat"
|
|
|
|
wscript.echo("Extracting: " & Archive & " - using: " & batname)
|
2006-08-28 02:01:41 +00:00
|
|
|
Set MyFile = fso.CreateTextFile(UtilsDir & batname, True)
|
2006-08-17 19:58:55 +00:00
|
|
|
MyFile.WriteLine("@" & quote & UtilsDir & "7za.exe" & quote & " x " & quote & Archive & quote & " -y -o" & quote & DestFolder & quote )
|
|
|
|
MyFile.Close
|
2006-08-28 02:01:41 +00:00
|
|
|
Set oExec = WshShell.Exec(UtilsDir & batname)
|
2006-08-17 19:58:55 +00:00
|
|
|
Do
|
|
|
|
WScript.Echo OExec.StdOut.ReadLine()
|
|
|
|
Loop While Not OExec.StdOut.atEndOfStream
|
2012-10-12 04:00:04 +00:00
|
|
|
If FSO.FileExists(Left(Archive, Len(Archive)-3))Then
|
|
|
|
WScript.Sleep(100)
|
|
|
|
FSO.DeleteFile UtilsDir & batname, True
|
2006-08-28 02:01:41 +00:00
|
|
|
Set MyFile = fso.CreateTextFile(UtilsDir & batname, True)
|
2006-08-17 19:58:55 +00:00
|
|
|
MyFile.WriteLine("@" & quote & UtilsDir & "7za.exe" & quote & " x " & quote & Left(Archive, Len(Archive)-3) & quote & " -y -o" & quote & DestFolder & quote )
|
|
|
|
MyFile.Close
|
2006-08-28 02:01:41 +00:00
|
|
|
Set oExec = WshShell.Exec(UtilsDir & batname)
|
2006-08-17 19:58:55 +00:00
|
|
|
Do
|
|
|
|
WScript.Echo OExec.StdOut.ReadLine()
|
|
|
|
Loop While Not OExec.StdOut.atEndOfStream
|
|
|
|
WScript.Sleep(500)
|
|
|
|
FSO.DeleteFile Left(Archive, Len(Archive)-3) ,true
|
|
|
|
End If
|
2012-10-12 04:00:04 +00:00
|
|
|
If FSO.FileExists(Left(Archive, Len(Archive)-3) & "tar")Then
|
|
|
|
WScript.Sleep(100)
|
|
|
|
FSO.DeleteFile UtilsDir & batname, True
|
2006-08-28 02:01:41 +00:00
|
|
|
Set MyFile = fso.CreateTextFile(UtilsDir & batname, True)
|
2006-08-17 19:58:55 +00:00
|
|
|
MyFile.WriteLine("@" & quote & UtilsDir & "7za.exe" & quote & " x " & quote & Left(Archive, Len(Archive)-3) & "tar" & quote & " -y -o" & quote & DestFolder & quote )
|
|
|
|
MyFile.Close
|
2006-08-28 02:01:41 +00:00
|
|
|
Set oExec = WshShell.Exec(UtilsDir & batname)
|
2006-08-17 19:58:55 +00:00
|
|
|
Do
|
|
|
|
WScript.Echo OExec.StdOut.ReadLine()
|
|
|
|
Loop While Not OExec.StdOut.atEndOfStream
|
|
|
|
WScript.Sleep(500)
|
|
|
|
FSO.DeleteFile Left(Archive, Len(Archive)-3) & "tar",true
|
|
|
|
End If
|
|
|
|
|
|
|
|
WScript.Sleep(500)
|
2006-08-28 02:01:41 +00:00
|
|
|
If FSO.FileExists(UtilsDir & batname)Then
|
|
|
|
FSO.DeleteFile UtilsDir & batname, True
|
|
|
|
End If
|
2006-08-17 19:58:55 +00:00
|
|
|
End Sub
|
|
|
|
|
|
|
|
Sub Wget(URL, DestFolder)
|
|
|
|
StartPos = InstrRev(URL, "/", -1, 1)
|
|
|
|
strlength = Len(URL)
|
|
|
|
filename=Right(URL,strlength-StartPos)
|
|
|
|
If Right(DestFolder, 1) <> "\" Then DestFolder = DestFolder & "\" End If
|
|
|
|
|
|
|
|
Wscript.echo("Downloading: " & URL)
|
2006-08-27 04:21:27 +00:00
|
|
|
|
|
|
|
If UseWgetEXE Then
|
2006-08-28 02:01:41 +00:00
|
|
|
batname = "tmp" & CStr(Int(10000*Rnd)) & ".bat"
|
|
|
|
Set MyFile = fso.CreateTextFile(UtilsDir & batname, True)
|
2006-08-27 04:21:27 +00:00
|
|
|
MyFile.WriteLine("@cd " & quote & DestFolder & quote)
|
|
|
|
MyFile.WriteLine("@" & quote & UtilsDir & "wget.exe" & quote & " " & URL)
|
|
|
|
MyFile.Close
|
2006-08-28 02:01:41 +00:00
|
|
|
Set oExec = WshShell.Exec(UtilsDir & batname)
|
2006-08-27 04:21:27 +00:00
|
|
|
Do
|
|
|
|
WScript.Echo OExec.StdOut.ReadLine()
|
|
|
|
Loop While Not OExec.StdOut.atEndOfStream
|
|
|
|
|
|
|
|
Else
|
2006-08-17 19:58:55 +00:00
|
|
|
xml.Open "GET", URL, False
|
|
|
|
xml.Send
|
|
|
|
|
|
|
|
Const adTypeBinary = 1
|
|
|
|
Const adSaveCreateOverWrite = 2
|
|
|
|
Const adSaveCreateNotExist = 1
|
2006-08-27 04:21:27 +00:00
|
|
|
|
2006-08-17 19:58:55 +00:00
|
|
|
oStream.type = adTypeBinary
|
|
|
|
oStream.open
|
|
|
|
oStream.write xml.responseBody
|
|
|
|
oStream.savetofile DestFolder & filename, adSaveCreateOverWrite
|
|
|
|
oStream.close
|
2006-08-27 04:21:27 +00:00
|
|
|
End If
|
|
|
|
|
|
|
|
End Sub
|
|
|
|
|
|
|
|
Sub Slow_Wget(URL, DestFolder)
|
|
|
|
StartPos = InstrRev(URL, "/", -1, 1)
|
|
|
|
strlength = Len(URL)
|
|
|
|
filename=Right(URL,strlength-StartPos)
|
|
|
|
If Right(DestFolder, 1) <> "\" Then DestFolder = DestFolder & "\" End If
|
|
|
|
|
|
|
|
Wscript.echo("Downloading: " & URL)
|
|
|
|
xml.Open "GET", URL, False
|
|
|
|
xml.Send
|
|
|
|
|
|
|
|
const ForReading = 1 , ForWriting = 2 , ForAppending = 8
|
|
|
|
Set MyFile = fso.OpenTextFile(DestFolder & filename ,ForWriting, True)
|
|
|
|
For i = 1 to lenb(xml.responseBody)
|
|
|
|
MyFile.write Chr(Ascb(midb(xml.responseBody,i,1)))
|
|
|
|
Next
|
|
|
|
MyFile.Close()
|
|
|
|
|
2006-08-17 19:58:55 +00:00
|
|
|
End Sub
|
|
|
|
|
|
|
|
Function Showpath(folderspec)
|
|
|
|
Set f = FSO.GetFolder(folderspec)
|
|
|
|
showpath = f.path & "\"
|
|
|
|
End Function
|
2006-08-27 20:37:01 +00:00
|
|
|
|
2007-08-19 08:08:04 +00:00
|
|
|
|
|
|
|
Function FindVersionStringInConfigure(strConfigFile, strVersionString)
|
|
|
|
|
|
|
|
Set objRegEx = CreateObject("VBScript.RegExp")
|
|
|
|
objRegEx.Pattern = "[^#]AC_SUBST\(" & strVersionString & ".*\[([^\[]*)\]"
|
|
|
|
|
|
|
|
Set objFSO = CreateObject("Scripting.FileSystemObject")
|
|
|
|
Set objFile = objFSO.OpenTextFile(strConfigFile, 1)
|
|
|
|
strSearchString = objFile.ReadAll
|
|
|
|
objFile.Close
|
|
|
|
|
|
|
|
Set colMatches = objRegEx.Execute(strSearchString)
|
|
|
|
|
|
|
|
strResult = ""
|
|
|
|
If colMatches.Count > 0 Then
|
|
|
|
For Each strMatch in colMatches
|
|
|
|
strResult = objRegEx.Replace(strMatch.Value, "$1")
|
|
|
|
Next
|
|
|
|
End If
|
|
|
|
|
|
|
|
FindVersionStringInConfigure = strResult
|
|
|
|
|
|
|
|
End Function
|
|
|
|
|
2006-08-27 20:37:01 +00:00
|
|
|
Sub FindReplaceInFile(FileName, sFind, sReplace)
|
|
|
|
Const OpenAsASCII = 0 ' Opens the file as ASCII (TristateFalse)
|
|
|
|
Const OpenAsUnicode = -1 ' Opens the file as Unicode (TristateTrue)
|
|
|
|
Const OpenAsDefault = -2 ' Opens the file using the system default
|
|
|
|
|
|
|
|
Const OverwriteIfExist = -1
|
|
|
|
Const FailIfNotExist = 0
|
|
|
|
Const ForReading = 1
|
|
|
|
|
|
|
|
Set fOrgFile = FSO.OpenTextFile(FileName, ForReading, FailIfNotExist, OpenAsASCII)
|
|
|
|
sText = fOrgFile.ReadAll
|
|
|
|
fOrgFile.Close
|
|
|
|
sText = Replace(sText, sFind, sReplace)
|
|
|
|
Set fNewFile = FSO.CreateTextFile(FileName, OverwriteIfExist, OpenAsASCII)
|
|
|
|
fNewFile.WriteLine sText
|
|
|
|
fNewFile.Close
|
|
|
|
End Sub
|
|
|
|
|
2012-07-08 14:10:28 +00:00
|
|
|
Function ExecAndGetResult(tmpFolder, VersionDir, execStr)
|
|
|
|
|
|
|
|
Set MyFile = FSO.CreateTextFile(tmpFolder & "tmpExec.Bat", True)
|
|
|
|
MyFile.WriteLine("@" & "cd " & quote & VersionDir & quote)
|
|
|
|
MyFile.WriteLine("@" & execStr)
|
|
|
|
MyFile.Close
|
|
|
|
|
|
|
|
Set oExec = WshShell.Exec("cmd /C " & quote & tmpFolder & "tmpExec.Bat" & quote)
|
|
|
|
|
|
|
|
ExecAndGetResult = Trim(OExec.StdOut.ReadLine())
|
|
|
|
|
|
|
|
Do
|
|
|
|
Loop While Not OExec.StdOut.atEndOfStream
|
|
|
|
|
|
|
|
FSO.DeleteFile(tmpFolder & "tmpExec.Bat")
|
|
|
|
|
|
|
|
End Function
|
|
|
|
|
|
|
|
Function ExecAndGetExitCode(tmpFolder, VersionDir, execStr)
|
|
|
|
|
|
|
|
Set MyFile = FSO.CreateTextFile(tmpFolder & "tmpExec.Bat", True)
|
|
|
|
MyFile.WriteLine("@" & "cd " & quote & VersionDir & quote)
|
|
|
|
MyFile.WriteLine("@" & execStr)
|
|
|
|
MyFile.WriteLine("@exit %ERRORLEVEL%")
|
|
|
|
MyFile.Close
|
|
|
|
|
|
|
|
ExecAndGetExitCode = WshShell.Run("cmd /C " & quote & tmpFolder & "tmpExec.Bat" & quote, 0, True)
|
|
|
|
|
|
|
|
FSO.DeleteFile(tmpFolder & "tmpExec.Bat")
|
|
|
|
|
|
|
|
End Function
|
|
|
|
|
|
|
|
Function pd(n, totalDigits)
|
|
|
|
If totalDigits > len(n) then
|
|
|
|
pd = String(totalDigits-len(n),"0") & n
|
|
|
|
Else
|
|
|
|
pd = n
|
|
|
|
End If
|
|
|
|
End Function
|
|
|
|
|
|
|
|
Function GetTimeUTC()
|
|
|
|
|
|
|
|
iOffset = WshShell.RegRead("HKLM\System\CurrentControlSet\Control\TimeZoneInformation\ActiveTimeBias")
|
|
|
|
|
|
|
|
If IsNumeric(iOffset) Then
|
|
|
|
GetTimeUTC = DateAdd("n", iOffset, Now())
|
|
|
|
Else
|
|
|
|
GetTimeUTC = Now()
|
|
|
|
End If
|
|
|
|
|
|
|
|
End Function
|
|
|
|
|
2006-08-27 20:37:01 +00:00
|
|
|
Sub CreateVersion(tmpFolder, VersionDir, includebase, includedest)
|
|
|
|
Dim oExec
|
2007-08-19 08:08:04 +00:00
|
|
|
|
|
|
|
strVerMajor = FindVersionStringInConfigure(VersionDir & "configure.in", "SWITCH_VERSION_MAJOR")
|
|
|
|
strVerMinor = FindVersionStringInConfigure(VersionDir & "configure.in", "SWITCH_VERSION_MINOR")
|
|
|
|
strVerMicro = FindVersionStringInConfigure(VersionDir & "configure.in", "SWITCH_VERSION_MICRO")
|
|
|
|
strVerRev = FindVersionStringInConfigure(VersionDir & "configure.in", "SWITCH_VERSION_REVISION")
|
2012-08-10 12:47:10 +00:00
|
|
|
strVerHuman = FindVersionStringInConfigure(VersionDir & "configure.in", "SWITCH_VERSION_REVISION_HUMAN")
|
2007-08-19 08:08:04 +00:00
|
|
|
|
2012-05-15 14:18:02 +00:00
|
|
|
'Set version to the one reported by configure.in
|
2012-06-05 13:44:22 +00:00
|
|
|
If strVerRev <> "" Then
|
2012-05-15 14:18:02 +00:00
|
|
|
VERSION = strVerRev
|
|
|
|
End If
|
2008-12-10 21:24:03 +00:00
|
|
|
|
2006-08-27 20:37:01 +00:00
|
|
|
Dim sLastFile
|
2012-07-08 14:10:28 +00:00
|
|
|
Const ForReading = 1
|
2012-08-10 12:47:10 +00:00
|
|
|
Const ShowUnclean = False 'Don't show unclean state for now
|
2012-07-08 14:10:28 +00:00
|
|
|
|
|
|
|
'Try To read revision from git
|
|
|
|
If FSO.FolderExists(VersionDir & ".git") Then
|
|
|
|
'Get timestamp for last commit
|
|
|
|
strFromProc = ExecAndGetResult(tmpFolder, VersionDir, "git log -n1 --format=" & quote & "%%ct" & quote & " HEAD")
|
|
|
|
If IsNumeric(strFromProc) Then
|
|
|
|
lastChangedDateTime = DateAdd("s", strFromProc, "01/01/1970 00:00:00")
|
|
|
|
strLastCommit = YEAR(lastChangedDateTime) & Pd(Month(lastChangedDateTime), 2) & Pd(DAY(lastChangedDateTime), 2) & "T" & Pd(Hour(lastChangedDateTime), 2) & Pd(Minute(lastChangedDateTime), 2) & Pd(Second(lastChangedDateTime), 2) & "Z"
|
2012-09-26 13:16:28 +00:00
|
|
|
strLastCommitHuman = YEAR(lastChangedDateTime) & "-" & Pd(Month(lastChangedDateTime), 2) & "-" & Pd(DAY(lastChangedDateTime), 2) & " " & Pd(Hour(lastChangedDateTime), 2) & ":" & Pd(Minute(lastChangedDateTime), 2) & ":" & Pd(Second(lastChangedDateTime), 2) & "Z"
|
2012-07-08 14:10:28 +00:00
|
|
|
Else
|
2012-08-10 12:47:10 +00:00
|
|
|
strLastCommit = ""
|
|
|
|
strLastCommitHuman = ""
|
2012-07-08 14:10:28 +00:00
|
|
|
End If
|
|
|
|
|
|
|
|
'Get revision hash
|
|
|
|
strRevision = ExecAndGetResult(tmpFolder, VersionDir, "git rev-list -n1 --abbrev=10 --abbrev-commit HEAD")
|
2012-09-26 13:16:28 +00:00
|
|
|
strRevisionHuman = ExecAndGetResult(tmpFolder, VersionDir, "git rev-list -n1 --abbrev=7 --abbrev-commit HEAD")
|
2012-07-08 14:10:28 +00:00
|
|
|
|
2012-09-26 13:16:28 +00:00
|
|
|
If strLastCommit <> "" And strLastCommitHuman <> "" And strRevision <> "" And strRevisionHuman <> "" Then
|
2012-08-10 12:47:10 +00:00
|
|
|
'Bild version string
|
2012-08-24 13:24:18 +00:00
|
|
|
strGitVer = "+git~" & strLastCommit & "~" & strRevision
|
2012-09-26 13:16:28 +00:00
|
|
|
strVerHuman = "git " & strRevisionHuman & " " & strLastCommitHuman
|
2012-08-10 12:47:10 +00:00
|
|
|
|
|
|
|
'Check for local changes, if found, append to git revision string
|
|
|
|
If ShowUnclean Then
|
|
|
|
If ExecAndGetExitCode(tmpFolder, VersionDir, "git diff-index --quiet HEAD") <> 0 Then
|
|
|
|
lastChangedDateTime = GetTimeUTC()
|
|
|
|
strGitVer = strGitVer & "+unclean~" & YEAR(lastChangedDateTime) & Pd(Month(lastChangedDateTime), 2) & Pd(DAY(lastChangedDateTime), 2) & "T" & Pd(Hour(lastChangedDateTime), 2) & Pd(Minute(lastChangedDateTime), 2) & Pd(Second(lastChangedDateTime), 2) & "Z"
|
2012-09-26 13:16:28 +00:00
|
|
|
strVerHuman = strVerHuman & " unclean " & YEAR(lastChangedDateTime) & "-" & Pd(Month(lastChangedDateTime), 2) & "-" & Pd(DAY(lastChangedDateTime), 2) & " " & Pd(Hour(lastChangedDateTime), 2) & ":" & Pd(Minute(lastChangedDateTime), 2) & ":" & Pd(Second(lastChangedDateTime), 2) & "Z"
|
2012-08-10 12:47:10 +00:00
|
|
|
End If
|
|
|
|
End If
|
|
|
|
Else
|
|
|
|
strGitVer = ""
|
|
|
|
strVerHuman = ""
|
2012-07-08 14:10:28 +00:00
|
|
|
End If
|
|
|
|
|
2012-08-24 13:24:18 +00:00
|
|
|
VERSION=VERSION & strGitVer
|
2012-07-08 14:10:28 +00:00
|
|
|
|
|
|
|
sLastVersion = ""
|
2012-09-26 13:16:28 +00:00
|
|
|
Set sLastFile = FSO.OpenTextFile(tmpFolder & "lastversion", ForReading, True, OpenAsASCII)
|
2012-07-08 14:10:28 +00:00
|
|
|
If Not sLastFile.atEndOfStream Then
|
|
|
|
sLastVersion = sLastFile.ReadLine()
|
|
|
|
End If
|
|
|
|
sLastFile.Close
|
2010-04-16 04:00:29 +00:00
|
|
|
End If
|
2006-08-27 20:37:01 +00:00
|
|
|
|
2012-08-10 12:47:10 +00:00
|
|
|
If VERSION & " " & strVerHuman <> sLastVersion Then
|
2006-08-27 20:37:01 +00:00
|
|
|
Set MyFile = fso.CreateTextFile(tmpFolder & "lastversion", True)
|
2012-08-10 12:47:10 +00:00
|
|
|
MyFile.WriteLine(VERSION & " " & strVerHuman)
|
2006-08-27 20:37:01 +00:00
|
|
|
MyFile.Close
|
|
|
|
|
|
|
|
FSO.CopyFile includebase, includedest, true
|
2007-08-19 08:08:04 +00:00
|
|
|
FindReplaceInFile includedest, "@SWITCH_VERSION_REVISION@", VERSION
|
|
|
|
FindReplaceInFile includedest, "@SWITCH_VERSION_MAJOR@", strVerMajor
|
|
|
|
FindReplaceInFile includedest, "@SWITCH_VERSION_MINOR@", strVerMinor
|
|
|
|
FindReplaceInFile includedest, "@SWITCH_VERSION_MICRO@", strVerMicro
|
2012-08-10 12:47:10 +00:00
|
|
|
FindReplaceInFile includedest, "@SWITCH_VERSION_REVISION_HUMAN@", strVerHuman
|
2006-08-27 20:37:01 +00:00
|
|
|
End If
|
|
|
|
|
|
|
|
End Sub
|