--- loncom/publisher/Attic/lonconstruct.pm 2001/06/23 18:26:40 1.4 +++ loncom/publisher/Attic/lonconstruct.pm 2003/09/21 03:32:06 1.14 @@ -1,7 +1,31 @@ # The LearningOnline Network with CAPA -# # Construction Space Page Wrapper for Construction # +# $Id: lonconstruct.pm,v 1.14 2003/09/21 03:32:06 taceyjo1 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/ +# +# # (Page Handler # # (TeX Content Handler @@ -12,11 +36,56 @@ # # 11/22,11/23,11/28, # 03/30/01 Gerd Kortemeyer - package Apache::lonconstruct; + use strict; -use Apache::Constants qw(:common :http); +use Apache::Constants qw(:common :http :methods); +use Apache::lonnet; +use Apache::Log (); +use HTML::Entities(); + +my $DEBUG = 0; +=pod + +=item Debug($request, $message) + + If debugging is enabled puts out a debuggin message determined by the + caller. The debug message goes to the Apache error log file. Debugging + is enabled by ssetting the module global DEBUG variable to nonzero (TRUE). + + Parameters: + +=over 4 + +=item $request - The curretn request operation. + +=item $message - The message to put inthe log file. + +=back + + Returns: + nothing. + +=cut + +sub Debug { + + # Marshall the parameters. + + my $r = shift; + my $log = $r->log; + my $message = shift; + + # Put out the indicated message butonly if DEBUG is false. + + if ($DEBUG) { + $log->debug($message); + } +} + + + # ================================================================ Main Handler @@ -30,14 +99,38 @@ sub handler { return OK if $r->header_only; my $lowerframe=$r->path_info; + + &Debug($r, "Initial URL for lower frame: ".$lowerframe); $lowerframe=~s/^\//\/\~/; + &Debug($r, "Lower frame URL afer ~ subst: ".$lowerframe); + $lowerframe= &HTML::Entities::encode($lowerframe); + &Debug($r, "LOwer frame URL after quote subst: ".$lowerframe); + +# +# Are we forcing edit mode? +# + + &Apache::loncommon::get_unprocessed_cgi + ($ENV{'QUERY_STRING'},['forceedit']); + if ($ENV{'form.forceedit'}) { + $lowerframe.='?editmode=Edit&problemmode=EditXML'; + } + &Apache::loncommon::get_unprocessed_cgi + ($ENV{'QUERY_STRING'},['forceColoredit']); + if ($ENV{'form.forceColoredit'}) { + $lowerframe.='?editmode=Edit&problemmode=Edit'; + } $r->print(< -LON-CAPA Construction Space - +LON-CAPA Construction Space + + + - + ENDPAGE @@ -46,9 +139,3 @@ ENDPAGE 1; __END__ - - - - - -