blob: 370494489364b9f50797bcbc23fba42d451d7e6d (
plain)
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
|
package bjc.rgens.newparser;
import java.io.IOException;
import java.net.URISyntaxException;
import java.net.URI;
import java.nio.file.FileSystem;
import java.nio.file.FileSystems;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.HashMap;
import java.util.Map;
/**
* Get access to the included grammars.
*
* @author Ben Culkin
*/
public class RGrammars {
private static RGrammarSet gramSet;
private static void loadSet() {
try {
URI rsc = RGrammarTest.class.getResource("/server-config-sample.cfg").toURI();
Map<String, String> env = new HashMap<>();
env.put("create", "true");
FileSystem zipfs = FileSystems.newFileSystem(rsc, env);
Path cfgPath = Paths.get(rsc);
gramSet = RGrammarSet.fromConfigFile(cfgPath);
} catch (IOException | URISyntaxException ex) {
RuntimeException rtex = new RuntimeException("Could not load grammars");
rtex.initCause(ex);
throw rtex;
}
}
public static String generateExport(String exportName) throws GrammarException {
if(gramSet == null) loadSet();
if(!gramSet.getExportedRules().contains(exportName)) {
throw new GrammarException(String.format("No built-in rule named %s", exportName));
}
RGrammar gram = gramSet.getExportSource(exportName);
String res = gram.generate(exportName);
if(exportName.contains("+")) res = res.replaceAll("\\s+", "");
return res;
}
}
|