ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/COMP/SCRAM/src/ActiveDoc/ActiveDoc.pm
(Generate patch)

Comparing COMP/SCRAM/src/ActiveDoc/ActiveDoc.pm (file contents):
Revision 1.7 by williamc, Tue Nov 23 17:20:40 1999 UTC vs.
Revision 1.26 by williamc, Mon Aug 28 07:43:20 2000 UTC

# Line 7 | Line 7
7   #
8   # Interface
9   # ---------
10 < # new()         : A new ActiveDoc object
10 > # new(ActiveStore)              : A new ActiveDoc object
11   # url()         : Return/set the docs url - essential
12   # file()        : Return the local filename of document
13 + # ProcessFile() : Return the filename of PreProcessed document
14   #
15 < # parse(parselabel): Parse the document file for the given parse level
15 < # newparse(parselabel) : Create a new parse type
16 < # addtag(parselabel,tagname,start,obj,text,obj,end,obj)
17 < #                               : Add tags to the parse given by label
18 < # newdoc(file)  : Return an new object of the appropriate type
15 > # parent()         : return the object ref of the calling parent
16   # getfile(url)  : get a processedfile object given a url
17 < # config([ActiveConfig]) : Set up/return Configuration for the document
21 < # basequery([ActiveConfig]) : Set up/return UserQuery for the doc
22 < # copydocconfig(ActiveDoc) : Copy the basic configuration from the ActiveDoc
23 < # copydocquery(ActiveDoc) : Copy the basicquery from the ActiveDoc
17 > # activatedoc(url) : Return the object ref for a doc described by the given url
18   #
19   # -- error methods --
20   # error(string)       : Report an general error to the user
21   # parseerror(string)  : Report an error during parsing a file
22 < # line()              : Return the current line number of the document
23 < #                       and the ProcessedFileObj it is in
22 > # line([linenumber])     : Return the line number of the document
23 > #                       and the ProcessedFileObj it is in corresponding to the
24 > #                       supplied number of the expanded document
25 > #                       If no number supplied - the currentparse number will be #                       used
26  
27   package ActiveDoc::ActiveDoc;
28   require 5.004;
29 < use ActiveDoc::Parse;
34 < use ActiveDoc::ActiveConfig;
29 > use ActiveDoc::SimpleURLDoc;
30   use ActiveDoc::PreProcessedFile;
31 < use ObjectUtilities::ObjectBase;
37 < use URL::URLhandler;
31 > use Utilities::Verbose;
32  
33 < @ISA = qw(ObjectUtilities::ObjectBase);
33 > @ISA = qw(ActiveDoc::SimpleURLDoc Utilities::Verbose);
34  
35   sub new {
36          my $class=shift;
37 <        $self={};
37 >        my $self={};
38          bless $self, $class;
39 <        $self->config(shift);
40 <        
41 <        # A URL handler per document
42 <        $self->{urlhandler}=URL::URLhandler->new($self->config()->cache());
43 <
50 <        $self->init(@_);
39 >        $self->{Ostore}=shift;
40 >        $self->cache($self->{Ostore}->cache());
41 >        $self->{dbstore}=$self->{Ostore};
42 >        $self->_initdoc("doc",@_);
43 > #       $self->{switch}=ActiveDoc::SimpleURLDoc->new($self->{cache});
44          return $self;
45   }
46  
54 # ----- parse related routines --------------
55 sub parse {
56        my $self=shift;
57        $parselabel=shift;
58
59        my $file=$self->file();
60        if ( $file ) {
61          $self->{currentparser}=$self->{parsers}{$parselabel};
62          $self->{parsers}{$parselabel}->parse($file,@_);
63          delete $self->{currentparser};
64        }
65        else {
66          print "Cannot parse - file not known\n";
67        }
68 }
69
70 sub newparse {
71        my $self=shift;
72        my $parselabel=shift;
73
74        $self->{parsers}{$parselabel}=ActiveDoc::Parse->new();
75        $self->{parsers}{$parselabel}->addignoretags();
76        $self->{parsers}{$parselabel}->addgrouptags();
77 }
78
79 sub addtag {
80        my $self=shift;
81        my $parselabel=shift;
82        if ( $#_ != 6 ) {
83                $self->error("Incorrect addtags specification\n".
84                                "called with :\n@_ \n");
85        }
86        $self->{parsers}{$parselabel}->addtag(@_);
87 }
88
89 sub addurltags {
90        my $self=shift;
91        my $parselabel=shift;
92        
93        $self->{parsers}{$parselabel}->
94                addtag("Base", \&Base_start, $self, "", $self,
95                        \&Base_end, $self);
96 }
97
47   sub url {
48          my $self=shift;
49 <        @_ ?$self->{File}=$self->getfile(shift)
50 <            : $self->{File};
51 < }
52 <
53 < sub copydocconfig {
54 <        my $self=shift;
55 <        my $ActiveDoc=shift;
56 <        
57 <        $self->config($ActiveDoc->config());
58 <
59 < }
111 <
112 < sub copydocquery {
113 <        my $self=shift;
114 <        my $ActiveDoc=shift;
115 <
116 <         $self->basequery($ActiveDoc->basequery());
117 < }
118 <
119 < sub config {
120 <        my $self=shift;
121 <        @_?$self->{ActiveConfig}=shift
122 <           : $self->{ActiveConfig};
123 < }
124 <
125 < sub basequery {
126 <        my $self=shift;
127 <        @_ ? $self->{UserQuery}=shift
128 <           : $self->{UserQuery};
49 >        # get file & preprocess
50 >        if ( @_  ) {
51 >                $self->{origurl}=shift;
52 >                $self->{File}=$self->getfile($self->{origurl});
53 >                $self->filetoparse($self->{File}->ProcessedFile());
54 >                $self->verbose("url downloaded to ".$self->{File}->ProcessedFile());
55 >        }
56 >        if ( defined $self->{File} ) {
57 >          return $self->{File}->url();
58 >        }
59 >        else { return "undefined"; }
60   }
61  
62 < sub getfile() {
62 > sub getfile {
63          my $self=shift;
64          my $origurl=shift;
65  
66          my $fileref;
67 <        my ($url, $file)=$self->{urlhandler}->get($origurl);
67 >        my ($url, $file);
68 >        if ( 0 ) {
69 >             $self->verbose("Forced download of $origurl");
70 >             ($url, $file)=$self->urldownload($origurl);
71 >        }
72 >        else {
73 >           $self->verbose("Attempting to get $origurl");
74 >           ($url, $file)=$self->urlget($origurl);
75 >        }
76          # do we already have an appropriate object?
77 <        ($fileref)=$self->config()->find($url);
139 <        #undef $fileref;
77 >        ($fileref)=$self->{dbstore}->find($url);
78          if (  defined $fileref ) {
79 <         print "found $url in database ----\n";
79 >         $self->verbose("Found $url in database");
80           $fileref->update();
81          }
82          else {
83           if ( $file eq "" ) {
84             $self->parseerror("Unable to get $origurl");
85           }
86 <         #-- set up a new preprocess file
87 <         print "Making a new file $url----\n";
88 <         $fileref=ActiveDoc::PreProcessedFile->new($self->config());
86 >         # -- set up a new preprocess file
87 >         $self->verbose("Making a new preprocessed file $url");
88 >         $fileref=ActiveDoc::PreProcessedFile->new($self->{Ostore});
89 >         #$fileref->cache($self->{cache});
90           $fileref->url($url);
91           $fileref->update();
92          }
93          return $fileref;
94   }
95  
96 < # -------- Error Handling and Error services --------------
96 > sub activatedoc {
97 >        my $self=shift;
98 >        my $url=shift;
99  
100 < sub error {
101 <        my $self=shift;
102 <        my $string=shift;
100 >        # first get a preprocessed copy of the file
101 >        my $fileobj=$self->getfile($url);
102 >
103 >        # now parse it for the <Doc> tag
104 >        my $tempdoc=ActiveDoc::SimpleURLDoc->new($self->{cache});
105 >        $tempdoc->filetoparse($fileobj->ProcessFile());
106 >        my ($doctype,$docversion)=$tempdoc->doctype();
107 >        undef $tempdoc;
108 >        
109 >        if ( ! defined $doctype ) {
110 >          $self->parseerror("No <Doc type=> Specified in ".$url);
111 >        }
112 >        $self->verbose("doctype required is $doctype $docversion");
113  
114 <        die $string."\n";
114 >        # Set up a new object of the specified type
115 >        eval "require $doctype";
116 >        die $@ if $@;
117 >        my $newobj=$doctype->new($self->{Ostore}, $url);
118 >        $newobj->url($url);
119 >        #$newobj->parent($self);
120 >        return $newobj;
121   }
122  
123 < sub parseerror {
124 <        my $self=shift;
168 <        my $string=shift;
123 > sub parent {
124 >        my $self=shift;
125  
126 <        ($line, $file)=$self->line();
127 <        print "Parse Error in ".$file->url().", line ".
172 <                                        $line."\n";
173 <        print $string."\n";
174 <        die;
126 >        @_?$self->{parent}=shift
127 >          :$self->{parent};
128   }
129  
130 < sub checktag {
130 > # -------- Error Handling and Error services --------------
131 >
132 > sub parseerror {
133          my $self=shift;
134 <        my $tagname=shift;
180 <        my $hashref=shift;
181 <        my $param=shift;
134 >        my $string=shift;
135  
136 <        if ( ! exists $$hashref{$param} ) {
137 <          $self->parseerror("Incomplete Tag <$tagname> : $param required");
138 <        }
136 >        if ( $self->currentparsename() eq "" ) {
137 >                $self->error($string);
138 >        }
139 >        elsif ( ! defined $self->{File} ) {
140 >         print "Parse Error in ".$self->filenameref()." line "
141 >                                .$self->{currentparser}->line()."\n";
142 >         print $string."\n";
143 >        }
144 >        else {
145 >         ($line, $file)=$self->line();
146 >         print "Parse Error in ".$file->url().", line ".
147 >                                        $line."\n";
148 >         print $string."\n";
149 >        }
150 >        exit;
151   }
152  
153   sub line {
154          my $self=shift;
155 +        my $parseline;
156 +
157 +        if ( @_ ) {
158 +          $parseline=shift;
159 +        }
160 +        else {
161 +          $parseline=$self->{currentparser}->line();
162 +        }
163 +
164          my ($line, $fileobj)=
165 <                $self->{PPfile}->line($self->{currentparser}->line());
165 >                $self->{File}->realline($parseline);
166          return ($line, $fileobj);
167   }
168  
169   sub tagstartline {
170          my $self=shift;
171 <        my ($line, $fileobj)=$self->{PPfile}->line(
171 >        my ($line, $fileobj)=$self->{File}->line(
172                  $self->{currentparser}->tagstartline());
173          return ($line, $fileobj);
174   }
# Line 202 | Line 176 | sub tagstartline {
176   sub file {
177          my $self=shift;
178  
179 <        $self->{PPf}->file();
179 >        $self->{File}->file();
180   }
181  
182 < # --------------- Initialisation Methods ---------------------------
209 <
210 < sub preprocess_init {
182 > sub ProcessFile {
183          my $self=shift;
212        $self->{PPfile}=PreProcessedFile->new($self->config());
213 }
184  
185 < sub init {
216 <        # Dummy Routine - override for derived classes
185 >        return $self->{File}->ProcessedFile();
186   }
187  
219 # ------------------- Tag Routines -----------------------------------
188   #
189 < # Base - for setting url bases
189 > # Delegate all else to the switch
190   #
191 < sub Base_start {
192 <        my $self=shift;
225 <        my $name=shift;
226 <        my $hashref=shift;
191 > #sub AUTOLOAD {
192 > #        my $self=shift;
193  
194 <        $self->checktag($name, $hashref, 'type' );
195 <        $self->checktag($name, $hashref, 'base' );
230 <      
231 <        # Keep track of base tags
232 <        push @{$self->{basestack}}, $$hashref{"type"};
233 <        # Set the base
234 <        $self->{urlhandler}->setbase($$hashref{"type"},$hashref);
194 >        # dont propogate destroy methods
195 > #        return if $AUTOLOAD=~/::DESTROY/;
196  
197 < }
197 >        # remove this package name
198 > #        ($name=$AUTOLOAD)=~s/ActiveDoc::ActiveDoc:://;
199  
200 < sub Base_end {
201 <        my $self=shift;
202 <        my $name=shift;
241 <        my $type;
200 >        # pass the message to SimpleDoc
201 > #        $self->{switch}->$name(@_);
202 > #}
203  
204 <        if ( $#{$self->{basestack}} == -1 ) {
205 <                print "Parse Error : unmatched </".$name."> on line ".
206 <                        $self->line()."\n";
207 <                die;
208 <        }
209 <        else {
210 <          $type = pop @{$self->{basestack}};
211 <          $self->{urlhandler}->unsetbase($type);
212 <        }
204 >
205 > # ------------------- Tag Routines -----------------------------------
206 > sub Doc_Start {
207 >        my $self=shift;
208 >        my $name=shift;
209 >        my $hashref=shift;
210 >        
211 >        $self->checktag($name, $hashref, "type");
212 >        $self->{doctypefound}++;
213 >        if ( $self->{doctypefound} == 1 ) { # only take first doctype
214 >           $self->{docobject}=$$hashref{'type'};
215 >        }
216   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines