--- loncom/homework/caparesponse/caparesponse.pm 2000/09/14 20:55:08 1.5
+++ loncom/homework/caparesponse/caparesponse.pm 2000/10/13 14:32:42 1.9
@@ -9,12 +9,45 @@ sub BEGIN {
&Apache::lonxml::register('Apache::caparesponse',('caparesponse'));
}
+$Apache::caparesponse::result='';
sub start_caparesponse {
- print "\n
\nreal caparesponse
\n";
+ my $envkey;
+
+ #foreach $envkey (sort keys %ENV) {
+ # Apache::lonxml::debug("$envkey ---- $ENV{$envkey}
");
+ #}
+
+ #Apache::lonxml::debug("\n
\nreal caparesponse
\n");
}
sub end_caparesponse {
- print "\n
\nreal end caparesponse
\n";
+ my ($target,$token,$parstack,$parser,$safeeval,$style)=@_;
+ if ( defined $ENV{'form.'.$ENV{'form.request.prefix'}.'submit'}) {
+ $Apache::caparesponse::result='';
+ $safeeval->share('&caparesponse_capa_check_answer');
+ $safeeval->share('$Apache::caparesponse::result');
+ my $response = $ENV{'form.'.$ENV{'form.request.prefix'}.'HWVAL'.$Apache::inputtags::curvalue};
+ #Apache::lonxml::debug("submitted a $response
\n");
+ #Apache::lonxml::debug($$parstack[$#$parstack] . "\n
");
+ my $expression="caparesponse_check $response $$parstack[$#$parstack];";
+ #&Apache::run::run($expression,$safeeval);
+
+ #&Apache::lonxml::debug("\n
result:$Apache::caparesponse::result:
\n");
+ my $args ='';
+ if ( $#$parstack > -1 ) {
+ $args=$$parstack[$#$parstack];
+ }
+ my $answer = &Apache::run::run("{$args;".'return $answer}',$safeeval);
+ if ( $answer eq $response ) {
+ return "Correct, Computer had $answer
";
+ } else {
+ return "Incorrect, Computer had $answer
";
+ }
+ } else {
+ #return "The correct answer is ".&Apache::run::run("{$$parstack['-1'];".'return $answer}',$safeeval)."\n";
+ }
+ #Apache::lonxml::debug("\n
\nreal end caparesponse
\n");
+ return '';
}
1;