From 9709dd2def24260ec2ea4fdc16e3a78fa206bbb9 Mon Sep 17 00:00:00 2001 From: ShizZy Date: Fri, 13 Sep 2013 17:46:27 -0400 Subject: added scm_rev_gen project to automatically create a header with the git revision on build --- src/common/scm_rev_gen.js | 80 ++++++++++++++++++++++++++++++++++++++++++ src/common/scm_rev_gen.vcxproj | 79 +++++++++++++++++++++++++++++++++++++++++ src/common/src/scm_rev.h | 4 +-- src/common/src/version.cpp | 2 +- 4 files changed, 162 insertions(+), 3 deletions(-) create mode 100644 src/common/scm_rev_gen.js create mode 100644 src/common/scm_rev_gen.vcxproj (limited to 'src') diff --git a/src/common/scm_rev_gen.js b/src/common/scm_rev_gen.js new file mode 100644 index 000000000..e3ca5e67b --- /dev/null +++ b/src/common/scm_rev_gen.js @@ -0,0 +1,80 @@ +var wshShell = new ActiveXObject("WScript.Shell") +var oFS = new ActiveXObject("Scripting.FileSystemObject"); + +var outfile = "./src/scm_rev.h"; +var cmd_revision = " rev-parse HEAD"; +var cmd_describe = " describe --always --long --dirty"; +var cmd_branch = " rev-parse --abbrev-ref HEAD"; + +function GetGitExe() +{ + for (var gitexe in {"git.cmd":1, "git":1}) + { + try + { + wshShell.Exec(gitexe); + return gitexe; + } + catch (e) + {} + } + + WScript.Echo("Cannot find git or git.cmd, check your PATH:\n" + + wshShell.ExpandEnvironmentStrings("%PATH%")); + WScript.Quit(1); +} + +function GetFirstStdOutLine(cmd) +{ + try + { + return wshShell.Exec(cmd).StdOut.ReadLine(); + } + catch (e) + { + // catch "the system cannot find the file specified" error + WScript.Echo("Failed to exec " + cmd + " this should never happen"); + WScript.Quit(1); + } +} + +function GetFileContents(f) +{ + try + { + return oFS.OpenTextFile(f).ReadAll(); + } + catch (e) + { + // file doesn't exist + return ""; + } +} + +// get info from git +var gitexe = GetGitExe(); +var revision = GetFirstStdOutLine(gitexe + cmd_revision); +var describe = GetFirstStdOutLine(gitexe + cmd_describe); +var branch = GetFirstStdOutLine(gitexe + cmd_branch); +var isMaster = +("master" == branch); + +// remove hash (and trailing "-0" if needed) from description +describe = describe.replace(/(-0)?-[^-]+(-dirty)?$/, '$2'); + +var out_contents = + "#define SCM_REV_STR \"" + revision + "\"\n" + + "#define SCM_DESC_STR \"" + describe + "\"\n" + + "#define SCM_BRANCH_STR \"" + branch + "\"\n" + + "#define SCM_IS_MASTER " + isMaster + "\n"; + +// check if file needs updating +if (out_contents == GetFileContents(outfile)) +{ + WScript.Echo(outfile + " current at " + describe); +} +else +{ + // needs updating - writeout current info + oFS.CreateTextFile(outfile, true).Write(out_contents); + WScript.Echo(outfile + " updated to " + describe); +} diff --git a/src/common/scm_rev_gen.vcxproj b/src/common/scm_rev_gen.vcxproj new file mode 100644 index 000000000..e1b413c56 --- /dev/null +++ b/src/common/scm_rev_gen.vcxproj @@ -0,0 +1,79 @@ + + + + + Debug + Win32 + + + Debug + x64 + + + Release + Win32 + + + Release + x64 + + + + + + + + + + + + {69F00340-5C3D-449F-9A80-958435C6CF06} + scm_rev_gen + scm_rev_gen + + + + Utility + false + Unicode + + + + + + + + + + + + + + + + + + + + + + + + + cscript /nologo /E:JScript "scm_rev_gen.js" + + + + + cscript /nologo /E:JScript "scm_rev_gen.js" + + + + + cscript /nologo /E:JScript "scm_rev_gen.js" + + + + + + \ No newline at end of file diff --git a/src/common/src/scm_rev.h b/src/common/src/scm_rev.h index cb4eccfd0..05ad76964 100644 --- a/src/common/src/scm_rev.h +++ b/src/common/src/scm_rev.h @@ -1,4 +1,4 @@ -#define SCM_REV_STR "7d11f8cedd7c135d96880f19ecbd3ff87a60a11f" -#define SCM_DESC_STR "3.5-254-dirty" +#define SCM_REV_STR "bfa6493324336066a1ef9d04f336faacae57d9f3" +#define SCM_DESC_STR "bfa6493" #define SCM_BRANCH_STR "master" #define SCM_IS_MASTER 1 diff --git a/src/common/src/version.cpp b/src/common/src/version.cpp index 47d7b52ad..d5cf10c3d 100644 --- a/src/common/src/version.cpp +++ b/src/common/src/version.cpp @@ -13,7 +13,7 @@ #define BUILD_TYPE_STR "" #endif -const char *scm_rev_str = "Dolphin " +const char *scm_rev_str = "Akiru " #if !SCM_IS_MASTER "[" SCM_BRANCH_STR "] " #endif -- cgit v1.2.3