]> git.zerfleddert.de Git - proxmark3-svn/blobdiff - tools/mkversion.pl
Update README.md
[proxmark3-svn] / tools / mkversion.pl
index 351bac91f0f894f3a182352e338eb30d71a22659..f726640e946b0aec7734ec5a6d66900a2507b4be 100644 (file)
@@ -3,70 +3,48 @@
 # Normally a couple of lines of bash would be enough (see openpcd project, original firmware by Harald Welte and Milosch Meriac)
 # but this will, at least in theory, also work on Windows with our current compile environment.
 # -- Henryk Plötz <henryk@ploetzli.ch> 2009-09-28
+# Modified april 2014 because of the move to github. 
+# --- Martin Holst Swende <martin@swende.se>
+# Modified january 2016 to work with Travis-CI
+# --- iceman <iceman@iuse.se>
 
-my $main_dir = shift;
-
-# Clear environment locale so that svn will not use localized strings
+# Clear environment locale so that git will not use localized strings
 $ENV{'LC_ALL'} = "C";
 $ENV{'LANG'} = "C";
 
-my $svnversion = 0;
-my $present = 0;
-my $clean = 2;
-my @compiletime = gmtime();
-
-# Strategy one: call svn info and extract last changed revision, call svn status and look for ^M
-if(open(SVNINFO, "svn info $main_dir|")) {
-       while(<SVNINFO>) {
-               if (/^Last Changed Rev: (.*)/) {
-                       $present = 1;
-                       $svnversion = $1;
-                       ## last; # Do not abort here, since SVN tends to complain about a Broken pipe
-               }
-       }
-       close(SVNINFO);
+my $githistory = `git fetch --all`;
+my $gitversion = `git describe --dirty`;
+my $gitbranch = `git rev-parse --abbrev-ref HEAD`;
+my $clean = $gitversion =~ '-dirty' ? 0 : 1;
+my @compiletime = localtime();
 
-       if(open(SVNSTATUS, "svn status $main_dir|")) {
-               $clean = 1;
-               while(<SVNSTATUS>) {
-                       if(/^M/) {
-                               $clean = 0;
-                               ## last;
-                       }
-               }
-               close(SVNINFO);
-       }
+my $fullgitinfo = 'iceman';
 
+if ( defined $gitbranch and defined $gitversion ) {
+       $fullgitinfo =  $fullgitinfo.'/'. $gitbranch . '/' . $gitversion;
 } else {
-       # Strategy two: look for .svn/entries. The third line should be "dir", the fourth line should contain
-       #  the currently checked out revision, the eleventh line should contain the last changed revision.
-       #  revision.
-       if(open(ENTRIES, "$main_dir/.svn/entries")) {
-               my $i = 1;
-               while(<ENTRIES>) {
-                       last if($i == 3 and !/^dir/);
-                       if($i == 11 and /^([0-9]*)/) {
-                               $present = 1;
-                               $svnversion = $1;
-                       }
-                       $i++;
-               }
-       }
+       $fullgitinfo =  $fullgitinfo.'/master/release-build (no_git)';
 }
 
+$fullgitinfo =~ s/(\s)//g;
+
+# Crop so it fits within 50 characters
+$fullgitinfo =~ s/.{50}\K.*//s;
+
 $compiletime[4] += 1;
 $compiletime[5] += 1900;
 my $ctime = sprintf("%6\$04i-%5\$02i-%4\$02i %3\$02i:%2\$02i:%1\$02i", @compiletime);
 
+
 print <<EOF
 #include "proxmark3.h"
 /* Generated file, do not edit */
-struct version_information __attribute__((section(".version_information"))) version_information = {
+const struct version_information __attribute__((section(".version_information"))) version_information = {
        VERSION_INFORMATION_MAGIC,
        1,
-       $present,
+       1,
        $clean,
-       "svn $svnversion",
+       "$fullgitinfo",
        "$ctime",
 };
 EOF
Impressum, Datenschutz