--- loncom/xml/lonxml.pm 2000/06/19 15:52:29 1.1
+++ loncom/xml/lonxml.pm 2002/10/17 14:42:07 1.203
@@ -1,1305 +1,1472 @@
-package Apache::lonxml;
-
+# The LearningOnline Network with CAPA
+# XML Parser Module
+#
+# $Id: lonxml.pm,v 1.203 2002/10/17 14:42:07 sakharuk 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/
+#
+# Copyright for TtHfunc and TtMfunc by Ian Hutchinson.
+# TtHfunc and TtMfunc (the "Code") may be compiled and linked into
+# binary executable programs or libraries distributed by the
+# Michigan State University (the "Licensee"), but any binaries so
+# distributed are hereby licensed only for use in the context
+# of a program or computational system for which the Licensee is the
+# primary author or distributor, and which performs substantial
+# additional tasks beyond the translation of (La)TeX into HTML.
+# The C source of the Code may not be distributed by the Licensee
+# to any other parties under any circumstances.
+#
+# last modified 06/26/00 by Alexander Sakharuk
+# 11/6 Gerd Kortemeyer
+# 6/1/1 Gerd Kortemeyer
+# 2/21,3/13 Guy
+# 3/29,5/4 Gerd Kortemeyer
+# 5/10 Scott Harrison
+# 5/26 Gerd Kortemeyer
+# 5/27 H. K. Ng
+# 6/2,6/3,6/8,6/9 Gerd Kortemeyer
+# 6/12,6/13 H. K. Ng
+# 6/16 Gerd Kortemeyer
+# 7/27 H. K. Ng
+# 8/7,8/9,8/10,8/11,8/15,8/16,8/17,8/18,8/20,8/23,8/24 Gerd Kortemeyer
+# Guy Albertelli
+# 9/26 Gerd Kortemeyer
+# Dec Guy Albertelli
+# YEAR=2002
+# 1/1 Gerd Kortemeyer
+# 1/2 Matthew Hall
+# 1/3 Gerd Kortemeyer
+#
+
+package Apache::lonxml;
+use vars
+qw(@pwd @outputstack $redirection $import @extlinks $metamode $evaluate %insertlist @namespace $prevent_entity_encode);
use strict;
-use HTML::TokeParser;
-use Safe;
-use Apache::Constants qw(:common);
-use Apache::lontexconvert;
-
+use HTML::LCParser();
+use HTML::TreeBuilder();
+use HTML::Entities();
+use Safe();
+use Safe::Hole();
+use Math::Cephes();
+use Math::Random();
+use Opcode();
+
+sub register {
+ my ($space,@taglist) = @_;
+ foreach my $temptag (@taglist) {
+ push(@{ $Apache::lonxml::alltags{$temptag} },$space);
+ }
+}
-#======================================================= Main subroutine: xmlparse
+sub deregister {
+ my ($space,@taglist) = @_;
+ foreach my $temptag (@taglist) {
+ my $tempspace = $Apache::lonxml::alltags{$temptag}[-1];
+ if ($tempspace eq $space) {
+ pop(@{ $Apache::lonxml::alltags{$temptag} });
+ }
+ }
+ #&printalltags();
+}
-sub xmlparse {
+use Apache::Constants qw(:common);
+use Apache::lontexconvert();
+use Apache::style();
+use Apache::run();
+use Apache::londefdef();
+use Apache::scripttag();
+use Apache::edit();
+use Apache::lonnet();
+use Apache::File();
+use Apache::loncommon();
+use Apache::lonfeedback();
+use Apache::lonmsg();
+
+#================================================== Main subroutine: xmlparse
+#debugging control, to turn on debugging modify the correct handler
+$Apache::lonxml::debug=0;
+
+#path to the directory containing the file currently being processed
+@pwd=();
+
+#these two are used for capturing a subset of the output for later processing,
+#don't touch them directly use &startredirection and &endredirection
+@outputstack = ();
+$redirection = 0;
+
+#controls wheter the tag actually does
+$import = 1;
+@extlinks=();
+
+# meta mode is a bit weird only some output is to be turned off
+#
';
+ }
+ }
+ }
+ unless ($discussiononly) {
+ $discussion.='';
+ }
+ }
+ if ($discussiononly) {
+ $discussion.=(<
+
+
+
+
+
+Note: in anonymous discussion, your name is visible only to
+course faculty
+
+
+ENDDISCUSS
+ $discussion.=&Apache::lonfeedback::generate_preview_button();
+ }
+ }
}
- return $finaloutput;
+ return $discussion.($discussiononly?'':'');
}
+sub tokeninputfield {
+ my $defhost=$Apache::lonnet::perlvar{'lonHostID'};
+ $defhost=~tr/a-z/A-Z/;
+ return (<
+ function updatetoken() {
+ var comp=new Array;
+ var barcode=unescape(document.tokeninput.barcode.value);
+ comp=barcode.split('*');
+ if (typeof(comp[0])!="undefined") {
+ document.tokeninput.codeone.value=comp[0];
+ }
+ if (typeof(comp[1])!="undefined") {
+ document.tokeninput.codetwo.value=comp[1];
+ }
+ if (typeof(comp[2])!="undefined") {
+ comp[2]=comp[2].toUpperCase();
+ document.tokeninput.codethree.value=comp[2];
+ }
+ document.tokeninput.barcode.value='';
+ }
+
+
+ENDINPUTFIELD
+}
-#================================================================== style subroutine
+sub maketoken {
+ my ($symb,$tuname,$tudom,$tcrsid)=@_;
+ unless ($symb) {
+ $symb=&Apache::lonnet::symbread();
+ }
+ unless ($tuname) {
+ $tuname=$ENV{'user.name'};
+ $tudom=$ENV{'user.domain'};
+ $tcrsid=$ENV{'request.course.id'};
+ }
-sub styleparser {
+ return &Apache::lonnet::checkout($symb,$tuname,$tudom,$tcrsid);
+}
- my ($target,$content_style_string) = @_;
+sub printtokenheader {
+ my ($target,$token,$tsymb,$tcrsid,$tudom,$tuname)=@_;
+ unless ($token) { return ''; }
+
+ my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser();
+ unless ($tsymb) {
+ $tsymb=$symb;
+ }
+ unless ($tuname) {
+ $tuname=$name;
+ $tudom=$domain;
+ $tcrsid=$courseid;
+ }
-#------------------------------------------------ target redefinition (if necessary)
-
- my @target_string = '';
- my $element;
-
- ($element,@target_string) = split ('&&',$target);
-
- map {$content_style_string =~ s/\<(.*)$_\>/\<$1$element\>/g; } @target_string;
-
- $target = $element;
-
-#------------------------------------------------- create a table for defined target
-#---------------------------------------------- from the information from Style File
-
- my @value_style = ();
- my $current_key = '';
- my $current_value = '';
-
- my $pstyle = HTML::TokeParser->new(\$content_style_string);
-
- my $stoken;
-
- while ($stoken = $pstyle->get_token) {
-#---------------------------------------------------------- start for tag definition
- if ($stoken->[0] eq 'S' and $stoken->[1] eq 'definetag') {
-#------------------------------------------------------------------- new key in hash
- $current_key = $stoken->[2]{name};
- if ($target eq 'meta') {
-#-------------------------------------------------- reserved for the metadate output
-
-
- } else {
-#-------------------------------------------------------------------- outtext output
- while ($stoken = $pstyle->get_token and $stoken->[1] ne 'outtext') {
- }
- while ($stoken = $pstyle->get_token and $stoken->[0] ne 'S') {
- $current_value .= $stoken->[1];
- }
- while ($stoken->[1] ne 'definetag') {
- if ($stoken->[0] eq 'S' and $stoken->[1] eq $target) {
- while ($stoken = $pstyle->get_token) {
- if ($stoken->[1] ne $target) {
- if ($stoken->[0] eq 'S') {
- $current_value .= $stoken->[4];
- }
- if ($stoken->[0] eq 'E') {
- $current_value .= $stoken->[2];
- }
- if ($stoken->[0] eq 'T') {
- $current_value .= $stoken->[1];
- }
- } else {
- last;
- }
- }
- } elsif ($stoken->[0] eq 'S' and $stoken->[1] ne $target) {
- while ($stoken = $pstyle->get_token and $stoken->[0] ne 'E') {
- }
- }
-
- while ($stoken = $pstyle->get_token) {
- if ($stoken->[0] eq 'T') {
- $current_value .= $stoken->[1];
- }
- if ($stoken->[0] eq 'E') {
- last;
- }
- if ($stoken->[0] eq 'S') {
- last;
- }
- }
-
- }
- }
+ my %reply=&Apache::lonnet::get('environment',
+ ['firstname','middlename','lastname','generation'],
+ $tudom,$tuname);
+ my $plainname=$reply{'firstname'}.' '.
+ $reply{'middlename'}.' '.
+ $reply{'lastname'}.' '.
+ $reply{'generation'};
+
+ if ($target eq 'web') {
+ my %idhash=&Apache::lonnet::idrget($tudom,($tuname));
+ return
+ ''.
+ 'Checked out for '.$plainname.
+ ' User: '.$tuname.' at '.$tudom.
+ ' ID: '.$idhash{$tuname}.
+ ' CourseID: '.$tcrsid.
+ ' Course: '.$ENV{'course.'.$tcrsid.'.description'}.
+ ' DocID: '.$token.
+ ' Time: '.localtime().'';
+ } else {
+ return $token;
+ }
+}
+
+sub fontsettings() {
+ my $headerstring='';
+ if (($ENV{'browser.os'} eq 'mac') && (!$ENV{'browser.mathml'})) {
+ $headerstring.=
+ '';
+ }
+ return $headerstring;
+}
+
+sub registerurl {
+ my $forcereg=shift;
+ my $target = shift;
+ my $result = '';
- }
- push (@value_style,lc $current_key,$current_value);
- $current_key = '';
- $current_value = '';
+ if ($target eq 'edit') {
+ $result .="\n";
+ }
+ if ((($ENV{'request.publicaccess'}) ||
+ (!&Apache::lonnet::is_on_map($ENV{'REQUEST_URI'}))) &&
+ (!$forcereg)) {
+ return $result.
+ '';
+ }
+ if ($Apache::lonxml::registered && !$forcereg) { return ''; }
+ $Apache::lonxml::registered=1;
+ my $nothing='';
+ if ($ENV{'browser.type'} eq 'explorer') { $nothing='javascript:void(0);'; }
+ my $newmail='';
+ if (&Apache::lonmsg::newmail()) {
+ $newmail='menu.setstatus("you have","messages");';
+ }
+ my $timesync='menu.syncclock(1000*'.time.');';
+ if (($ENV{'REQUEST_URI'}!~/^\/(res\/)*adm\//) || ($forcereg)) {
+ my $hwkadd='';
+ if ($ENV{'request.filename'}=~/\.(problem|exam|quiz|assess|survey|form)$/) {
+ if (&Apache::lonnet::allowed('vgr',$ENV{'request.course.id'})) {
+ $hwkadd.=(<
+// BEGIN LON-CAPA Internal
+
+ function LONCAPAreg() {
+ menu=window.open("$nothing","LONCAPAmenu","",false);
+ menu.clearTimeout(menu.menucltim);
+ $timesync
+ $newmail
+ menu.currentURL=window.location.pathname;
+ menu.reloadURL=window.location.pathname;
+ menu.currentStale=0;
+ menu.clearbut(3,1);
+ menu.switchbutton
+ (6,3,'catalog.gif','catalog','info','catalog_info()');
+ menu.switchbutton
+ (8,1,'eval.gif','evaluate','this','gopost("/adm/evaluate",currentURL)');
+ menu.switchbutton
+ (8,2,'fdbk.gif','feedback','discuss','gopost("/adm/feedback",currentURL)');
+ menu.switchbutton
+ (8,3,'prt.gif','prepare','printout','gopost("/adm/printout",currentURL)');
+ menu.switchbutton
+ (2,1,'back.gif','backward','','gopost("/adm/flip","back:"+currentURL)');
+ menu.switchbutton
+ (2,3,'forw.gif','forward','','gopost("/adm/flip","forward:"+currentURL)');
+ menu.switchbutton
+ (9,1,'sbkm.gif','set','bookmark','set_bookmark()');
+ menu.switchbutton
+ (9,2,'vbkm.gif','view','bookmark','edit_bookmarks()');
+ menu.switchbutton
+ (9,3,'anot.gif','anno-','tations','annotate()');
+ $hwkadd
+ }
+
+ function LONCAPAstale() {
+ menu=window.open("$nothing","LONCAPAmenu","",false);
+ menu.currentStale=1;
+ if (menu.reloadURL!='' && menu.reloadURL!= null) {
+ menu.switchbutton
+ (3,1,'reload.gif','return','location','go(reloadURL)');
+ }
+ menu.clearbut(7,1);
+ menu.clearbut(7,2);
+ menu.clearbut(7,3);
+ menu.menucltim=menu.setTimeout(
+ 'clearbut(2,1);clearbut(2,3);clearbut(8,1);clearbut(8,2);clearbut(8,3);'+
+ 'clearbut(9,1);clearbut(9,2);clearbut(9,3);clearbut(6,3)',
+ 2000);
}
-
- my %style_for_target = @value_style;
-
-#-------------------------------------------------------------------- check printing
-# while (($current_key,$current_value) = each %style_for_target) {
-# print "$current_key => $current_value\n";
-# }
- return %style_for_target;
-
+// END LON-CAPA Internal
+
+ENDREGTHIS
+
+ } else {
+ $result = (<
+// BEGIN LON-CAPA Internal
+
+ function LONCAPAreg() {
+ menu=window.open("$nothing","LONCAPAmenu","",false);
+ $timesync
+ menu.currentStale=1;
+ menu.clearbut(2,1);
+ menu.clearbut(2,3);
+ menu.clearbut(8,1);
+ menu.clearbut(8,2);
+ menu.clearbut(8,3);
+ if (menu.currentURL) {
+ menu.switchbutton
+ (3,1,'reload.gif','return','location','go(currentURL)');
+ } else {
+ menu.clearbut(3,1);
+ }
+ }
+
+ function LONCAPAstale() {
+ }
+
+// END LON-CAPA Internal
+
+ENDDONOTREGTHIS
+ }
+ return $result;
}
+sub loadevents() {
+ return 'LONCAPAreg();';
+}
+sub unloadevents() {
+ return 'LONCAPAstale();';
+}
-#=============================================================== Subroutine definition
-#--------------------------------------------------------------------------------- Run
- sub evaluate {
- my ($expression,$safeeval) = @_;
- return $safeeval->reval($expression);
- }
-
- sub run {
- my ($code,$safeeval) = @_;
- $safeeval->reval($code);
- }
-
-#===================================================================== TAG SUBROUTINES
-#----------------------------------------------------------------------------- tag
- sub start_m {
- my ($target,$token) = @_;
- my $currentstring = '';
- if ($target eq 'web') {
- $currentstring = "\$out = lontexconvert::converted(\$in = '\$'.\"";
- } elsif ($target eq 'tex') {
- $currentstring = "\$";
- }
- return $currentstring;
- }
- sub end_m {
- my ($target,$token) = @_;
- my $currentstring = '';
- if ($target eq 'web') {
- $currentstring = "\".'\$') ";
- } elsif ($target eq 'tex') {
- $currentstring = "\$";
- }
- return $currentstring;
- }
-#-------------------------------------------------------------------------- tag
- sub start_html {
- my ($target,$token) = @_;
- my $currentstring = '';
- if ($target eq 'web') {
- $currentstring = $token->[4];
- }
- return $currentstring;
- }
- sub end_html {
- my ($target,$token) = @_;
- my $currentstring = '';
- if ($target eq 'web') {
- $currentstring = $token->[2];
- }
- return $currentstring;
- }
-#-------------------------------------------------------------------------- tag
- sub start_head {
- my ($target,$token) = @_;
- my $currentstring = '';
- if ($target eq 'web') {
- $currentstring = $token->[4];
- }
- return $currentstring;
- }
- sub end_head {
- my ($target,$token) = @_;
- my $currentstring = '';
- if ($target eq 'web') {
- $currentstring = $token->[2];
- }
- return $currentstring;
- }
-#---------------------------------------------------------------------------