#+TITLE: sdp output hub
#+AUTHOR: Ralph Amissah
#+EMAIL: [[mailto:ralph.amissah@gmail.com][ralph.amissah@gmail.com]]
#+DESCRIPTION: documents - structuring, publishing in multiple formats & search
#+KEYWORDS
#+LANGUAGE: en
#+STARTUP: indent content
#+OPTIONS: H:3 num:nil toc:t \n:nil @:t ::t |:t ^:nil _:nil -:t f:t *:t <:t
#+OPTIONS: TeX:t LaTeX:t skip:nil d:nil todo:t pri:nil tags:not-in-toc
#+OPTIONS: author:nil email:nil creator:nil timestamp:nil
#+PROPERTY: header-args :padline no :exports code :noweb yes
#+EXPORT_SELECT_TAGS: export
#+EXPORT_EXCLUDE_TAGS: noexport
#+FILETAGS: :sdp:rel:output:
#+TAGS: assert(a) class(c) debug(d) mixin(m) sdp(s) tangle(T) template(t) WEB(W) noexport(n)
[[./sdp.org][sdp]] [[./][org/]]
* 0. output hub [#A] :module:sdp:output_hub:
** module template
#+BEGIN_SRC d :tangle ../src/sdp/output/hub.d
/++
output hub
check & generate output types requested
+/
module sdp.output.hub;
template outputHub() {
<>
void outputHub(D,I)(D doc_abstraction, I doc_matters) {
mixin SiSUoutputRgxInit;
static auto rgx = Rgx();
debug (substitutions) {
enum Substitute { match, markup, html, }
writeln(__LINE__, ":", __FILE__, ": DEBUG substitutions:");
writeln("Doc Title: ", doc_matters.conf_make_meta.meta.title_full);
if (doc_matters.conf_make_meta.make.bold) {
writeln("regex to match: ", doc_matters.conf_make_meta.make.bold[Substitute.match]);
writeln("substitution to make: ", doc_matters.conf_make_meta.make.bold[Substitute.html]);
auto _w = "1. Debian test string. Debian again. (the problem) do not use initialized only not repopulated"
.replaceAll(
regex(doc_matters.conf_make_meta.make.bold[Substitute.match]),
doc_matters.conf_make_meta.make.bold[Substitute.html]
);
writeln(_w);
writeln("2a. Debian test string. Debian again. (the problem) do not use initialized only not repopulated"
.replaceAll(
regex(doc_matters.conf_make_meta.make.bold[Substitute.match]),
doc_matters.conf_make_meta.make.bold[Substitute.html]
));
auto _v = regex(doc_matters.conf_make_meta.make.bold[Substitute.match]);
writeln("2b. Debian test string. Debian again. (the problem) do not use initialized only not repopulated"
.replaceAll(
_v,
doc_matters.conf_make_meta.make.bold[Substitute.html]
));
}
}
<>
}
}
template outputHubOp() {
<>
void outputHubOp(E,O)(E env, O opt_action) {
mixin SiSUoutputRgxInit;
static auto rgx = Rgx();
<>
}
}
#+END_SRC
** initialize / imports
#+name: output_imports
#+BEGIN_SRC d
import sdp.output,
sdp.output.epub3,
sdp.output.html,
sdp.output.sqlite,
sdp.output.xmls,
sdp.output.source_sisupod,
sdp.output.create_zip_file,
sdp.output.paths_output;
#+END_SRC
** output options
*** verbose
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.verbose) {
writeln(doc_matters.xml.keys_seq.seg);
}
#+END_SRC
*** output source: _sisusrc_ &/or _sisupod_
[[./output_sisupod.org][output_sisupod]]
#+name: output_options
#+BEGIN_SRC d
if ((doc_matters.opt.action.source)
|| (doc_matters.opt.action.sisupod)) {
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.source)) {
writeln("sisu source processing... ");
}
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.sisupod)) {
writeln("sisupod source processing... ");
}
SiSUpod!()(doc_matters);
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.debug_do)
&& (doc_matters.opt.action.source)) {
writeln("sisu source done");
}
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.debug_do)
&& (doc_matters.opt.action.sisupod)) {
writeln("sisupod done");
}
}
#+END_SRC
*** text
[[./output_text.org][output_text]]
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.text) {
/+ mixin outputText; +/
if ((doc_matters.opt.action.verbose)) {
writeln("text processing... ");
}
}
#+END_SRC
*** html
[[./output_xmls.org][output_xmls]]
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.html) {
if ((doc_matters.opt.action.verbose)) {
writeln("html scroll processing... ");
}
outputHTML!().scroll(doc_abstraction, doc_matters);
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.debug_do)) {
writeln("html scroll done");
}
if ((doc_matters.opt.action.verbose)) {
writeln("html seg processing... ");
}
outputHTML!().seg(doc_abstraction, doc_matters);
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.debug_do)) {
writeln("html seg done");
}
outputHTML!().css(doc_matters);
} else if (doc_matters.opt.action.html_seg) {
if ((doc_matters.opt.action.verbose)) {
writeln("html seg processing... ");
}
outputHTML!().seg(doc_abstraction, doc_matters);
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.debug_do)) {
writeln("html seg done");
}
outputHTML!().css(doc_matters);
} else if (doc_matters.opt.action.html_scroll) {
if ((doc_matters.opt.action.verbose)) {
writeln("html scroll processing... ");
}
outputHTML!().scroll(doc_abstraction, doc_matters);
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.debug_do)) {
writeln("html scroll done");
}
outputHTML!().css(doc_matters);
}
#+END_SRC
*** epub
[[./output_xmls.org][output_xmls]]
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.epub) {
if ((doc_matters.opt.action.verbose)) {
writeln("epub3 processing... ");
}
outputEPub3!()(doc_abstraction, doc_matters);
// epub.css_write;
if ((doc_matters.opt.action.verbose)
&& (doc_matters.opt.action.debug_do)) {
writeln("epub3 done");
}
}
#+END_SRC
*** pdf
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.pdf) {
/+ mixin outputPDF; +/
writeln("pdf processing");
}
#+END_SRC
*** odt
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.odt) {
/+ mixin outputODT; +/
writeln("odt processing");
}
#+END_SRC
*** sqlite
**** discrete
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.sqlite_discrete) {
if ((doc_matters.opt.action.verbose)) {
writeln("sqlite processing... ");
}
SQLiteHubDiscreteBuildTablesAndPopulate!()(doc_abstraction, doc_matters);
}
#+END_SRC
**** collection
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.sqlite_update) {
if ((doc_matters.opt.action.verbose)) {
writeln("sqlite processing... ");
}
SQLiteHubBuildTablesAndPopulate!()(doc_abstraction, doc_matters);
}
#+END_SRC
*** sqlite (create, drop)
**** collection
#+name: output_options_op
#+BEGIN_SRC d
if ((opt_action.sqlite_create)) {
if ((opt_action.verbose)) {
writeln("sqlite create table... ");
}
SQLiteTablesCreate!()(env, opt_action);
}
if ((opt_action.sqlite_drop)) {
if ((opt_action.verbose)) {
writeln("sqlite drop table... ");
}
SQLiteTablesDrop!()();
}
#+END_SRC
*** postgresql
#+name: output_options
#+BEGIN_SRC d
if (doc_matters.opt.action.postgresql) {
/+ mixin outputPostgreSQL; +/
writeln("pgsql processing");
}
#+END_SRC
* __END__