Diff for /loncom/xml/lonplot.pm between versions 1.28 and 1.29

version 1.28, 2001/12/31 19:02:00 version 1.29, 2002/01/01 19:34:25
Line 69  sub BEGIN { Line 69  sub BEGIN {
 ##        Tests used in checking the validitity of input         ##  ##        Tests used in checking the validitity of input         ##
 ##                                                               ##  ##                                                               ##
 ###################################################################  ###################################################################
   
   my %linestyles = 
       (
        lines          => 2,     # Maybe this will be used in the future
        linespoints    => 2,     # to check on whether or not they have 
        dots    => 2,     # supplied enough <data></data> fields
        points         => 2,     # to use the given line style.  But for
        steps    => 2,     # now there are more important things 
        fsteps    => 2,     # for me to deal with.
        histeps        => 2,
        errorbars    => 2,
        xerrorbars    => 2,
        yerrorbars    => 2,
        xyerrorbars    => 2,
        boxes          => 2,
        boxerrorbars   => 2,
        boxxyerrorbars => 2,
        financebars    => 2,
        candlesticks   => 2,
        vector    => 2
       );    
   
 my $int_test       = sub {$_[0]=~s/\s+//g;$_[0]=~/^\d+$/};  my $int_test       = sub {$_[0]=~s/\s+//g;$_[0]=~/^\d+$/};
 my $real_test      =   my $real_test      = 
     sub {$_[0]=~s/\s+//g;$_[0]=~/^[+-]?\d*\.?\d*([eE][+-]\d+)?$/};      sub {$_[0]=~s/\s+//g;$_[0]=~/^[+-]?\d*\.?\d*([eE][+-]\d+)?$/};
Line 76  my $color_test     = sub {$_[0]=~s/\s+// Line 98  my $color_test     = sub {$_[0]=~s/\s+//
 my $onoff_test     = sub {$_[0]=~/^(on|off)$/};  my $onoff_test     = sub {$_[0]=~/^(on|off)$/};
 my $key_pos_test   = sub {$_[0]=~/^(top|bottom|right|left|outside|below| )+$/};  my $key_pos_test   = sub {$_[0]=~/^(top|bottom|right|left|outside|below| )+$/};
 my $sml_test       = sub {$_[0]=~/^(small|medium|large)$/};  my $sml_test       = sub {$_[0]=~/^(small|medium|large)$/};
 my $linestyle_test = sub {$_[0]=~/^(lines|linespoints|dots|points|steps)$/};  my $linestyle_test = sub {exists($linestyles{$_[0]})};
 my $words_test     = sub {$_[0]=~s/\s+/ /g;$_[0]=~/^([\w\(\)]+ ?)+$/};  my $words_test     = sub {$_[0]=~s/\s+/ /g;$_[0]=~/^([\w\(\)]+ ?)+$/};
   
 ###################################################################  ###################################################################
Line 89  my %plot_defaults = Line 111  my %plot_defaults =
      height       => {       height       => {
  default     => 200,   default     => 200,
  test        => $int_test,   test        => $int_test,
  description => 'vertical size of image (pixels)',   description => 'height of image (pixels)',
  edit_type   => 'entry'    edit_type   => 'entry' 
  },   },
      width        => {       width        => {
  default     => 200,   default     => 200,
  test        => $int_test,   test        => $int_test,
  description => 'horizontal size of image (pixels)',   description => 'width of image (pixels)',
  edit_type   => 'entry'   edit_type   => 'entry'
  },   },
      bgcolor      => {       bgcolor      => {
Line 244  my %curve_defaults = Line 266  my %curve_defaults =
  test => $linestyle_test,   test => $linestyle_test,
  description => 'Style of the axis lines',   description => 'Style of the axis lines',
  edit_type   => 'choice',   edit_type   => 'choice',
  choices     => ['lines','linespoints','dots','points','steps']   choices     => ['lines','linespoints','dots','points','steps',
    'fsteps','histeps','errorbars','xerrorbars',
    'yerrorbars','xyerrorbars','boxes','boxerrorbars',
    'boxxyerrorbars','financebars','candlesticks',
    'vector']
  }   }
      );       );
   
Line 264  sub start_plot { Line 290  sub start_plot {
     my $result='';      my $result='';
     &Apache::lonxml::register('Apache::lonplot',      &Apache::lonxml::register('Apache::lonplot',
      ('title','xlabel','ylabel','key','axis','label','curve'));       ('title','xlabel','ylabel','key','axis','label','curve'));
     push (@Apache::lonxml::namespace,'plot');      push (@Apache::lonxml::namespace,'lonplot');
     my $inside = &Apache::lonxml::get_all_text("/plot",$$parser[-1]);  
     if ($target eq 'web') {      if ($target eq 'web') {
    my $inside = &Apache::lonxml::get_all_text("/plot",$$parser[-1]);
  $inside=&Apache::run::evaluate($inside,$safeeval,$$parstack[-1]);   $inside=&Apache::run::evaluate($inside,$safeeval,$$parstack[-1]);
     }   &Apache::lonxml::newparser($parser,\$inside);
     &Apache::lonxml::newparser($parser,\$inside);  
     if ($target eq 'web') {  
  &get_attributes(\%plot,\%plot_defaults,$parstack,$safeeval,   &get_attributes(\%plot,\%plot_defaults,$parstack,$safeeval,
  $tagstack->[-1]);   $tagstack->[-1]);
     } elsif ($target eq 'edit') {      } elsif ($target eq 'edit') {
Line 300  sub end_plot { Line 324  sub end_plot {
  ## Determine filename   ## Determine filename
  my $tmpdir = '/home/httpd/perl/tmp/';   my $tmpdir = '/home/httpd/perl/tmp/';
  my $filename = $ENV{'user.name'}.'_'.$ENV{'user.domain'}.   my $filename = $ENV{'user.name'}.'_'.$ENV{'user.domain'}.
     '_'.time.'_'.$$.'_plot.data';      '_'.time.'_'.$$.int(rand(1000)).'_plot.data';
  ## Write the plot description to the file   ## Write the plot description to the file
  my $fh=Apache::File->new(">$tmpdir$filename");   my $fh=Apache::File->new(">$tmpdir$filename");
  print $fh &write_gnuplot_file();   print $fh &write_gnuplot_file();
Line 362  sub start_title { Line 386  sub start_title {
  $result.='</td></tr><tr><td colspan="3">'.   $result.='</td></tr><tr><td colspan="3">'.
     &Apache::edit::editfield('',$text,'',20,1);      &Apache::edit::editfield('',$text,'',20,1);
     } elsif ($target eq 'modified') {      } elsif ($target eq 'modified') {
  my $text=$$parser[-1]->get_text("/function");   my $text=$$parser[-1]->get_text("/title");
  $result.=&Apache::edit::modifiedfield($token);   $result.=&Apache::edit::modifiedfield($token);
     }      }
     return $result;      return $result;
Line 389  sub start_xlabel { Line 413  sub start_xlabel {
  $result.='</td></tr><tr><td colspan="3">'.   $result.='</td></tr><tr><td colspan="3">'.
     &Apache::edit::editfield('',$text,'',20,1);      &Apache::edit::editfield('',$text,'',20,1);
     } elsif ($target eq 'modified') {      } elsif ($target eq 'modified') {
  my $text=$$parser[-1]->get_text("/function");   my $text=$$parser[-1]->get_text("/xlabel");
  $result.=&Apache::edit::modifiedfield($token);   $result.=&Apache::edit::modifiedfield($token);
     }      }
     return $result;      return $result;
Line 417  sub start_ylabel { Line 441  sub start_ylabel {
  $result .= '</td></tr><tr><td colspan="3">'.   $result .= '</td></tr><tr><td colspan="3">'.
     &Apache::edit::editfield('',$text,'',20,1);      &Apache::edit::editfield('',$text,'',20,1);
     } elsif ($target eq 'modified') {      } elsif ($target eq 'modified') {
  my $text=$$parser[-1]->get_text("/function");   my $text=$$parser[-1]->get_text("/ylabel");
  $result.=&Apache::edit::modifiedfield($token);   $result.=&Apache::edit::modifiedfield($token);
     }      }
     return $result;      return $result;
Line 619  sub start_axis { Line 643  sub start_axis {
  $result .= &Apache::edit::tag_start($target,$token,'Plot Axes');   $result .= &Apache::edit::tag_start($target,$token,'Plot Axes');
  $result .= &edit_attributes($target,$token,\%axis_defaults);   $result .= &edit_attributes($target,$token,\%axis_defaults);
     } elsif ($target eq 'modified') {      } elsif ($target eq 'modified') {
    my $constructtag=&Apache::edit::get_new_args
       ($token,$parstack,$safeeval,keys(%axis_defaults));
    if ($constructtag) {
       $result = &Apache::edit::rebuild_tag($token);
       $result.= &Apache::edit::handle_insert();
    }
     }      }
     return $result;      return $result;
 }  }
Line 630  sub end_axis { Line 660  sub end_axis {
     } elsif ($target eq 'edit') {      } elsif ($target eq 'edit') {
  $result.=&Apache::edit::tag_end($target,$token);   $result.=&Apache::edit::tag_end($target,$token);
     } elsif ($target eq 'modified') {      } elsif ($target eq 'modified') {
  my $constructtag=&Apache::edit::get_new_args  
     ($token,$parstack,$safeeval,keys(%axis_defaults));  
  if ($constructtag) {  
     $result = &Apache::edit::rebuild_tag($token);  
     $result.= &Apache::edit::handle_insert();  
  }  
     }      }
     return $result;      return $result;
 }  }
Line 811  sub edit_attributes { Line 835  sub edit_attributes {
   
 #------------------------------------------------ insert_xxxxxxx  #------------------------------------------------ insert_xxxxxxx
 sub insert_plot {  sub insert_plot {
     my $result;      my $result = '';
     #  plot attributes      #  plot attributes
     $result .= '<plot ';      $result .= "<plot \n";
     foreach my $attr (%plot_defaults) {      foreach my $attr (%plot_defaults) {
  $result .= '     '.$attr.'="'.$plot_defaults{$attr}->{'default'}.   $result .= "     $attr=\"$plot_defaults{$attr}->{'default'}\"\n";
     "\"\n";  
     }      }
     $result .= ">\n";      $result .= ">\n";
     # Add the components      # Add the components
     $result .= &insert_key();      $result .= &insert_key();
     $result .= &insert_axis();      $result .= &insert_axis();
     $result .= &insert_label();          $result .= &insert_title();    
     $result .= &insert_curve();      $result .= &insert_xlabel();    
     $result .= &insert_function();          $result .= &insert_ylabel();    
     $result .= "</curve>\n";  
     $result .= &insert_curve();      $result .= &insert_curve();
     $result .= &insert_data();      
     $result .= "</curve>\n";  
     # close up the <plot>      # close up the <plot>
     $result .= "</plot>\n";      $result .= "</plot>\n";
     return $result;      return $result;
Line 836  sub insert_plot { Line 856  sub insert_plot {
   
 sub insert_key {  sub insert_key {
     my $result;      my $result;
     $result .= '    <key ';      $result .= "    <key \n";
     foreach my $attr (%key_defaults) {      foreach my $attr (%key_defaults) {
  $result .= '         '.$attr.'="'.$key_defaults{$attr}->{'default'}.   $result .= "         $attr=\"$key_defaults{$attr}->{'default'}\"\n";
     "\"\n";  
     }      }
     $result .= "   />\n";      $result .= "   />\n";
     return $result;      return $result;
Line 849  sub insert_axis{ Line 868  sub insert_axis{
     my $result;      my $result;
     $result .= '    <axis ';      $result .= '    <axis ';
     foreach my $attr (%axis_defaults) {      foreach my $attr (%axis_defaults) {
  $result .= '         '.$attr.'="'.$axis_defaults{$attr}->{'default'}.   $result .= "         $attr=\"$axis_defaults{$attr}->{'default'}\"\n";
     "\"\n";  
     }      }
     $result .= "   />\n";      $result .= "   />\n";
     return $result;      return $result;
 }  }
   
 sub insert_title { return "    <title></title>\n"; }  sub insert_title { return "    <title></title>\n"; }
 sub insert_title { return "    <xlabel></xlabel>\n"; }  sub insert_xlabel { return "    <xlabel></xlabel>\n"; }
 sub insert_title { return "    <ylabel></ylabel>\n"; }  sub insert_ylabel { return "    <ylabel></ylabel>\n"; }
   
 sub insert_label {  sub insert_label {
     my $result;      my $result;
Line 878  sub insert_curve { Line 896  sub insert_curve {
  $result .= '         '.$attr.'="'.   $result .= '         '.$attr.'="'.
     $curve_defaults{$attr}->{'default'}."\"\n";      $curve_defaults{$attr}->{'default'}."\"\n";
     }      }
     $result .= "    >\n";      $result .= "    ></curve>\n";
 }  }
   
 sub insert_function {  sub insert_function {

Removed from v.1.28  
changed lines
  Added in v.1.29


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>