[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;
}