[LON-CAPA-cvs] cvs: loncom / lonmaxima

raeburn lon-capa-cvs@mail.lon-capa.org
Thu, 08 Feb 2007 10:08:02 -0000


raeburn		Thu Feb  8 05:08:02 2007 EDT

  Modified files:              
    /loncom	lonmaxima 
  Log:
  Alternative solution to the case of slow computations.
  
  while() loop eliminated in favor of use of a regular expression in $command->expect() which includes next input prompt. Output is only parsed for ouput (o%N) from previous executed statement (i%N), once next input prompt (i%N+1) detected.
  
  Timeout included in $command->expect() call will now terminate computations which take too long.
  
  
Index: loncom/lonmaxima
diff -u loncom/lonmaxima:1.24 loncom/lonmaxima:1.25
--- loncom/lonmaxima:1.24	Thu Feb  8 01:28:30 2007
+++ loncom/lonmaxima	Thu Feb  8 05:08:02 2007
@@ -3,7 +3,7 @@
 # The LearningOnline Network with CAPA
 # Connect to MAXIMA CAS
 #
-# $Id: lonmaxima,v 1.24 2007/02/08 06:28:30 raeburn Exp $
+# $Id: lonmaxima,v 1.25 2007/02/08 10:08:02 raeburn Exp $
 #
 # Copyright Michigan State University Board of Trustees
 #
@@ -259,10 +259,7 @@
            while (my $cmd=<$client>) {
               &status('Processing command');
               print $command &unescape($cmd);
-              my ($reply,$finished,$syntaxerr);
-              while ((!$finished) && (!$syntaxerr) && ($reply !~ /^Error\:/)) {
-                  ($reply,$finished,$syntaxerr) = &getmaximaoutput($command);
-              }
+              my ($reply,$finished,$syntaxerr) = &getmaximaoutput($command,1);
               print $client &escape($reply)."\n";
               if ($reply=~/^Error\:/) {
                  &logthis('Died through '.$reply);
@@ -294,7 +291,7 @@
 	my $expect=$counter.time;
 	print $command "$expect;\n";
 	while (1) {
-	    my $output=&getmaximaoutput($command);
+	    my $output=&getmaximaoutput($command,1);
 	    if (($output=~/\Q$expect\E/) || ($output=~/^Error\:/)) {
 		return;
 	    }
@@ -303,8 +300,15 @@
 }
 
 sub getmaximaoutput {
-    my ($command)=@_;
-    my (undef,$error,undef,$output)=$command->expect(20, -re => '^\(\%i\d+\)');
+    my ($command,$numcheck)=@_;
+    my $regexp = '\(\%i\d+\)';
+    if ($numcheck) {
+        if ($command->match() =~ /\(\%i(\d+)\)/) {
+            my $nextmatch = $1+1;
+            $regexp = '\(\%i'.$nextmatch.'\)';
+        }
+    }
+    my (undef,$error,undef,$output)=$command->expect(20, -re => $regexp);
     if ($error) {
        return 'Error: '.$error;
     }