Class Compiler
java.lang.Object
org.apache.jasper.compiler.Compiler
- Direct Known Subclasses:
AntCompiler, JavaCompiler, JDTCompiler
Main JSP compiler class. This class uses Ant for compiling.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected JspCompilationContextThe JSP compilation context.protected ErrorDispatcherThe error dispatcher.protected JspServletWrapperThe JSP servlet wrapper.protected OptionsThe compilation options.protected PageInfoThe page information.protected Node.NodesThe page nodes.protected TagFileProcessorThe tag file processor. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidcompile()Compile the jsp file from the current engine context.voidcompile(boolean compileClass) Compile the jsp file from the current engine context.voidcompile(boolean compileClass, boolean jspcMode) Compile the jsp file from the current engine context.protected abstract voidgenerateClass(Map<String, SmapStratum> smaps) Servlet compilation.protected Map<String, SmapStratum> Compile the jsp file into equivalent servlet in .java fileReturns the JSP compilation context.Returns the error dispatcher.Returns the page information.Returns the source map for the specified class.voidinit(JspCompilationContext ctxt, JspServletWrapper jsw) Initializes the compiler with the given compilation context and servlet wrapper.booleanThis is a protected method intended to be overridden by subclasses of Compiler.booleanisOutDated(boolean checkClass) Determine if a compilation is necessary by checking the time stamp of the JSP page with that of the corresponding .class or .java file.voidRemove generated class files.voidRemove generated files
-
Field Details
-
ctxt
The JSP compilation context. -
errDispatcher
The error dispatcher. -
pageInfo
The page information. -
jsw
The JSP servlet wrapper. -
tfp
The tag file processor. -
options
The compilation options. -
pageNodes
The page nodes.
-
-
Constructor Details
-
Compiler
public Compiler()Default constructor for Compiler.
-
-
Method Details
-
init
Initializes the compiler with the given compilation context and servlet wrapper.- Parameters:
ctxt- the JSP compilation contextjsw- the JSP servlet wrapper
-
getSmap
Returns the source map for the specified class.- Parameters:
className- the class name- Returns:
- the source map, or
nullif not available
-
generateJava
Compile the jsp file into equivalent servlet in .java file- Returns:
- A map of class names to JSR 045 source maps
- Throws:
Exception- Error generating Java source
-
generateClass
protected abstract void generateClass(Map<String, SmapStratum> smaps) throws FileNotFoundException, JasperException, Exception Servlet compilation. This compiles the generated sources into Servlets.- Parameters:
smaps- The source maps for the class(es) generated from the source file- Throws:
FileNotFoundException- Source files not foundJasperException- Compilation errorException- Some other error
-
compile
Compile the jsp file from the current engine context.- Throws:
FileNotFoundException- Source files not foundJasperException- Compilation errorException- Some other error
-
compile
Compile the jsp file from the current engine context. As a side effect, tag files that are referenced by this page are also compiled.- Parameters:
compileClass- If true, generate both .java and .class file If false, generate only .java file- Throws:
FileNotFoundException- Source files not foundJasperException- Compilation errorException- Some other error
-
compile
public void compile(boolean compileClass, boolean jspcMode) throws FileNotFoundException, JasperException, Exception Compile the jsp file from the current engine context. As a side effect, tag files that are referenced by this page are also compiled.- Parameters:
compileClass- If true, generate both .java and .class file If false, generate only .java filejspcMode- true if invoked from JspC, false otherwise- Throws:
FileNotFoundException- Source files not foundJasperException- Compilation errorException- Some other error
-
isOutDated
public boolean isOutDated()This is a protected method intended to be overridden by subclasses of Compiler. This is used by the compile method to do all the compilation.- Returns:
trueif the source generation and compilation should occur
-
isOutDated
public boolean isOutDated(boolean checkClass) Determine if a compilation is necessary by checking the time stamp of the JSP page with that of the corresponding .class or .java file. If the page has dependencies, the check is also extended to its dependents, and so on. This method can be overridden by a subclasses of Compiler.- Parameters:
checkClass- If true, check against .class file, if false, check against .java file.- Returns:
trueif the source generation and compilation should occur
-
getErrorDispatcher
Returns the error dispatcher.- Returns:
- the error dispatcher.
-
getPageInfo
Returns the page information.- Returns:
- the info about the page under compilation
-
getCompilationContext
Returns the JSP compilation context.- Returns:
- the compilation context
-
removeGeneratedFiles
public void removeGeneratedFiles()Remove generated files -
removeGeneratedClassFiles
public void removeGeneratedClassFiles()Remove generated class files.
-