ViewVC Help
View File | Revision Log | Show Annotations | Download File | View Changeset | Root Listing
root/repos/FeepingCreaturism/Jargon.cpp
(Generate patch)

Comparing FeepingCreaturism/Jargon.cpp (file contents):
Revision 265 by Douglas Thrift, 2004-10-27T01:50:34-07:00 vs.
Revision 336 by douglas, 2004-12-13T21:23:11-08:00

# Line 5 | Line 5
5   // $Id$
6  
7   #include "Jargon.hpp"
8 < #include "Matcher.hpp"
8 > #include "Matcher/Matcher.hpp"
9  
10 < Jargon::Jargon(const ext::String& path, const ext::String& jargon, bool include,
11 <        const ext::String& relative) : include(include), args(1, "jargon.xsl")
10 > Jargon::Jargon(const ext::String& path, const ext::String& jargon, bool include, const ext::String& relative) : include(include)
11   {
12 <        args.InsertLast(ios::String() << path << "/" << jargon);
13 <        args.InsertLast(ios::String() << "$jargon=" << jargon);
14 <
15 <        if (include) args.InsertLast("$include=true()");
12 >        args.InsertLast("--stringparam");
13 >        args.InsertLast("jargon");
14 >        args.InsertLast(jargon);
15 >        args.InsertLast("--param");
16 >        args.InsertLast("include");
17 >        args.InsertLast(ios::String() << include << "()");
18  
19          if (!relative.IsEmpty())
20          {
21 <                args.InsertLast(ios::String() << "$relative=" << relative);
21 >                args.InsertLast("--stringparam");
22 >                args.InsertLast("relative");
23 >                args.InsertLast(relative);
24          }
25 +
26 +        args.InsertLast("jargon.xsl");
27 +        args.InsertLast(ios::String() << path << "/" << jargon);
28   }
29  
30   ios::PrintWriter& operator<<(ios::PrintWriter& pout, const Jargon& jargon)
31   {
32 <        _S<api::Process> xslt("/usr/local/bin/sabcmd", jargon.args);
32 >        _S<api::Process> xslt("/usr/local/bin/xsltproc", jargon.args);
33  
34          if (jargon.include) ios::ReadLine(*xslt.GetReader());
35  
36 <        ios::ReadToWrite(*xslt.GetReader(), pout);
36 >        if (jargon.include)
37 >        {
38 >                ext::String line;
39 >                Matcher matcher("^(.*) xmlns=\"http://www.w3.org/1999/xhtml\"(.*)$");
40 >
41 >                while (ios::ReadLine(*xslt.GetReader(), line))
42 >                {
43 >                        while (line == matcher) line = matcher[1] + matcher[2];
44 >
45 >                        pout << line << ios::NewLine;
46 >                }
47 >        }
48 >        else ios::ReadToWrite(*xslt.GetReader(), pout);
49 >
50 >        xslt.Join();
51  
52          return pout;
53   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines