summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorin2 <in2@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2003-07-03 13:49:45 +0800
committerin2 <in2@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2003-07-03 13:49:45 +0800
commitf7441119f0e3051bf21057d2bf9367260033daf5 (patch)
treeb595d686e86bf3f1deaa18ecfb5cf96ce06275b1
parent7dd329b898761fd898fdeba082f9083625390506 (diff)
downloadpttbbs-f7441119f0e3051bf21057d2bf9367260033daf5.tar
pttbbs-f7441119f0e3051bf21057d2bf9367260033daf5.tar.gz
pttbbs-f7441119f0e3051bf21057d2bf9367260033daf5.tar.bz2
pttbbs-f7441119f0e3051bf21057d2bf9367260033daf5.tar.lz
pttbbs-f7441119f0e3051bf21057d2bf9367260033daf5.tar.xz
pttbbs-f7441119f0e3051bf21057d2bf9367260033daf5.tar.zst
pttbbs-f7441119f0e3051bf21057d2bf9367260033daf5.zip
add manbuilder.pl
git-svn-id: http://opensvn.csie.org/pttbbs/pttbbs/trunk@1003 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
-rwxr-xr-xpttbbs/staticweb/manbuilder.pl59
1 files changed, 59 insertions, 0 deletions
diff --git a/pttbbs/staticweb/manbuilder.pl b/pttbbs/staticweb/manbuilder.pl
new file mode 100755
index 00000000..ecb0972e
--- /dev/null
+++ b/pttbbs/staticweb/manbuilder.pl
@@ -0,0 +1,59 @@
+#!/usr/bin/perl
+# $Id: manbuilder.pl,v 1.1 2003/07/03 05:49:45 in2 Exp $
+use lib '/home/bbs/bin/';
+use strict;
+use OurNet::FuzzyIndex;
+use Getopt::Std;
+use DB_File;
+use BBSFileHeader;
+use Data::Serializer;
+
+my(%db, %idx, $serial);
+
+sub main
+{
+ die usage() unless( @ARGV );
+
+ $serial = Data::Serializer->new(serializer => 'Storable',
+ digester => 'MD5',
+ compress => 0,
+ );
+
+ foreach( @ARGV ){
+ tie %db, 'DB_File', "$_.db", O_CREAT | O_RDWR, 0666, $DB_HASH;
+ build("/home/bbs/man/boards/".substr($_, 0, 1)."/$_", '');
+ untie %db;
+ }
+}
+
+sub build($$)
+{
+ my($basedir, $doffset) = @_;
+ my(%bfh, $fn, @tdir);
+
+ print "$basedir, $doffset\n";
+ tie %bfh, 'BBSFileHeader', $basedir;
+ foreach( 0..($bfh{num} - 1) ){
+ next if( $bfh{"$_.filemode"} & 32 ); # skip HIDDEN
+
+ $fn = $bfh{"$_.filename"};
+ if( $bfh{"$_.isdir"} ){
+ push @tdir, ["$doffset/$fn/", $bfh{"$_.title"}];
+ build("$basedir/$fn", "$doffset/$fn");
+ }
+ else{
+ push @tdir, ["$doffset/$fn", $bfh{"$_.title"}];
+ $db{"$doffset/$fn"} = $bfh{"$_.content"};
+ }
+ }
+ $db{"$doffset/"} = $serial->serialize(\@tdir);
+}
+
+sub usage
+{
+ print ("$0 boardname ...\n");
+ exit(0);
+}
+
+main();
+1;