Comments
[tpope-extra.git] / perl / sct6
index f8a539a16a051fbd6f28c1db21868beea97c82a1..cb3fe0b19bc274d7e64b34176b4fb65020494570 100755 (executable)
--- a/perl/sct6
+++ b/perl/sct6
@@ -6,6 +6,9 @@
 # Create a ~/.sct6rc that has SID=yourssn and PIN=yourpin
 # You'll need to change the url below if you go anywhere but TAMUK.
 
+# Update: This tool now only outputs in XML.  For other formats, convert
+# with schedproc
+
 use strict;
 use Date::Calc::Object qw(Day_of_Week Decode_Day_of_Week Decode_Month Week_of_Year Monday_of_Week Day_of_Week_Abbreviation Delta_Days Add_Delta_Days Nth_Weekday_of_Month_Year Gmtime Mktime);
 use Date::Calendar::Profiles qw($Profiles);
@@ -94,14 +97,6 @@ die $response->status_line unless $response->is_success;
 my @terms = grep {s/^<option value="([^"]*)">.*/$1/i} (split( /\r?\n/, $response->content)); # "
 die "Site down. Try again later.\n" unless (@terms);
 
-sub generate_id {
-    my ($section, $number) = split("-", shift);
-    my $id = 0;
-    foreach (split //, $section) {$id=26*$id+(ord($_)-1)%32;}
-    $id=10000*$id+$number;
-    return $id;
-}
-
 sub next_class {
     my %class = @_;
     $class{'duration'} =~ /(\d\d\d\d)(\d\d)(\d\d)-(\d\d\d\d)(\d\d)(\d\d)/;
@@ -296,43 +291,6 @@ sub get_schedule {
     return @schedule;
 }
 
-sub get_faculty_email {
-    my ($name, $school, $email);
-    if((-f $ENV{'HOME'} . "/public_html/faculty.csv") && ! %faculty) {
-       open INS, $ENV{'HOME'} . "/public_html/faculty.csv";
-       while($_ = <INS>) {
-           chomp;
-           m/"([^"]*)",([^,]*),([^,]*)/; # "
-           ($name, $email, $school) = ($1, $2, $3);
-           #$name =~ s/^([^,]*), ([^,]*)(.*)$/$2 $1$3/;
-           $name =~ s/ [A-Z]\.//g;
-           $name = lc $name;
-           $name =~ s/\W//g;
-           $faculty{$name} = $email;
-       }
-    }
-    $name = shift;
-    $name =~ s/ [A-Z]r?\.//g;
-    $name = lc $name;
-    $name =~ s/\W//g;
-    return $faculty{$name};
-}
-
-sub get_mhc_header {
-return (
-"X-SC-Subject: New Years Day\nX-SC-Category: Holiday\nX-SC-Cond: 1 Jan\nX-SC-Duration: 00010101-\nX-SC-Record-Id: <New_Years_Day\@from.sctweb>\n",
-"X-SC-Subject: Martin Luther King, Jr. Day\nX-SC-Category: Holiday\nX-SC-Cond: 3rd Mon Jan\nX-SC-Duration: 19870119-\nX-SC-Record-Id: <Martin_Luther_King_Jr_Day\@from.sctweb>\n",
-"X-SC-Subject: Presidents Day\nX-SC-Category: Holiday\nX-SC-Cond: 3rd Mon Feb\nX-SC-Duration: 19710515-\nX-SC-Record-Id: <Presidents_Day\@from.sctweb>\n",
-"X-SC-Subject: Memorial Day\nX-SC-Category: Holiday\nX-SC-Cond: Last Mon May\nX-SC-Duration: 19710531-\nX-SC-Record-Id: <Memorial_Day\@from.sctweb>\n",
-"X-SC-Subject: Independence Day\nX-SC-Category: Holiday\nX-SC-Cond: 4 Jul\nX-SC-Duration: 17760704-\nX-SC-Record-Id: <Independence_Day\@from.sctweb>\n",
-"X-SC-Subject: Labor Day\nX-SC-Category: Holiday\nX-SC-Cond: 1st Mon Sep\nX-SC-Duration: 18840901-\nX-SC-Record-Id: <Labor_Day\@from.sctweb>\n",
-"X-SC-Subject: Columbus Day\nX-SC-Category: Holiday\nX-SC-Cond: 2nd Mon Oct\nX-SC-Duration: 19711011-\nX-SC-Record-Id: <Columbus_Day\@from.sctweb>\n",
-"X-SC-Subject: Veterans Day\nX-SC-Category: Holiday\nX-SC-Cond: 11 Nov\nX-SC-Duration: 19261111-\nX-SC-Record-Id: <Veterans_Day\@from.sctweb>\n",
-"X-SC-Subject: Thanksgiving\nX-SC-Category: Holiday\nX-SC-Cond: 4th Thu Nov\nX-SC-Duration: 14921122-\nX-SC-Record-Id: <Thanksgiving\@from.sctweb>\n",
-"X-SC-Subject: Christmas\nX-SC-Category: Holiday\nX-SC-Cond: 25 Dec\nX-SC-Duration: 00011225-\nX-SC-Record-Id: <Christmas\@from.sctweb>\n",
-);
-}
-
 sub do_xml_schedule {
     my $file = shift if (defined $_[0] and $_[0] !~ /^\d/);
     my $schedule = { class => [ get_schedule(@_) ] };
@@ -346,118 +304,19 @@ sub do_xml_schedule {
     }
 }
 
-sub do_html_schedule {
-    my @showheaders = ("Section ID/Title", "Instructor", "Days", "Time", "Duration", "Location");
-    my $shade = "dark";
-    my @schedule = get_schedule(@_);
-    print '<table id="schedule" cellpadding="3" cellspacing="0">'."\n<tr><th>";
-    print join("</th><th>",@showheaders);
-    print "</th></tr>\n";
-       foreach my $row (@schedule) {
-           map { s/\n/<br \/>/g; $_} %$row;
-           $row->{'duration'} =~ s/-/<br \/>/g;
-           $row->{'duration'} =~ s/\d\d(\d\d)(\d\d)(\d\d)/$2-$3-$1/g;
-           print '<tr class="'.$shade.'">';
-           $shade = ($shade eq "dark"?"light":"dark");
-           print '<td class="idtitle">';
-           print '<span class="sectionid">' .$row->{'id'}. '</span><br />';
-           print '<span class="coursetitle">' .$row->{'title'}. '</span></td>';
-           my $instructor = $row->{'instructor'};
-           #$instructor =~ s/^([^,]*), ([^,]*)(.*)/$2 $1$3/;
-           my $email = get_faculty_email($instructor);
-           #if($email) {
-               #print '<td><a href="mailto:' . $email . '">'
-               #. $row->{'instructor'} . "</a></td>";
-           # } else {
-               print "<td>" . $row->{'instructor'} . "</td>";
-           #}
-           print "<td>" . $row->{'days'} . "</td>";
-           print "<td>" . $row->{'begin'}."-<wbr />".$row->{'end'} . "</td>";
-           print "<td>" . $row->{'duration'} . "</td>";
-           print "<td>" . $row->{'location'} . "</td>";
-           print "</tr>\n";
-       }
-    print "</table>\n";
-}
-
-sub do_html_grades {
-    my @readheaders = ("Section ID", "Course Title", "Grade", "Earned  Hours", "Quality  Hours", "Quality  Points", "GPA");
-    @readheaders = ("Section", "Course Title", "FinalGrade", "Earned Hours", "Quality Hours", "Quality Points", "GPA") if($opts{'school'} eq 'tamuk');
-    my @showheaders = ("Section ID", "Course Title", "Grade", "Earned<br />Hours", "Quality<br />Hours", "Quality<br />Points");
-    my ($row, $lastrow);
-    my $shade = "dark";
-    my $te = new HTML::TableExtract( headers => [ @readheaders ] );
-    my $response = $ua->get("$url&tserve_tip_write=||WID|SID|PIN|Term&tserve_trans_config=rgrdterm.cfg"); # Valid grading terms
-    die $response->status_line unless $response->is_success;
-    #my @terms = reverse grep {s/^<option value="([^"]*)">.*/$1/} (split( /\r\n/, $response->content));
-    my @terms = ();
-    my $year = Date::Calc->localtime->year;
-    for(my $y=$year-4;$y<=$year;$y++) { push @terms, ($y.2,$y."F",$y.3,$y.4,$y.1,$y."S"); }
-    foreach(@_ ? @_ : @terms) {
-       $response = $ua->get("$url&tserve_tip_write=||WID|SID|PIN|Term&tserve_trans_config=rgrades.cfg&Term=".($_) );
-       die $response->status_line unless $response->is_success;
-       $te->parse($response->content);
-    }
-    print '<table id="grades" cellpadding="3" cellspacing="0">'."\n<tr>";
-    print '<th align="left" class="sectionid">', $showheaders[0];
-    print '</th><th align="left" class="coursetitle">', $showheaders[1];
-    print '</th><th align="center" class="grade">';
-    print join('</th><th align="center" class="right-number">',@showheaders[2 .. 5]);
-    print "</th></tr>\n";
-    foreach my $ts ($te->table_states) {
-       foreach my $row ($ts->rows) {
-           map { s/^\s+//; s/\xa0|\r//g; s/\n/<br \/>/g; $_} @$row;
-           $row->[1] = capitalize($row->[1]);
-           $row->[1] =~ s/&/&amp;/g;
-           $row->[0] =~ s/Cumulative through/Cumulative: through/;
-           $row->[0] =~ s/Cumulative:(.*) (\d{4}) (.*)/Cumulative:$1 $3 $2/;
-           $lastrow=$row;
-           next if $row->[0] =~ /:|Current Term/;
-           print '<tr class="'.$shade.'">';
-           $shade = ($shade eq "dark"?"light":"dark");
-           print '<td align="left" class="sectionid">', $$row[0], '</td>';
-           print '<td align="left" class="coursetitle">', $$row[1], '</td>';
-           print '<td align="center" class="grade">';
-           #print join('</td><td>', @$row[0 .. 1]);
-           print join('</td><td align="right" class="right-number">', @$row[2 .. 5]);
-           print "</td></tr>\n";
-       }
-    }
-    print '<tr class="cumulative '.$shade.'"><td id="cumulative" colspan="2">', capitalize($lastrow->[0]);
-    #shift @$lastrow; shift @$lastrow;
-    print '</td><td align="center" id="gpa" class="grade">';
-    print $$lastrow[6];
-    print '</td><td align="right" class="right-number">';
-    print join('</td><td align="right" class="right-number">', @$lastrow[3 .. 5]);
-    print "</td></tr>\n";
-    print "</table>\n";
+sub do_xml_grades {
+    print "<grades>\n</grades>\n";
 }
 
 sub do_transcripts {
-    $response = $ua->get("$url&tserve_tip_write=||WID|SID|PIN&tserve_trans_config=rtranscr.cfg&CareerReqNum=1");
-    foreach (split /\n/, $response->content) {
-       next unless s/^\&nbsp;|<pre>// || s/\&nbsp;/ /;
-       s/<\/?([Hh]\d|[Bb])>//g;
-       next if /<\/td>/;
-       print "$_\n";
-    }
+    print "Not implemented.\n";
 }
 
-if ($arg eq "-s" || $arg eq "-h") {
-    do_html_schedule(@ARGV);
-} elsif ($arg eq "-m") {
-    do_mhc_schedule(@ARGV);
-} elsif ($arg eq "-c") {
-    do_csv_schedule(@ARGV);
-} elsif ($arg eq "-v") {
-    do_vcalendar_schedule(@ARGV);
-} elsif ($arg eq "-g") {
-    die "Grade support currently broken.\n";
-    do_html_grades(@ARGV);
+if ($arg eq "-g") {
+    do_xml_grades(@ARGV);
 } elsif ($arg eq "-t") {
-    die "Transcript support currently broken.\n";
     do_transcripts;
-} elsif ($arg eq "-x" || 1) {
+} elsif ($arg eq "-x" || $arg eq "-s" || 1) {
     do_xml_schedule(@ARGV);
 }