#!perl # repviewer parses the reputation file generated by jcwren's luke_repwalker.pl # to generate a full list of your articles sorted by creation time, title or # reputation just like the one at perlmonks user search except that all # articles are displayed on one page. Just set $pm and $rep below. use strict; use CGI qw(:standard *table); use HTML::Entities; my$pm = 'http://perlmonks.org'; # your login domain for perlmonks, used for node link my$rep = 'c:\.rep.epoptai'; # full path to rep file generated by luke_repwalker.pl my%i = map{$_ => param($_)} param; my($mode,$td,$ta,$rd,$ra,$ca,$cd); if($i{'o'} eq 'title DESC'){$mode='td'; $td='selected'} if($i{'o'} eq 'title ASC'){$mode='ta'; $ta='selected'} if($i{'o'} eq 'reputation DESC'){$mode='rd'; $rd='selected'} if($i{'o'} eq 'reputation ASC'){$mode='ra'; $ra='selected'} if($i{'o'} eq 'createtime ASC'){$mode='ca'; $ca='selected'} if(($i{'o'} eq 'createtime DESC') or (!$i{'o'})){$mode='cd'; $cd='selected'} print header,start_html(-title=>'repviewer',-bgcolor=>'#a0a0a0'); print<
Order By:
HTML

open(REP,"< $rep") or die "$!";
my@rep=;
die "$!" unless close(REP);

my(%reps,%tits,%dates,@reps,@tits,$tot);
for(@rep){
	$_=~m/^"(\d+)","(.*)","(-?\d+)","(.*)"$/;
	my$node = $1;
	my$title= $2;
	my$rep  = $3;
	my$date = $4;
	&encode_entities($title);
	$reps{$node}=$rep;
	$tits{$node}=$title;
	$dates{$node}=$date;
	}
for(values(%reps)){
	$tot += $_
	}
for(keys(%tits)){
	push @tits, $tits{$_}.'=|||='.$_
	}
my$i=1;
printf ("    Total articles: %d\n", scalar @rep); # nod to luke
printf ("  Total reputation: %d\n", $tot);
printf ("Average reputation: %3.2f\n", $tot / scalar @rep);   
print '
'; if($mode=~/td|ta/){ # by title print start_table({-border=>'1',-cellpadding=>'2',-cellspacing=>'1',-bgcolor=>'#c0c0c0'}); print 'numtitlerepdate'; if($mode=~/ta/){ # ascending for(sort{ lc($a) cmp lc($b)}(@tits)){ my($f,$b)=split(/=\|\|\|=/,$_); print< $i $f $reps{$b} $dates{$b} HTML $i++ } } if($mode=~/td/){ # descending for(reverse(sort{ lc($a) cmp lc($b)}(@tits))){ my($f,$b)=split(/=\|\|\|=/,$_); print< $i $f $reps{$b} $dates{$b} HTML $i++ } } print end_table,end_html; exit } if($mode=~/cd|ca/){ # by date print start_table({-border=>'1',-cellpadding=>'3',-cellspacing=>'1',-bgcolor=>'#c0c0c0'}); print 'numtitlerepdate'; } if($mode eq 'cd'){@rep=reverse(@rep)} # descending my$i=1; for(@rep){ $_=~m/^"(\d+)","(.*)","(-?\d+)","(.*)"$/; my$node = $1; my$title= $2; my$rep = $3; my$date = $4; &encode_entities($title); $reps{$node}=$rep; $tits{$node}=$title; $dates{$node}=$date; if($mode=~/cd|ca/){ print< $i $title $rep $date HTML } $i++ } if($mode=~/cd|ca/){ print end_table,end_html; exit } if($mode=~/rd|ra/){ # by rep print start_table({-border=>'1',-cellpadding=>'3',-cellspacing=>'1',-bgcolor=>'#c0c0c0'}); for(keys(%reps)){ push @reps, $reps{$_}.'='.$_ # construct a sortable rep array } for(@reps){ my($a,$b)=split(/=/,$_); if($a < 10){ $_=~s/(\d)/0$1/o # pad for sort } } $i=1; print 'numtitlerepdate'; if($mode=~/rd/){ for(reverse(sort{$a cmp $b}(@reps))){ # descending my($f,$b)=split(/=/,$_); if($f=~/^0\d$/){$f=~s/^0//o} # strip sort padding if($f=~/^-0\d$/){$f=~s/^-0/-/o} print< $i $tits{$b} $f $dates{$b} HTML $i++ } } if($mode=~/ra/){ # ascending for(sort{$a cmp $b}(@reps)){ my($f,$b)=split(/=/,$_); if($f=~/^0\d$/){$f=~s/^0//o} if($f=~/^-0\d$/){$f=~s/^-0/-/o} print< $i $tits{$b} $f $dates{$b} HTML $i++ } } print end_table,end_html; } exit