98_version.pm 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. # $Id: 98_version.pm 11987 2016-08-19 17:13:41Z markusbloch $
  2. package main;
  3. use strict;
  4. use warnings;
  5. sub version_Initialize($$) {
  6. $cmds{version} = { Fn => "CommandVersion",
  7. Hlp=>"[<filter>|revision] [noheader],print SVN version of loaded modules"};
  8. }
  9. #####################################
  10. sub
  11. CommandVersion($$)
  12. {
  13. my ($cl, $param) = @_;
  14. my $noheader = ($param =~ s/(?:^\s*|\s+)noheader\s*$//);
  15. eval { "test" =~ /$param/ };
  16. return "invalid filter regexp" if($@);
  17. my @ret;
  18. my $max = 0;
  19. my $modpath = (exists($attr{global}{modpath}) ? $attr{global}{modpath} : "");
  20. my @files = map {$INC{$_}} keys %INC;
  21. push @files, $0; # path to fhem.pl
  22. push @ret, cfgDB_svnId() if(configDBUsed());
  23. @files = () if($param && $param eq "revision");
  24. foreach my $fn (@files) {
  25. next unless($fn =~ /^(?:$modpath.?)?FHEM/ or $fn =~ /fhem.pl$/); # configDB
  26. my $mod_name = ($fn=~ /[\/\\]([^\/\\]+)$/ ? $1 : $fn);
  27. next if($param ne "" && $mod_name !~ /$param/);
  28. next if(grep(/$mod_name/, @ret));
  29. Log 4, "Looking for SVN Id in module $mod_name";
  30. $max = length($mod_name) if($max < length($mod_name));
  31. my $line;
  32. if(!open(FH, $fn)) {
  33. $line = "$fn: $!";
  34. if(configDBUsed()){
  35. Log 4, "Looking for module $mod_name in configDB to find SVN Id";
  36. $line = cfgDB_Fileversion($fn,$line);
  37. }
  38. } else {
  39. while(<FH>) {
  40. chomp;
  41. if(/#.*\$Id\:[^\$\n\r].+\$/) {
  42. $line = $_;
  43. last;
  44. }
  45. }
  46. close(FH);
  47. }
  48. $line = "No Id found for $mod_name" unless($line);
  49. push @ret, $line;
  50. }
  51. my $fhem_revision = version_getRevFromControls();
  52. $fhem_revision = "Latest Revision: $fhem_revision\n\n" if(defined($fhem_revision) && !$noheader);
  53. @ret = map {/\$Id\: (\S+?) (\d+?) (\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}Z \S+?) \$/ ? sprintf("%-".$max."s %5d %s",$1,$2,$3) : $_} @ret;
  54. @ret = sort {version_sortModules($a, $b)} grep {($param ne "" ? /$param/ : 1)} @ret;
  55. return "no loaded modules found that match: $param" if($param ne "" && $param ne "revision" && !@ret);
  56. return (((!$param && !$noheader) || $param eq "revision") ? $fhem_revision : "").
  57. ($noheader || !@ret ? "" : sprintf("%-".$max."s %s","File","Rev Last Change\n\n")).
  58. trim(join("\n", grep (($_ =~ /^fhem.pl|\d\d_/), @ret))."\n\n".
  59. join("\n", grep (($_ !~ /^fhem.pl|\d\d_/), @ret))
  60. );
  61. }
  62. #####################################
  63. sub version_sortModules($$)
  64. {
  65. my ($a, $b) = @_;
  66. $a =~ s/^(?:No Id found for |#\s*\$Id\: )//;
  67. $b =~ s/^(?:No Id found for |#\s*\$Id\: )//;
  68. my @a_vals = split(' ', $a);
  69. my @b_vals = split(' ', $b);
  70. # fhem.pl always at top
  71. return -1 if($a_vals[0] eq "fhem.pl");
  72. return 1 if($b_vals[0] eq "fhem.pl");
  73. $a_vals[0] =~ s/^\d\d_//;
  74. $b_vals[0] =~ s/^\d\d_//;
  75. return uc($a_vals[0]) cmp uc($b_vals[0]);
  76. }
  77. sub version_getRevFromControls(;$)
  78. {
  79. my ($name) = @_;
  80. $name = "fhem" unless(defined($name));
  81. my $control_file = AttrVal("global","modpath",".")."/FHEM/controls_$name.txt";
  82. my $revision;
  83. if(open(FH, $control_file)) {
  84. while(<FH>) {
  85. chomp;
  86. if(/^REV\s+(\S+.*)$/) {
  87. $revision = $1;
  88. last;
  89. }
  90. }
  91. close(FH);
  92. }
  93. return $revision;
  94. }
  95. 1;
  96. =pod
  97. =item command
  98. =item summary shows the version of FHEM and all loaded modules.
  99. =item summary_DE zeigt die Version von FHEM und allen geladenen Modulen an
  100. =begin html
  101. <a name="version"></a>
  102. <h3>version</h3>
  103. <ul>
  104. <code>version [&lt;filter&gt;|revision] [noheader]</code>
  105. <br><br>
  106. List the version of fhem.pl and all loaded modules. The optional parameter
  107. can be used to filter the ouput. The special filter value "revision" shows
  108. only the latest revision number since the last update.<br><br>
  109. The optional flag <code>noheader</code> disables the output of the header lines (Latest Revision, File, Rev, Last Change).
  110. <br><br>
  111. Example output of <code>version</code>:
  112. <ul>
  113. <code><br>
  114. Latest Revision: 10814<br><br>
  115. File&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Rev&nbsp;&nbsp;&nbsp;Last&nbsp;Change<br><br>
  116. fhem.pl&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10769&nbsp;2016-02-08&nbsp;12:11:51Z&nbsp;rudolfkoenig<br>
  117. 90_at.pm&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10048&nbsp;2015-11-29&nbsp;14:51:40Z&nbsp;rudolfkoenig<br>
  118. 98_autocreate.pm&nbsp;10165&nbsp;2015-12-13&nbsp;11:14:15Z&nbsp;rudolfkoenig<br>
  119. 00_CUL.pm&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10146&nbsp;2015-12-10&nbsp;10:17:42Z&nbsp;rudolfkoenig<br>
  120. 10_CUL_HM.pm&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10411&nbsp;2016-01-08&nbsp;15:18:17Z&nbsp;martinp876<br>
  121. ...
  122. </code>
  123. </ul>
  124. <br>
  125. Example output of <code>version fhem.pl</code>:
  126. <ul>
  127. <code><br>
  128. File&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Rev&nbsp;&nbsp;&nbsp;Last&nbsp;Change<br><br>
  129. fhem.pl&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10397&nbsp;2016-01-07&nbsp;08:36:49Z&nbsp;rudolfkoenig<br>
  130. </code>
  131. </ul>
  132. <br>
  133. Example output of <code>version fhem.pl noheader</code>:
  134. <ul>
  135. <code><br>
  136. fhem.pl&nbsp;10397&nbsp;2016-01-07&nbsp;08:36:49Z&nbsp;rudolfkoenig<br>
  137. </code>
  138. </ul>
  139. </ul>
  140. =end html
  141. =begin html_DE
  142. <a name="version"></a>
  143. <h3>version</h3>
  144. <ul>
  145. <code>version [&lt;filter&gt;|revision] [noheader]</code>
  146. <br><br>
  147. Gibt die Versionsinformation von fhem.pl und aller geladenen Module aus. Mit
  148. dem optionalen Parameter kann man die Ausgabe filtern. Der spezielle Filterwert "revision"
  149. zeigt nur die aktuellste Revisions-Nummer seit dem letzten Update an.
  150. <br><br>
  151. Der optionale Parameter <code>noheader</code> unterdr&uuml;ckt die Ausgabe des Listenkopfs (Latest Revision, File, Rev, Last Change).
  152. <br><br>
  153. Beispiel der Ausgabe von <code>version</code>:
  154. <ul>
  155. <code><br>
  156. Latest Revision: 10814<br><br>
  157. File&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Rev&nbsp;&nbsp;&nbsp;Last&nbsp;Change<br><br>
  158. fhem.pl&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10769&nbsp;2016-02-08&nbsp;12:11:51Z&nbsp;rudolfkoenig<br>
  159. 90_at.pm&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10048&nbsp;2015-11-29&nbsp;14:51:40Z&nbsp;rudolfkoenig<br>
  160. 98_autocreate.pm&nbsp;10165&nbsp;2015-12-13&nbsp;11:14:15Z&nbsp;rudolfkoenig<br>
  161. 00_CUL.pm&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10146&nbsp;2015-12-10&nbsp;10:17:42Z&nbsp;rudolfkoenig<br>
  162. 10_CUL_HM.pm&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10411&nbsp;2016-01-08&nbsp;15:18:17Z&nbsp;martinp876<br>
  163. ...
  164. </code>
  165. </ul>
  166. <br>
  167. Beispiel der Ausgabe von <code>version fhem</code>:
  168. <ul>
  169. <code><br>
  170. File&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Rev&nbsp;&nbsp;&nbsp;Last&nbsp;Change<br><br>
  171. fhem.pl&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;10769&nbsp;2016-02-08&nbsp;12:11:51Z&nbsp;rudolfkoenig<br>
  172. </code>
  173. </ul>
  174. <br>
  175. Beispiel der Ausgabe von <code>version fhem.pl noheader</code>:
  176. <ul>
  177. <code><br>
  178. fhem.pl&nbsp;10769&nbsp;2016-02-08&nbsp;12:11:51Z&nbsp;rudolfkoenig<br>
  179. </code>
  180. </ul>
  181. </ul>
  182. =end html_DE
  183. =cut