5 |
|
// $Id$ |
6 |
|
|
7 |
|
#include "Jargon.hpp" |
8 |
< |
#include "Matcher.hpp" |
8 |
> |
#include "Matcher/Matcher.hpp" |
9 |
|
|
10 |
< |
Jargon::Jargon(const ext::String& path, bool include, |
11 |
< |
const ext::String& relative) : include(include), |
12 |
< |
args(1, FeepingCreaturism::program) |
10 |
> |
Jargon::Jargon(const ext::String& path, const ext::String& jargon, bool include, const ext::String& relative) : include(include) |
11 |
|
{ |
12 |
< |
args.push_back("-p"); |
13 |
< |
args.push_back("include"); |
14 |
< |
args.push_back(lexical_cast<ext::String>(include) + "()"); |
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.push_back("-p"); |
22 |
< |
args.push_back("relative"); |
23 |
< |
args.push_back("\"" + relative + "\""); |
21 |
> |
args.InsertLast("--stringparam"); |
22 |
> |
args.InsertLast("relative"); |
23 |
> |
args.InsertLast(relative); |
24 |
|
} |
25 |
|
|
26 |
< |
args.push_back(path); |
27 |
< |
args.push_back("jargon.xsl"); |
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 |
< |
redi::ipstream pin("/usr/local/bin/Xalan", jargon.args); |
32 |
> |
_S<api::Process> xslt("/usr/local/bin/xsltproc", jargon.args); |
33 |
|
|
34 |
< |
if (jargon.include) |
34 |
< |
{ |
35 |
< |
std::string ignore; |
34 |
> |
if (jargon.include) ios::ReadLine(*xslt.GetReader()); |
35 |
|
|
36 |
< |
std::getline(pin, ignore); |
38 |
< |
} |
39 |
< |
|
40 |
< |
do |
36 |
> |
if (jargon.include) |
37 |
|
{ |
38 |
< |
std::string line; |
38 |
> |
ext::String line; |
39 |
> |
Matcher matcher("^(.*) xmlns=\"http://www.w3.org/1999/xhtml\"(.*)$"); |
40 |
|
|
41 |
< |
std::getline(pin, line); |
41 |
> |
while (ios::ReadLine(*xslt.GetReader(), line)) |
42 |
> |
{ |
43 |
> |
while (line == matcher) line = matcher[1] + matcher[2]; |
44 |
|
|
45 |
< |
pout << line << '\n'; |
45 |
> |
pout << line << ios::NewLine; |
46 |
> |
} |
47 |
|
} |
48 |
< |
while (pin.good()); |
48 |
> |
else ios::ReadToWrite(*xslt.GetReader(), pout); |
49 |
|
|
50 |
|
return pout; |
51 |
|
} |