[LON-CAPA-cvs] cvs: loncom /debugging_tools seed_accesscount.pl
matthew
lon-capa-cvs@mail.lon-capa.org
Fri, 14 Nov 2003 19:52:10 -0000
matthew Fri Nov 14 14:52:10 2003 EDT
Added files:
/loncom/debugging_tools seed_accesscount.pl
Log:
Initial commit of tool to process an existing nohist_reseval.db and
produce a nohist_accesscount.db. Best used with the find command.
Index: loncom/debugging_tools/seed_accesscount.pl
+++ loncom/debugging_tools/seed_accesscount.pl
#!/usr/bin/perl -w
#
# The LearningOnline Network
#
# $Id: seed_accesscount.pl,v 1.1 2003/11/14 19:52:10 matthew Exp $
#
# Copyright Michigan State University Board of Trustees
#
# This file is part of the LearningOnline Network with CAPA (LON-CAPA).
#
# LON-CAPA is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# LON-CAPA is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with LON-CAPA; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# /home/httpd/html/adm/gpl.txt
#
# http://www.lon-capa.org/
#
#################################################
use strict;
use Getopt::Long;
use GDBM_File;
#
# Options
my ($verbose,$help) = (0);
GetOptions("v" => \$verbose,
"help" => \$help);
#
# Help them out if they ask for it
if ($help) {
print <<END;
seed_accesscount.pl
END
exit;
}
#
# Loop through ARGV getting files.
$|=1;
while (my $resDBname = shift()) {
my ($path) = ($resDBname =~ /^(.*)nohist_resevaldata.db$/);
print STDERR $path.$/;
my %resevalDB;
if (! tie(%resevalDB,'GDBM_File',$resDBname,&GDBM_READER,0640)) {
warn "Unable to tie to $resDBname";
next;
}
#
my $accessDBname = $path.'nohist_accesscount.db';
my %accessDB;
if (! tie(%accessDB,'GDBM_File',$accessDBname,&GDBM_WRCREAT,0640)) {
warn "Unable to tie to $accessDBname";
next;
}
#
my @Keys;
my ($basekey,$value);
#
$! = 0;
while (eval('($basekey,$value) = each(%resevalDB);')) {
if ($!) {
print STDERR $1.$/;
$!=0;
}
my $key = &unescape($basekey);
my $src;
next if (! ((undef,$src) = ($key =~ /^(.*)___(.*)___count/)));
my $value = &unescape($value);
if (exists($accessDB{$src})) {
$accessDB{$src}+=$value;
} else {
$accessDB{$src}=$value;
}
push (@Keys,$basekey);
}
#
untie %accessDB;
untie %resevalDB;
# remove the keys we saved.
next if (! scalar(@Keys)); # skip it if we did not get anything...
if (! tie(%resevalDB,'GDBM_File',$resDBname,&GDBM_WRITER,0640)) {
die "Unable to re-tie to $resDBname. No deletes occured.";
}
foreach my $basekey (@Keys) {
delete($resevalDB{$basekey});
}
untie %resevalDB;
}
exit;
######################################
sub unescape {
my $str=shift;
$str =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;
return $str;
}