AdocUtils.java
/**************************************************************************
*
* Copyright (c) 2017-2020 Yawg project contributors.
*
**************************************************************************/
package com.varmateo.yawg.asciidoctor;
import java.io.File;
import java.nio.file.Path;
import io.vavr.control.Option;
import org.asciidoctor.AttributesBuilder;
import org.asciidoctor.OptionsBuilder;
import org.asciidoctor.SafeMode;
import com.varmateo.yawg.spi.PageVars;
/**
* Utility functions simplifying Asciidoctor usage.
*/
final class AdocUtils {
/**
* No instances of this class are to be created.
*/
private AdocUtils() {
// Nothing to do.
}
/**
*
*/
public static OptionsBuilder buildOptionsForBakeWithoutTemplate(
final Path sourcePath,
final Path targetDir,
final Path targetPath,
final PageVars pageVars) {
final File targetFile = targetPath.toFile();
final AttributesBuilder attributes =
buildCommonAttributes(sourcePath, targetDir, pageVars)
.noFooter(false);
return buildCommonOptions(attributes)
.toFile(targetFile);
}
/**
*
*/
public static OptionsBuilder buildOptionsForBakeWithTemplate(
final Path sourcePath,
final Path targetDir,
final PageVars pageVars) {
final AttributesBuilder attributes =
buildCommonAttributes(sourcePath, targetDir, pageVars);
return buildCommonOptions(attributes)
.headerFooter(false);
}
/**
*
*/
private static OptionsBuilder buildCommonOptions(
final AttributesBuilder attributes) {
return OptionsBuilder.options()
.attributes(attributes)
.safe(SafeMode.UNSAFE);
}
/**
* Prepares a set of attributes that affect how Asciidoctor works.
*/
private static AttributesBuilder buildCommonAttributes(
final Path sourcePath,
final Path targetDir,
final PageVars pageVars) {
final String docDir = Option.of(sourcePath.getParent())
.map(Object::toString)
.getOrElse(".");
final AttributesBuilder attributes = AttributesBuilder.attributes();
// First add all the existing page vars as attributes visible
// to Asciidoc content.
attributes.attributes(pageVars.asMap());
// And now add , or override, some well known attributes which
// control behavior in the Asciidoctor renderer.
// Path of directory that contains the document. It is needed
// for the PlantUML AsciidoctorJ extension to find its input
// files relative to the AsciiDoc source document. At least in
// version 1.3.1 of asciidoctorj-diagrams
attributes.attribute("docdir", docDir);
// Path of directory where image files generated by PlantUML
// will be created.
final String imagesOutDir = targetDir.toAbsolutePath().normalize().toString();
attributes.attribute("imagesoutdir", imagesOutDir);
// Enable basic syntax highlithing by default.
attributes.attribute("source-highlighter", "coderay");
attributes.attribute("coderay-css", "style");
// Turn on callout icons in admonition blocks.
attributes.attribute("icons", "font");
// HACK - THIS MAKES THE AsciiDoc BAKER NOT THREAD SAFE.
System.setProperty("plantuml.include.path", docDir);
return attributes;
}
}