/++
  output hub<BR>
  check & generate output types requested
+/
module sdp.output.hub;
template outputHub() {
  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;
  void outputHub(D,I)(D doc_abstraction, I doc_matters) {
    mixin SiSUoutputRgxInit;
    mixin Msg;
    auto msg = Msg!()(doc_matters);
    static auto rgx = Rgx();
    if (doc_matters.opt.action.verbose) {
      writeln(doc_matters.xml.keys_seq.seg);
    }
    if ((doc_matters.opt.action.source)
    || (doc_matters.opt.action.sisupod)) {
      if (doc_matters.opt.action.source) {
        msg.v("sisu source processing...");
      }
      if (doc_matters.opt.action.sisupod) {
        msg.v("sisupod source processing...");
      }
      SiSUpod!()(doc_matters);
      if (doc_matters.opt.action.source) {
        msg.vv("sisu source done");
      }
      if (doc_matters.opt.action.sisupod) {
        msg.v("sisupod source done");
      }
    }
    if (doc_matters.opt.action.html_seg) {
      msg.v("html seg source processing...");
      outputHTML!().seg(doc_abstraction, doc_matters);
      msg.vv("html seg done");
    }
    if (doc_matters.opt.action.html_scroll) {
      msg.v("html scroll source processing...");
      outputHTML!().scroll(doc_abstraction, doc_matters);
      msg.vv("html scroll done");
    }
    if (doc_matters.opt.action.html_stuff) {
      msg.v("html copying images & css...");
      outputHTML!().css(doc_matters);
      outputHTML!().images_cp(doc_matters);
      msg.vv("html css & images done");
    }
    if (doc_matters.opt.action.epub) {
      msg.v("epub3 source processing...");
      outputEPub3!()(doc_abstraction, doc_matters);
      msg.vv("epub3 done");
    }
    if (doc_matters.opt.action.sqlite_discrete) {
      msg.v("sqlite processing...");
      SQLiteHubDiscreteBuildTablesAndPopulate!()(doc_abstraction, doc_matters);
      msg.vv("sqlite done");
    }
    if (doc_matters.opt.action.sqlite_insert
      || doc_matters.opt.action.sqlite_update
    ) {
      msg.v("sqlite update processing...");
      SQLiteHubBuildTablesAndPopulate!()(doc_abstraction, doc_matters);
      msg.vv("sqlite update done");
    } else if (doc_matters.opt.action.sqlite_delete) {
      msg.v("sqlite delete processing...");
      SQLiteHubBuildTablesAndPopulate!()(doc_abstraction, doc_matters);
      msg.vv("sqlite delete done");
    }
  }
}
template outputHubOp() {
  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;
  void outputHubOp(E,O)(E env, O opt_action) {
    mixin SiSUoutputRgxInit;
    static auto rgx = Rgx();
    if ((opt_action.sqlite_db_drop)) {
      if ((opt_action.verbose)) {
        writeln("sqlite drop db...");
      }
      SQLiteDbDrop!()(opt_action);
      if ((opt_action.very_verbose)) {
        writeln("sqlite drop db done");
      }
    }
    if ((opt_action.sqlite_db_create)) {
      if ((opt_action.verbose)) {
        writeln("sqlite create table...");
      }
      SQLiteTablesCreate!()(env, opt_action);
      if ((opt_action.very_verbose)) {
        writeln("sqlite create table done");
      }
    }
  }
}