#!@PERL@
# 
# Copyright (C) 1999 Kayvan A. Sylvan <kayvan@sylvan.com>
# You are free to use and modify this code under the terms of
# the GNU General Public Licence version 2 or later.
#
# Written with assistance from:
#   Edmar Wienskoski Jr. <edmar-w-jr@technologist.com>
#   Amir Karger <karger@post.harvard.edu>
#
# $Id: noweb2lyx.in,v 1.2 2000/03/29 23:02:36 karger Exp $
#
# NOTE: This file was automatically generated from noweb2lyx.lyx using noweb.
#
&usage() if ($#ARGV < 1); # zero or one argument 
if ($ARGV[0] eq "-pre") {
  &usage unless ($#ARGV == 2);
  $input_file = $ARGV[1]; $output_file = $ARGV[2]; $pre_only = 1;
} elsif ($ARGV[0] eq "-post") {
  &usage unless ($#ARGV == 2);
  $input_file = $ARGV[1]; $output_file = $ARGV[2]; $post_only = 1;
} else {
  &usage unless ($#ARGV == 1);
  $input_file = $ARGV[0]; $output_file = $ARGV[1];
  $pre_only = 0; $post_only = 0;
}
sub setup_files {
  my($in, $out) = @_;
  open(INPUT, "<$in") || die "Can not read $in: $!\n";
  open(OUTPUT, ">$out") || die "Can not write $out: $!\n";
}
sub usage() {
  print "Usage: noweb2lyx [-pre | -post] input-file output-file

If -pre is specified, only pre-processes the input-file for reLyX.
Similarly, in the case of -post, post-processes reLyX output.
In case of bugs, Email Kayvan Sylvan <kayvan\@sylvan.com>.\n";
  exit;
}
if (!$post_only) {
  if ($pre_only) {
    &setup_files($input_file, $output_file);
  } else {
    $relyx_file = "temp$$";
    &setup_files($input_file, $relyx_file);
  }
  inputline: while(<INPUT>)
  {
    if (/^\s*\<\<.*\>\>=/) { # Beginning of a noweb scrap
      $savedScrap = $_;
      $endLine = "";
      scrapline: while (<INPUT>) {
        last scrapline if /^@\s+/;
        $savedScrap .= $_;
      };
      switch: {
        if (/^@\s+$/) {$savedScrap .= $_; last switch; }
        if (/^@\s+%def.*$/) {$savedScrap .= $_; last switch; }
        if (/^@\s+(.*)$/) {$savedScrap .= "@\n"; $endLine = "$1\n"; }
      }
      print OUTPUT "\\begin{reLyXskip}\n";
      print OUTPUT $savedScrap;
      print OUTPUT "\\end{reLyXskip}\n\n";
      print OUTPUT "$endLine";
    } elsif (/^@\s+(.*)/) { # Beginning of a documentation chunk
      print OUTPUT $1; # We do not need the ``@'' part
    } elsif (/\[\[.+\]\]/) { # noweb quoted code
      s/\[\[.+?\]{2,}/{$&}/g;
      print OUTPUT;
    } else {
      print OUTPUT; # Just let the line pass through
    }
  }
  close(INPUT);
  close(OUTPUT);
}
if ((!$pre_only) && (!$post_only)) {
  open(INPUT, "<$relyx_file") ||
    die "Can not read $relyx_file: $!\n";
  $class = "article"; # default if none found
  parse: while(<INPUT>) {
    if (/\\docu[m]entclass{(.*)}/) {
      $class = $1;
      last parse;
    }
  }
  close(INPUT);
  $doc_class = "literate-" . $class;
  die "reLyX returned non-zero: $!\n"
    if (system("reLyX -c $doc_class $relyx_file"));
}
if (!$pre_only) {
  if ($post_only) {
    &setup_files("$input_file", "$output_file");
  } else {
    &setup_files("$relyx_file.lyx", "$output_file");
  }
  line: while(<INPUT>)
  {
    if (/\\latex latex/) { # Beginning of some latex code
      if (($line = <INPUT>) =~ /^\s*<</) { # code scrap
        $savedScrap = "\\layout Scrap\n\n$line";
        codeline: while (<INPUT>) {
          $savedScrap .= $_;
          last codeline if /^@\s+/;
        };
        print OUTPUT $savedScrap;
        slurp: while (<INPUT>) {
          last slurp if /\\latex /;
          next slurp if /\\newline/;
          next slurp if /^\s*$/;
          warn "confused by line: $_";
        }
      } else {
        # print the \latex latex line + next line
        print OUTPUT "$_$line";
      }
      next line;
    }
    if (/\[\[.+\]\]/) { # special code for [[var]]
      s/\[\[.+?\]{2,}/\n\\latex latex\n$&\n\\latex default\n/g;
      print OUTPUT;
      next line;
    }
    print OUTPUT; # default
  } 
  close(INPUT);
  close(OUTPUT);
}
system("rm -f $relyx_file*") unless ($post_only || $pre_only);