forked from jooby-project/jooby
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDocApp.java
More file actions
66 lines (51 loc) · 1.64 KB
/
DocApp.java
File metadata and controls
66 lines (51 loc) · 1.64 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/**
* Jooby https://jooby.io
* Apache License Version 2.0 https://jooby.io/LICENSE.txt
* Copyright 2014 Edgar Espina
*/
package io.jooby.adoc;
import io.jooby.Jooby;
import io.jooby.LogConfigurer;
import io.methvin.watcher.DirectoryWatcher;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.slf4j.bridge.SLF4JBridgeHandler;
import java.nio.file.Path;
import java.util.Arrays;
import static org.slf4j.helpers.NOPLogger.NOP_LOGGER;
public class DocApp extends Jooby {
static {
SLF4JBridgeHandler.removeHandlersForRootLogger();
SLF4JBridgeHandler.install();
}
{
Path site = DocGenerator.basedir().resolve("asciidoc").resolve("site");
assets("/*", site);
}
public static void main(String[] args) throws Exception {
// watch and block
LogConfigurer.configure(Arrays.asList("dev"));
Path basedir = DocGenerator.basedir();
Logger log = LoggerFactory.getLogger(DocGenerator.class);
log.info("waiting for doc");
DocGenerator.generate(basedir, false, Arrays.asList(args).contains("v1"));
log.info("doc ready");
runApp(new String[]{"server.port=4000"}, DocApp::new);
DirectoryWatcher watcher = DirectoryWatcher.builder()
.path(basedir.resolve("asciidoc"))
.logger(NOP_LOGGER)
.listener(event -> {
Path file = event.path();
if (file.toString().endsWith(".adoc")) {
try {
DocGenerator.generate(basedir, false, false);
log.info("doc ready");
} catch (Exception x) {
log.error("doc sync error", x);
}
}
})
.build();
watcher.watch();
}
}