X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=blobdiff_plain;f=commitid.scad.pl;h=ebdbe917a39a6cb73db24da322d83a22e85af045;hp=eb4846a954ee6cc3d136f6a7a884ff52c50e0031;hb=bf19d2a95b043beeab235234d8f2aaebf774c370;hpb=0882646568c9a77ff98ba93c4d9c7bf3a9aef97d diff --git a/commitid.scad.pl b/commitid.scad.pl index eb4846a..ebdbe91 100755 --- a/commitid.scad.pl +++ b/commitid.scad.pl @@ -52,6 +52,12 @@ $SIG{__WARN__} = sub { die @_; }; # # We can generate these forms: # +# In each case: +# if tree is dirty, * is suffixed or prefixed to count or commitid +# if tree has untracked files, + is added +# (where it is added depends on the Form; in any case it does not +# change the size, but steals space from digits) +# # Small3: # Small4: # Small5: @@ -63,19 +69,18 @@ $SIG{__WARN__} = sub { die @_; }; # git rev-list --first-parent --count HEAD # typically 3-4 characters but we allow for up to 6 # padded with zeroes; if too long we reduce mod 10^n -# eg -# Small4 1070 -# If tree is dirty, + or * is suffixed, reducing number of -# digits by 1. +# eg if the count is 123456 +# Small5 3456* +# Small8 __123456 (where _ are spaces) # # Small4S: # Small6S: Small6T: # Small8S: Small9T: # Small10S: # same but split into two lines (S) or three lines (T) eg -# Small4S 10 Small6t 1 -# 70 07 -# 0* +# Small4S 45 Small6T _3 +# 6* 45 +# 6* # # Git4 Git4S # Git6 Git6S Git6T @@ -83,10 +88,8 @@ $SIG{__WARN__} = sub { die @_; }; # Git9 Git9T # Git10 Git10S # git-rev-parse HEAD (prefix of requested length) -# eg -# Git6 82f2a2 -# If tree is dirty, + or * is suffixed to commitid, -# reducing number of hex digits by 1. +# eg if the commitid is abcdef0123... +# Git5 abcd* # Full3 # Full4 @@ -99,10 +102,18 @@ $SIG{__WARN__} = sub { die @_; }; # git-rev-list --first-parent --count HEAD # git-rev-parse HEAD # eg -# Full6 1070 -# 82f2a2 -# If tree is dirty, + or * is suffixed to count (but not to -# commitid) reducing number of digits by 1. +# Full6 abcdef Full8 abcdef01 +# 23456* _123456* +# +# Full6T +# Full9T +# Full12T +# Full15T +# as Full but commit is split over two lines +# for a 3-line message; eg +# Full9T abc +# de* +# 456 # # FontDemo # @@ -351,10 +362,19 @@ sub do_git () { gentextmodule_plusq("Git$sz", ljustt($sz, $git_object, $git_dirty)) if defined $git_object; - gentextmodule("Full$sz", - rjustt($sz, $git_count.$git_dirty), - ljustt($sz, $git_object, '')) - if defined $git_count && defined $git_object; + if (defined $git_count && defined $git_object) { + gentextmodule("Full$sz", + ljustt($sz, $git_object, ''), + rjustt($sz, $git_count.$git_dirty)); + + if (!($sz % 2)) { + my $e = $sz/2; + gentextmodule("Full".($e*3)."T", + ljustt($e*2, $git_object, $git_dirty) + =~ m/.{$e}/g, + rjustt($e, $git_count)); + } + } } }