From 1b0a18d44180a3c19ae9325bb599831708804c03 Mon Sep 17 00:00:00 2001 From: ulrich Date: Sat, 03 Jul 2021 07:41:48 +0000 Subject: [PATCH] Nutzung des HttpHelper hinzugefuegt --- src/de/uhilger/httpserver/adoc/AdocActor.java | 39 +++++++++++++++++++++------------------ 1 files changed, 21 insertions(+), 18 deletions(-) diff --git a/src/de/uhilger/httpserver/adoc/AdocActor.java b/src/de/uhilger/httpserver/adoc/AdocActor.java index 66bbe00..08bb487 100644 --- a/src/de/uhilger/httpserver/adoc/AdocActor.java +++ b/src/de/uhilger/httpserver/adoc/AdocActor.java @@ -17,7 +17,10 @@ */ package de.uhilger.httpserver.adoc; +import com.sun.net.httpserver.HttpExchange; +import de.uhilger.httpserver.base.HttpResponder; import java.io.File; +import java.io.IOException; import java.util.Map; import java.util.logging.Level; import java.util.logging.Logger; @@ -46,6 +49,16 @@ public static final String HTML = "html"; public static final String PDF = "pdf"; + public void handle(HttpExchange e, String fileBase, String fileName) throws IOException { + File adocfile = new File(fileBase, fileName); + logger.fine("adocfile: " + adocfile.getAbsolutePath()); + AdocActor actor = new AdocActor(); + File outfile = actor.getTargetFile(adocfile, AdocActor.HTML); + logger.fine("outfile: " + outfile.getAbsolutePath()); + HttpResponder fs = new HttpResponder(); + fs.serveFile(e, outfile); + } + public File getTargetFile(File adocfile, String ext) { String nameext = adocfile.getName(); String fname = nameext.substring(0, nameext.lastIndexOf(DOT)); @@ -60,12 +73,6 @@ logger.log(Level.FINE, "in: {0}", absname); // HTML-Datei ermitteln - //String nameext = adocfile.getName(); - //String fname = nameext.substring(0, nameext.lastIndexOf(DOT)); - //File htmlfile = new File(adocfile.getParentFile(), fname + DOT + HTML); - //File outfile = htmlfile; // Standardmaessig wird HTML zurueckgegeben - //logger.fine("out: " + outfile.getAbsolutePath()); - //response.setCharacterEncoding("UTF-8"); File outfile = getTargetFile(adocfile, HTML); File htmlfile = outfile; @@ -74,6 +81,7 @@ die HTML-Datei noch nicht existiert */ if(!htmlfile.exists() || adocfile.lastModified() > htmlfile.lastModified()) { + logger.fine("calling transform for " + absname); transform(absname); } @@ -91,17 +99,6 @@ //response.setContentType("application/pdf"); transform(absname, PDF); } - //ServletOutputStream os = response.getOutputStream(); - //InputStream bytes = new FileInputStream(outfile); - //int b = bytes.read(); - //while(b > -1 ) { - // os.write(b); - // b = bytes.read(); - //} - } else { - //PrintWriter out = response.getWriter(); - //InputStreamReader in = new InputStreamReader(new FileInputStream(outfile), "UTF-8"); - //in.transferTo(out); } } @@ -121,6 +118,7 @@ * nach PDF transformiert werden soll */ private void transform(String fileName, String backend) { + logger.fine("fileName: " + fileName + ", backend: " + backend); Map<String, Object> attributes; File outFile = new File(fileName); String thisDirName = outFile.getParent(); @@ -150,9 +148,14 @@ .attributes(attributes).asMap(); } + File adcf = new File(fileName); + logger.fine("before asciidoctor create, adcf: " + adcf.getAbsolutePath()); Asciidoctor asciidoctor = create(); + logger.fine("asciidoctor created."); asciidoctor.requireLibrary("asciidoctor-diagram"); - asciidoctor.convertFile(new File(fileName), options); + logger.fine("asciidoctor requireLibrary diagram passed."); + logger.fine("calling asciidoctor.convert for file " + adcf.getAbsolutePath()); + asciidoctor.convertFile(adcf, options); } } -- Gitblit v1.9.3