chiark / gitweb /
Calculate sourcebasedir and datadir each time
authorIan Jackson <ijackson@chiark.greenend.org.uk>
Tue, 25 Aug 2009 16:02:23 +0000 (17:02 +0100)
committerIan Jackson <Ian.Jackson@eu.citrix.com>
Tue, 25 Aug 2009 16:02:23 +0000 (17:02 +0100)
yarrg/CommodsWeb.pm
yarrg/web/source.tar.gz

index d5c7700..84ea710 100644 (file)
@@ -43,15 +43,12 @@ use JSON;
 use Commods;
 use CommodsDatabase;
 
-our $self_url;
-our $base_url;
-
 BEGIN {
     use Exporter ();
     our ($VERSION, @ISA, @EXPORT, @EXPORT_OK, %EXPORT_TAGS);
     $VERSION     = 1.00;
     @ISA         = qw(Exporter);
-    @EXPORT      = qw(&dbw_connect &ocean_list $sourcebasedir
+    @EXPORT      = qw(&dbw_connect &ocean_list &sourcebasedir
                      &to_json_shim &to_json_protecttags
                      &set_ctype_utf8
                      &prettyprint_age &meta_prettyprint_age);
@@ -60,24 +57,31 @@ BEGIN {
     @EXPORT_OK   = qw();
 }
 
-our $datadir='.';
-our $sourcebasedir;
-
-for my $dir (@INC) {
-    if ($dir =~ m/\.perl-lib$/) {
-       $sourcebasedir= "$dir/..";
-       if (stat "$dir/DATA") {
-           $datadir= "$dir/DATA";
-       } elsif ($!==&ENOENT) {
-           $datadir= "$dir";
-       } else {
-           die "stat $dir/DATA $!";
+sub sourcebasedir () {
+    my $dir;
+    
+    for my $dir (@INC) {
+       if ($dir =~ m/\.perl-lib$/) {
+           $dir= "$dir/..";
+           last;
        }
-       last;
     }
+    defined $dir or
+       die "no source base dir in @INC";
+    return $dir;
+}
+
+my datadir () {
+    my $dir= sourcebasedir();
+    if (stat "$dir/DATA") {
+       return "$dir/DATA";
+    } elsif ($!==&ENOENT) {
+       return "$dir";
+    } else {
+       die "stat $dir/DATA $!";
+    }
+    return '.';
 }
-defined $sourcebasedir or
-    die "no source base dir in @INC";
 
 my @ocean_list;
 
@@ -101,7 +105,7 @@ sub dbw_connect ($) {
     my ($ocean) = @_;
     die "unknown ocean $ocean ?"
        unless grep { $_ eq $ocean } ocean_list();
-    return dbr_connect($datadir, $ocean);
+    return dbr_connect(datadir(), $ocean);
 }
 
 sub to_json_shim ($) {
index 13cd22f..1d92ad8 100755 (executable)
@@ -42,7 +42,7 @@ use CommodsWeb;
 $r->content_type('application/octet-stream');
 $m->flush_buffer();
 
-$ENV{'YPPSC_YARRG_SRCBASE'}= $sourcebasedir;
+$ENV{'YPPSC_YARRG_SRCBASE'}= sourcebasedir();
 my $pipe= new IO::Pipe or die $!;
 my $pid= fork();  defined $pid or die $!;
 if (!$pid) {