Diff for /loncom/lonsql between versions 1.25 and 1.26

version 1.25, 2001/03/27 19:11:12 version 1.26, 2001/03/27 19:57:53
Line 233  sub make_new_child { Line 233  sub make_new_child {
     my $result;      my $result;
     my @files;      my @files;
     my $subsetflag=0;      my $subsetflag=0;
     unless ($sth->execute())      if ($query) {
     {   unless ($sth->execute())
  &logthis("<font color=blue>WARNING: Could not retrieve from database: $@</font>");   {
  $result="";      &logthis("<font color=blue>WARNING: Could not retrieve from database: $@</font>");
     }      $result="";
     else {   }
  my $r1=$sth->fetchall_arrayref;   else {
  my @r2;      my $r1=$sth->fetchall_arrayref;
  map {my $a=$_;       my @r2;
      my @b=map {escape($_)} @$a;      map {my $a=$_; 
      push @files,@{$a}[3];   my @b=map {escape($_)} @$a;
      push @r2,join(",", @b)   push @files,@{$a}[3];
      } (@$r1);   push @r2,join(",", @b)
  $result=join("&",@r2);   } (@$r1);
       $result=join("&",@r2);
    }
     }      }
   
     # do custom metadata searching here and build into result      # do custom metadata searching here and build into result
     if ($custom) {      if ($custom) {
  &logthis("am going to do custom query for $custom");   &logthis("am going to do custom query for $custom");
  if (@files) {   if ($query) {
     @metalist=map {$perlvar{'lonDocRoot'}.$_.'.meta'} @files;      @metalist=map {$perlvar{'lonDocRoot'}.$_.'.meta'} @files;
  }   }
  else {   else {
Line 266  sub make_new_child { Line 267  sub make_new_child {
  # if file is indicated in sql database and is   # if file is indicated in sql database and is
  # part of query result list, then do the pattern match.   # part of query result list, then do the pattern match.
  my $customresult='';   my $customresult='';
    my @r2;
  foreach my $m (@metalist) {   foreach my $m (@metalist) {
     my $fh=IO::File->new($m);      my $fh=IO::File->new($m);
     my @lines=<$fh>;      my @lines=<$fh>;
Line 278  sub make_new_child { Line 280  sub make_new_child {
     $stuff=~s/\n?\<$f[^\>]*\>.*?<\/$f[^\>]*\>\n?//;      $stuff=~s/\n?\<$f[^\>]*\>.*?<\/$f[^\>]*\>\n?//;
  }   }
  my $m2=$m; my $docroot=$perlvar{'lonDocRoot'};   my $m2=$m; my $docroot=$perlvar{'lonDocRoot'};
  $m2=~s/^$docroot//; $m2=~s/\.meta$//;   $m2=~s/^$docroot//;
    $m2=~s/\.meta$//;
    unless ($query) {
       my $q2="select * from metadata where url like '$m2'";
       my $sth = $dbh->prepare($query);
       $sth->execute();
       my $r1=$sth->fetchall_arrayref;
       map {my $a=$_; 
    my @b=map {escape($_)} @$a;
    push @files,@{$a}[3];
    push @r2,join(",", @b)
    } (@$r1);
    }
 # &logthis("found: $stuff");  # &logthis("found: $stuff");
  $customresult.='&custom='.escape($m2).','.escape($stuff);   $customresult.='&custom='.escape($m2).','.escape($stuff);
     }      }
  }   }
    $result=join("&",@r2) unless $query;
  $result.=$customresult;   $result.=$customresult;
     }      }
     # reply with result      # reply with result

Removed from v.1.25  
changed lines
  Added in v.1.26


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