]> git.lyx.org Git - lyx.git/blobdiff - lib/scripts/prefTest.pl.in
FindAdv: Ignore comment-feature (but not its content)
[lyx.git] / lib / scripts / prefTest.pl.in
index 82c80aa8db2eaeaf3e1a1f365bb2ef226f4c81fd..d999b6a10bb01e5c9e42005c10c1a5137e707fe9 100755 (executable)
@@ -4,21 +4,34 @@
 use strict;
 use warnings;
 
-# Syntax: prefTest.pl [<var1>=<Subst1> [<var2>=<Subst> ...]] [[ctest parameters]]
+# Syntax: prefTest.pl [test|default] [<var1>=<Subst1> [<var2>=<Subst> ...]] [[ctest parameters]]
+# If the first parameter is "test"
+#       allow use of -shell-escape in converters and
+#       allow use of external programs
+# If the first parameter is "default"
+#       remove "-shell-escape" from converters and
+#       forbid use of external programs
+# Else
+#       allow use of -shell-escape in converters and
+#       do not change handling the use of external programs
+############################################################
+
+BEGIN  {
+  unshift(@INC, "@CMAKE_CURRENT_SOURCE_DIR@");
+}
+
+use prefTest;
 
 my $bindir = "@CMAKE_BINARY_DIR@";
 
 my $userdir = "$bindir/Testing/.lyx";
 
-sub createConvLine($);
-sub getConverters($);
-sub getConverter($);
-sub getNext($);
-
 my %allowedKeys = (
   "use_converter_needauth_forbidden" => ["true", "false"],
   "use_converter_needauth" => ["true", "false"],
   "allow_geometry_session" => ["false"],
+  "use_converter_cache" => ["true", "false"],
+  "converter_cache_maxage" => "integer",
     );
 
 my %Converter = ();
@@ -29,85 +42,42 @@ chdir($bindir);
 
 my %Subst = ();
 
-my $ctestparams = 0;
 my @ctestpars = ();
 
-&getConverters($userdir);
-
-for my $arg ("allow_geometry_session=false", @ARGV) {
-  if ($ctestparams) {
-    push(@ctestpars, $arg);
-  }
-  else {
-    if ($arg =~ /^([^=]+)=(.*)$/) {
-      my $key = $1;
-      my $value = $2;
-      my $valid = 0;
-      if (defined($allowedKeys{$key})) {
-       for my $val (@{$allowedKeys{$key}}) {
-         if ($val eq $value) {
-           $valid = 1;
-           last;
-         }
-       }
-      }
-      if ($valid) {
-       $Subst{$key} = [$value, 0];
-      }
-      else {
-       die("invalid key or value specified in \"$arg\"");
-      }
-    }
-    else {
-      $ctestparams = 1;
-      push(@ctestpars, $arg);
-    }
-  }
+my $shell_escapes = 1;
+my $handle_argv = "";
+if (defined($ARGV[0]) && ($ARGV[0] =~ /^(test|default)$/)) {
+  $handle_argv = $1;
+  shift(@ARGV);
 }
 
-if (%Subst) { # Try to do something only if a substitute is requested
-  if (open(FO, '>', "$userdir/preferences.tmp")) {
-    if (open(FI, "$userdir/preferences")) {
-      while (my $l = <FI>) {
-       for my $k (keys %Subst) {
-         if ($l =~ /^\\$k\b/) {
-           $l = "\\$k $Subst{$k}->[0]\n";
-           $Subst{$k}->[1] = 1;
-         }
-         elsif ($l =~ /^\\converter\s+(.*)$/) {
-           my $entry = &getConverter($1);
-           if (defined($entry)) {
-             my $key = $entry->[0];
-             if (defined($Converter{$key})) {
-               if (defined($Converter{$key}->[2])) {
-                 $l = "";
-               }
-               else {
-                 $Converter{$key}->[2] = 1;
-                 $l = &createConvLine($key);
-               }
-             }
-           }
-         }
-       }
-       print FO $l;
-      }
-    }
-    for my $k (keys %Subst) {
-      if ($Subst{$k}->[1] == 0) {
-       print FO "\\$k $Subst{$k}->[0]\n";
-      }
-    }
-    for my $key (keys %Converter) {
-      if (! defined($Converter{$key}->[2])) {
-       $Converter{$key}->[2] = 1;
-       my $l = &createConvLine($key);
-       print FO $l;
-      }
-    }
-    rename("$userdir/preferences.tmp", "$userdir/preferences");
-  }
+if ($handle_argv eq "test") {
+  @ctestpars = &getSubstitutes(\%allowedKeys, \%Subst,
+                              "allow_geometry_session=false",
+                              "use_converter_needauth_forbidden=false",
+                              "use_converter_needauth=false",
+                              "use_converter_cache=false",
+                              "converter_cache_maxage=" . 180*24*60*60,
+                              @ARGV);
+}
+elsif ($handle_argv eq "default") {
+  $shell_escapes = 0;
+  @ctestpars = &getSubstitutes(\%allowedKeys, \%Subst,
+                              "allow_geometry_session=false",
+                              "use_converter_needauth_forbidden=true",
+                              "use_converter_needauth=true",
+                              "use_converter_cache=true",
+                              "converter_cache_maxage=" . 61*24*60*60,
+                              @ARGV);
 }
+else {
+  @ctestpars = &getSubstitutes(\%allowedKeys, \%Subst,
+                              "allow_geometry_session=false", @ARGV);
+}
+
+&getConverters($userdir, \%Converter, $shell_escapes);
+
+&applyChanges($userdir, \%Subst, \%Converter, $shell_escapes);
 
 my $res = 0;
 if (@ctestpars) {
@@ -116,66 +86,3 @@ if (@ctestpars) {
 
 exit($res);
 
-sub createConvLine($)
-{
-  my ($key) = @_;
-  my $l = "\\converter $key \"$Converter{$key}->[0]\" \"$Converter{$key}->[1]\"\n";
-  return($l);
-}
-
-sub getConverters($)
-{
-  my ($userdir) = @_;
-
-  if (open(FI, "$userdir/lyxrc.defaults")) {
-    while (my $l = <FI>) {
-      if ($l =~ s/^\s*\\converter\s+//) {
-       my $entry = &getConverter($l);
-       if (defined($entry)) {
-         $Converter{$entry->[0]} = $entry->[1];
-       }
-      }
-    }
-  }
-}
-
-sub getConverter($)
-{
-  my ($l) = @_;
-  chomp($l);
-  my ($from, $to, $cmd, $par);
-  ($l, $from) = getNext($l);
-  return undef if ($from !~ /tex$/);
-  ($l, $to) = getNext($l);
-  return undef if ($to !~ /^(dvi|dvi3|pdf|pdf[23456])$/);
-  ($l, $cmd) = getNext($l);
-  if ($cmd !~ /\-shell-escape/) {
-    if ($cmd =~ /^(\S+)\s*(.*)$/) {
-      $cmd = "$1 -shell-escape $2";
-      $cmd =~ s/\s+$//;
-    }
-  }
-  ($l, $par) = getNext($l);
-  return undef if ($par !~ /^latex/);
-  my $key = "\"$from\" \"$to\"";
-  return([$key, [$cmd, $par]]);
-}
-
-sub getNext($)
-{
-  my ($l) = @_;
-  my $val = undef;
-
-  if ($l =~ /^\s*\"([^\"]*)\"\s*(.*)$/) {
-    $val = $1;
-    $l = $2;
-  }
-  elsif ($l =~ /^\s*(\S+)\s*(.*)$/) {
-    $val = $1;
-    $l = $2;
-  }
-  else {
-    exit(7);
-  }
-  return($l, $val);
-}