]> matita.cs.unibo.it Git - helm.git/commitdiff
added support for unload and reload of predefined stylesheets
authorStefano Zacchiroli <zack@upsilon.cc>
Wed, 9 Oct 2002 12:19:42 +0000 (12:19 +0000)
committerStefano Zacchiroli <zack@upsilon.cc>
Wed, 9 Oct 2002 12:19:42 +0000 (12:19 +0000)
helm/scripts/init.d/loadPredefinedStylesheets.pl

index 387a6fc2c6dcbfcc5acde0fd854b3fdbae9e188d..bf04ef4fb7d204b5c341214f5c9e6ff3415112f7 100755 (executable)
@@ -1,12 +1,18 @@
 #!/usr/bin/perl -w
 use strict;
 
-my $confile = $ENV{"UWOBO_PANEL_CONF"} || die "UWOBO_PANEL_CONF not defined";
-
 use LWP::UserAgent;
 use URI::Escape;
 
-sub getPredefinedStylesheets () {
+my $usage = <<EOHELP;
+loadPredefinedStylesheets.pl
+loadPredefinedStylesheets.pl { -u | --unload }
+loadPredefinedStylesheets.pl { -r | --reload }
+loadPredefinedStylesheets.pl { -h | --help }
+EOHELP
+
+sub getPredefinedStylesheets ($) {
+  my $confile = shift;
   my %stylesconf;
   my $inForm = 0; # currenlty inside 'predefinedStylesheets' form
   open(CONF, "< $confile") || die "Can't open $confile";
@@ -39,11 +45,19 @@ sub getPredefinedStylesheets () {
   return %stylesconf;
 }
 
-sub main () {
-  my $getter_url = $ENV{"HELM_GETTER_URL"} || die "HELM_GETTER_URL not defined";
-  my $uwobo_url = $ENV{"HELM_UWOBO_URL"} || die "HELM_UWOBO_URL not defined";
-  my %styles = getPredefinedStylesheets();
-  my $request_url = "";
+my $action = "load";
+my $opt = shift || "";
+die $usage if (($opt eq "-h") or ($opt eq "--helm"));
+$action = "unload" if (($opt eq "-u") or ($opt eq "--unload"));
+$action = "reload" if (($opt eq "-r") or ($opt eq "--reload"));
+
+my $confile = $ENV{"UWOBO_PANEL_CONF"} || die "UWOBO_PANEL_CONF not defined";
+my $getter_url = $ENV{"HELM_GETTER_URL"} || die "HELM_GETTER_URL not defined";
+my $uwobo_url = $ENV{"HELM_UWOBO_URL"} || die "HELM_UWOBO_URL not defined";
+my %styles = getPredefinedStylesheets($confile);
+my $request_url = "";
+
+if ($action eq "load") {  # load predefined stylesheets
   foreach my $k (keys %styles) {
     $request_url .= "&" unless ($request_url eq "");
     my $ur = $styles{$k}[0];
@@ -57,11 +71,19 @@ sub main () {
     $request_url .= uri_escape($tmp);
   }
   $request_url = $uwobo_url . "add?$request_url";
-  my $agent = LWP::UserAgent->new();
-  my $response = $agent->get($request_url);
-  print $response->as_string();
-#   print "$request_url\n";
+
+} elsif ($action eq "unload") { # unload predefined stylesheets
+  $request_url = $uwobo_url . "remove?keys=" . join(',', keys %styles);
+
+} elsif ($action eq "reload") { # reload predefined stylesheets
+  $request_url = $uwobo_url . "reload?keys=" . join(',', keys %styles);
+
+} else {  # unknown action
+  die "Unknown action '$action'";
 }
 
-main();
+my $agent = LWP::UserAgent->new();
+my $response = $agent->get($request_url);
+print $response->as_string();
+#   print "$request_url\n";