use of com.google.template.soy.SoyFileSetParser.ParseResult in project closure-templates by google.
the class MsgHtmlTagNodeTest method parseMsgHtmlTagNode.
private static MsgHtmlTagNode parseMsgHtmlTagNode(String htmlTag, ErrorReporter errorReporter, String... params) {
Checkpoint cp = errorReporter.checkpoint();
ParseResult parse = SoyFileSetParserBuilder.forFileContents(Joiner.on('\n').join("{namespace ns}", "", "{template .t stricthtml=\"false\"}", Joiner.on('\n').join(params), "{msg desc=\"...\"}", htmlTag, "{/msg}", "{/template}")).errorReporter(errorReporter).parse();
if (errorReporter.errorsSince(cp)) {
return null;
}
MsgFallbackGroupNode child = (MsgFallbackGroupNode) parse.fileSet().getChild(0).getChild(0).getChild(0);
return (MsgHtmlTagNode) ((MsgPlaceholderNode) child.getChild(0).getChild(0)).getChild(0);
}
use of com.google.template.soy.SoyFileSetParser.ParseResult in project closure-templates by google.
the class SoyFileSet method compileToIncrementalDomSrcFiles.
/**
* Compiles this Soy file set into JS source code files and writes these JS files to disk.
*
* @param outputPathFormat The format string defining how to build the output file path
* corresponding to an input file path.
* @param jsSrcOptions The compilation options for the JS Src output target.
* @throws SoyCompilationException If compilation fails.
* @throws IOException If there is an error in opening/reading a message file or opening/writing
* an output JS file.
*/
void compileToIncrementalDomSrcFiles(String outputPathFormat, SoyIncrementalDomSrcOptions jsSrcOptions) throws IOException {
resetErrorReporter();
disallowExternalCalls();
ParseResult result = preprocessIncrementalDOMResults();
new IncrementalDomSrcMain(apiCallScopeProvider, typeRegistry).genJsFiles(result.fileSet(), result.registry(), jsSrcOptions, outputPathFormat, errorReporter);
throwIfErrorsPresent();
reportWarnings();
}
use of com.google.template.soy.SoyFileSetParser.ParseResult in project closure-templates by google.
the class SoyFileSet method generateParseInfo.
/**
* Generates Java classes containing parse info (param names, template names, meta info). There
* will be one Java class per Soy file.
*
* @param javaPackage The Java package for the generated classes.
* @param javaClassNameSource Source of the generated class names. Must be one of "filename",
* "namespace", or "generic".
* @return A map from generated file name (of the form "<*>SoyInfo.java") to generated file
* content.
* @throws SoyCompilationException If compilation fails.
*/
ImmutableMap<String, String> generateParseInfo(String javaPackage, String javaClassNameSource) {
resetErrorReporter();
// TODO(lukes): see if we can enforce that globals are provided at compile time here. given that
// types have to be, this should be possible. Currently it is disabled for backwards
// compatibility
// N.B. we do not run the optimizer here for 2 reasons:
// 1. it would just waste time, since we are not running code generation the optimization work
// doesn't help anything
// 2. it potentially removes metadata from the tree by precalculating expressions. For example,
// trivial print nodes are evaluated, which can remove globals from the tree, but the
// generator requires data about globals to generate accurate proto descriptors. Also, the
// ChangeCallsToPassAllData pass will change the params of templates.
ParseResult result = parse(passManagerBuilder(SyntaxVersion.V2_0).allowUnknownGlobals().optimize(false), typeRegistry, new PluginResolver(// we allow undefined plugins since they typically aren't provided :(
PluginResolver.Mode.ALLOW_UNDEFINED, printDirectives, soyFunctionMap, errorReporter));
throwIfErrorsPresent();
SoyFileSetNode soyTree = result.fileSet();
TemplateRegistry registry = result.registry();
// Do renaming of package-relative class names.
ImmutableMap<String, String> parseInfo = new GenerateParseInfoVisitor(javaPackage, javaClassNameSource, registry).exec(soyTree);
throwIfErrorsPresent();
reportWarnings();
return parseInfo;
}
use of com.google.template.soy.SoyFileSetParser.ParseResult in project closure-templates by google.
the class SoyFileSet method compileForServerRendering.
/**
* Runs common compiler logic shared by tofu and jbcsrc backends.
*/
private ServerCompilationPrimitives compileForServerRendering() {
ParseResult result = parse(SyntaxVersion.V2_0);
throwIfErrorsPresent();
SoyFileSetNode soyTree = result.fileSet();
TemplateRegistry registry = result.registry();
// which case it is pointless.
if (cache == null) {
new ClearSoyDocStringsVisitor().exec(soyTree);
}
throwIfErrorsPresent();
return new ServerCompilationPrimitives(registry, soyTree);
}
use of com.google.template.soy.SoyFileSetParser.ParseResult in project closure-templates by google.
the class SoyFileSet method compileToJsSrc.
/**
* Compiles this Soy file set into JS source code files and returns these JS files as a list of
* strings, one per file.
*
* @param jsSrcOptions The compilation options for the JS Src output target.
* @param msgBundle The bundle of translated messages, or null to use the messages from the Soy
* source.
* @return A list of strings where each string represents the JS source code that belongs in one
* JS file. The generated JS files correspond one-to-one to the original Soy source files.
* @throws SoyCompilationException If compilation fails.
*/
@SuppressWarnings("deprecation")
public List<String> compileToJsSrc(SoyJsSrcOptions jsSrcOptions, @Nullable SoyMsgBundle msgBundle) {
ParseResult result = preprocessJsSrcResults(jsSrcOptions);
TemplateRegistry registry = result.registry();
SoyFileSetNode fileSet = result.fileSet();
List<String> generatedSrcs = new JsSrcMain(apiCallScopeProvider, typeRegistry).genJsSrc(fileSet, registry, jsSrcOptions, msgBundle, errorReporter);
throwIfErrorsPresent();
reportWarnings();
return generatedSrcs;
}
Aggregations