[Libreoffice-commits] .: bin/lo-set-version

Petr Mladek pmladek at kemper.freedesktop.org
Fri Nov 19 06:57:43 PST 2010


 bin/lo-set-version |  224 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 224 insertions(+)

New commits:
commit 114f63dfd2cb2f6de60f9d7465c3e1bdaf034ff6
Author: Petr Mladek <pmladek at suse.cz>
Date:   Fri Nov 19 15:54:35 2010 +0100

    lo-set-version: new helper script to increment version in the sources

diff --git a/bin/lo-set-version b/bin/lo-set-version
new file mode 100755
index 0000000..3cb7116
--- /dev/null
+++ b/bin/lo-set-version
@@ -0,0 +1,224 @@
+#!/usr/bin/perl
+    eval 'exec /usr/bin/perl -S $0 ${1+"$@"}'
+        if $running_under_some_shell;
+#!/usr/bin/perl
+
+use strict;
+use File::Copy;
+use File::Temp qw/ tempfile tempdir /;
+
+sub find_item($$)
+{
+    my ($file, $item) = @_;
+
+    open (FILE, "$file") ||
+        die "can't open \"$file\" for reading: $!\n";
+
+#    print "Looking for: $item\n";
+    my $found_value;
+    while ((my $line = <FILE>) && (!defined $found_value)) {
+        chomp $line;
+
+#        print "$line\n";
+        if ($line =~ /^(.*$item[\s\:=])\s*([^\s\)]*)/) {
+#            print "  found: $2\n";
+            $found_value="$2";
+        }
+    }
+    close (FILE);
+
+    return $found_value;
+}
+
+sub replace_items($$)
+{
+    my ($file, $p_items) = @_;
+
+    open (FILE, "$file") ||
+        die "can't open \"$file\" for reading: $!\n";
+
+    my ( $tmp_fh, $tmp_filename ) = tempfile( "$file.XXXXXX" );
+    if ( !defined $tmp_fh ) {
+        close (FILE);
+        die "Error: can't create temporary file: \"$file.XXXXXX\"\n";
+    }
+
+    while (my $line = <FILE>) {
+        chomp $line;
+
+        foreach my $item (keys %{$p_items})
+        {
+            if ($line =~ /^(.*$item[\s\:=]\s*)[^\s\)]*(.*)$/) {
+                $line = $1 . %{$p_items}->{$item} . $2;
+            }
+        }
+
+        print ${tmp_fh} "$line\n";
+    }
+    close (FILE);
+    close (${tmp_fh});
+
+    # preserve permissions on target file by applying them to temp file
+    my ( $mode, $uid, $gid ) = ( stat($file) )[ 2, 4, 5 ];
+    $mode = $mode & 07777;
+
+    chmod $mode, $tmp_filename;
+    chown $uid, $gid, $tmp_filename;
+
+    rename ($tmp_filename, $file) ||
+        die "Can't rename \"$tmp_filename\" to \"$file\": $!\n";
+}
+
+sub inc_ver($)
+{
+    my ($ver) = @_;
+    my $last_ver;
+
+    if ($ver =~ /.*(\d+)$/) {
+        $last_ver = $1;
+    } else {
+        die "Error: do not know how to increment: $ver\n";
+    }
+
+    my $new_last_ver = $last_ver + 1;
+    $ver =~ s/$last_ver$/$new_last_ver/;
+
+    return $ver;
+}
+
+sub get_versions($$)
+{
+    my ($p_config_files, $p_versions) = @_;
+
+    %{$p_versions}->{'minor.mk'}{'BUILD'} = find_item(%{$p_config_files}->{'minor.mk'}, "BUILD");
+    %{$p_versions}->{'openoffice.lst'}{'OOOPACKAGEVERSION'} = find_item (%{$p_config_files}->{'openoffice.lst'}, "OOOPACKAGEVERSION");
+    %{$p_versions}->{'openoffice.lst'}{'SHORT_PRODUCTEXTENSION'} = find_item (%{$p_config_files}->{'openoffice.lst'}, "SHORT_PRODUCTEXTENSION");
+}
+
+sub set_versions($$)
+{
+    my ($p_config_files, $p_versions) = @_;
+
+    foreach my $config (keys %{$p_config_files}) {
+        replace_items(%{$p_config_files}->{$config}, \%{%{$p_versions}->{$config}});
+    }
+}
+
+sub show_versions($)
+{
+    my ($p_versions) = @_;
+
+    print "Product version:       " . %{$p_versions}->{'openoffice.lst'}{'OOOPACKAGEVERSION'} . %{$p_versions}->{'openoffice.lst'}{'SHORT_PRODUCTEXTENSION'} . "\n";
+    print "Windows build Version: " . %{$p_versions}->{'minor.mk'}{'BUILD'} . "\n";
+}
+
+sub usage()
+{
+    print "This tool helps to modify LO versions in the git sources\n\n" .
+
+          "Usage:\n".
+          "\tlo-pack-sources [--help] [--show] [--inc] [--force-build=<ver>]\n" .
+          "\t                [--force-prod-micro=<ver>] build_dir\n" .
+
+          "Options:\n\n" .
+          "\t--help: print this help\n" .
+          "\t--show: show current version\n" .
+          "\t--inc:  increment current version (win build version and product\n" .
+          "\t        micro version)\n" .
+          "\t--force-build: force windows build version, e.g. 4567\n" .
+          "\t--force-prod-micro: force product micro version, .e.g. beta1\n" .
+          "\tbuild_dir: path to the clone of libreoffice/build; it expects\n" .
+          "\t           that other pieces are cloned in the clone subdirectory\n";
+}
+
+my $show;
+my $inc;
+my $build_dir;
+my $build_ver_force;
+my $prod_micro_ver_force;
+my %versions;
+my %config_files;
+
+###################
+# Arguments parsing
+###################
+
+for my $arg (@ARGV) {
+    if ($arg eq '--help' || $arg eq '-h') {
+        usage;
+        exit 0;
+    } elsif ($arg eq '--show') {
+        $show=1;
+    } elsif ($arg eq '--inc') {
+        $inc=1;
+    } elsif ($arg =~ '--force-build=(.*)') {
+        $build_ver_force=$1;
+    } elsif ($arg =~ '--force-prod-micro=(.*)') {
+        $prod_micro_ver_force=$1;
+    } elsif ($arg =~ /^-/ ) {
+        die "Error: unknown option: $arg\n";
+    } else {
+        if (! defined $build_dir) {
+            $build_dir = $arg;
+        } else {
+            die "Error: Too many arguments $arg\n";
+        }
+    }
+}
+
+###################
+# Initial checks
+###################
+
+unless ( defined $build_dir ) {
+    die "Error: undefined directory with build repo, try --help\n";
+}
+
+unless ( -d "$build_dir" ) {
+    die "Error: not a directory: $build_dir\n";
+}
+
+my $bootstrap_dir = "$build_dir/clone/bootstrap";
+unless ( -d "$bootstrap_dir" ) {
+    die "Error: not a directory: $bootstrap_dir\n";
+}
+
+# current versions
+
+$config_files{'minor.mk'} = "$bootstrap_dir/solenv/inc/minor.mk";
+$config_files{'openoffice.lst'} = "$bootstrap_dir/instsetoo_native/util/openoffice.lst";
+
+get_versions(\%config_files, \%versions);
+
+print "Current values:\n";
+print "---------------\n";
+show_versions(\%versions);
+
+if (defined $show) {
+    exit 0;
+}
+
+print "\n";
+unless (defined $inc || defined $build_ver_force || defined $prod_micro_ver_force) {
+    print "No change requested\n";
+    exit 0;
+}
+
+# new versions
+if ($inc) {
+    $versions{'minor.mk'}{'BUILD'} = inc_ver($versions{'minor.mk'}{'BUILD'});
+    $versions{'openoffice.lst'}{'SHORT_PRODUCTEXTENSION'} = inc_ver($versions{'openoffice.lst'}{'SHORT_PRODUCTEXTENSION'});
+}
+$versions{'minor.mk'}{'BUILD'} = $build_ver_force if (defined $build_ver_force);
+$versions{'openoffice.lst'}{'SHORT_PRODUCTEXTENSION'} = $prod_micro_ver_force if (defined $prod_micro_ver_force);
+
+# update also (Build:XXX) in the RSCREVISION variable
+$versions{'minor.mk'}{'Build'} = $versions{'minor.mk'}{'BUILD'};
+
+print "New values:\n";
+print "---------------\n";
+show_versions(\%versions);
+
+set_versions(\%config_files, \%versions);
+
+print "\nUpdate succeeded\n";


More information about the Libreoffice-commits mailing list