Package org.apache.axis.wsdl.toJava
Class JavaGeneratorFactory
java.lang.Object
org.apache.axis.wsdl.toJava.JavaGeneratorFactory
- All Implemented Interfaces:
GeneratorFactory
This is Wsdl2java's implementation of the GeneratorFactory
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected JavaGeneratorFactory.Writers
Return Wsdl2java's JavaBindingWriter object.static String
Field COMPLEX_TYPE_FAULTprotected Emitter
Field emitterstatic String
Field EXCEPTION_CLASS_NAMEstatic String
Field EXCEPTION_DATA_TYPEprotected JavaGeneratorFactory.Writers
Return Wsdl2java's JavaServiceWriter object.protected SymbolTable
Field symbolTable -
Constructor Summary
ConstructorsConstructorDescriptionDefault constructor.JavaGeneratorFactory
(Emitter emitter) Constructor JavaGeneratorFactory -
Method Summary
Modifier and TypeMethodDescriptionprotected void
Method addBindingGeneratorsprotected void
Method addDefinitionGeneratorsvoid
addGenerator
(Class wsdlClass, Class generator) Method addGeneratorprotected void
These addXXXGenerators are called by the constructor.protected void
Method addPortTypeGeneratorsprotected void
Method addServiceGeneratorsprotected void
Method addTypeGeneratorsprotected void
constructSignatures
(SymbolTable symbolTable) Method constructSignaturesprotected void
determineIfHoldersNeeded
(SymbolTable symbolTable) Find all inout/out parameters and add a flag to the Type of that parameter saying a holder is needed.protected void
determineInterfaceNames
(SymbolTable symbolTable) Method determineInterfaceNamesvoid
generatorPass
(javax.wsdl.Definition def, SymbolTable symbolTable) Do the Wsdl2java generator pass: - resolve name clashes - construct signaturesMethod getBaseTypeMappingprotected String
getExceptionJavaNameHook
(QName qname) getGenerator
(javax.wsdl.Binding binding, SymbolTable symbolTable) Method getGeneratorgetGenerator
(javax.wsdl.Definition definition, SymbolTable symbolTable) Method getGeneratorgetGenerator
(javax.wsdl.Message message, SymbolTable symbolTable) Method getGeneratorgetGenerator
(javax.wsdl.PortType portType, SymbolTable symbolTable) Method getGeneratorgetGenerator
(javax.wsdl.Service service, SymbolTable symbolTable) Method getGeneratorgetGenerator
(TypeEntry type, SymbolTable symbolTable) Method getGeneratorprotected String
getOperationJavaNameHook
(BindingEntry bEntry, String wsdlOpName) protected String
getParameterTypeJavaNameHook
(BindingEntry bEntry, String wsdlOpName, int pos) protected String
getPortJavaNameHook
(String portName) protected String
getReturnTypeJavaNameHook
(BindingEntry bEntry, String wsdlOpName) protected String
getServiceEndpointInterfaceJavaNameHook
(PortTypeEntry ptEntry, BindingEntry bEntry) protected String
protected void
ignoreNonSOAPBindings
(SymbolTable symbolTable) If a binding's type is not TYPE_SOAP, then we don't use that binding or that binding's portType.protected boolean
Determines whether the QName supplied should be generated by comparing the namespace for the QName against the included and excluded names.protected void
javifyNames
(SymbolTable symbolTable) Fill in the names of each SymTabEntry with the javaified name.protected int
javifyTypeEntryName
(SymbolTable symbolTable, TypeEntry entry, HashMap anonQNames, int uniqueNum) Refactored to call recursively for JAX-RPC 1.1 spec 4.2.5.protected void
resolveNameClashes
(SymbolTable symbolTable) Messages, PortTypes, Bindings, and Services can share the same name.protected void
The --all flag is set on the command line (or generateAll(true) is called on WSDL2Java).void
Method setBaseTypeMappingvoid
setEmitter
(Emitter emitter) Method setEmitter
-
Field Details
-
emitter
Field emitter -
symbolTable
Field symbolTable -
COMPLEX_TYPE_FAULT
Field COMPLEX_TYPE_FAULT -
EXCEPTION_CLASS_NAME
Field EXCEPTION_CLASS_NAME -
EXCEPTION_DATA_TYPE
Field EXCEPTION_DATA_TYPE -
bindingWriters
Return Wsdl2java's JavaBindingWriter object. -
serviceWriters
Return Wsdl2java's JavaServiceWriter object.
-
-
Constructor Details
-
JavaGeneratorFactory
public JavaGeneratorFactory()Default constructor. Note that this class is unusable until setEmitter is called. -
JavaGeneratorFactory
Constructor JavaGeneratorFactory- Parameters:
emitter
-
-
-
Method Details
-
setEmitter
Method setEmitter- Parameters:
emitter
-
-
addMessageGenerators
protected void addMessageGenerators()These addXXXGenerators are called by the constructor. If an extender of this factory wants to CHANGE the set of generators that are called per WSDL construct, they should override these addXXXGenerators methods. If all an extender wants to do is ADD a generator, then the extension should simply call addGenerator. (NOTE: It doesn't quite work this way, yet. Only the Definition generators fit this model at this point in time.) -
addPortTypeGenerators
protected void addPortTypeGenerators()Method addPortTypeGenerators -
addBindingGenerators
protected void addBindingGenerators()Method addBindingGenerators -
addServiceGenerators
protected void addServiceGenerators()Method addServiceGenerators -
addTypeGenerators
protected void addTypeGenerators()Method addTypeGenerators -
addDefinitionGenerators
protected void addDefinitionGenerators()Method addDefinitionGenerators -
generatorPass
Do the Wsdl2java generator pass: - resolve name clashes - construct signatures- Specified by:
generatorPass
in interfaceGeneratorFactory
- Parameters:
def
-symbolTable
-
-
getGenerator
Method getGenerator- Specified by:
getGenerator
in interfaceGeneratorFactory
- Parameters:
message
-symbolTable
-- Returns:
-
getGenerator
Method getGenerator- Specified by:
getGenerator
in interfaceGeneratorFactory
- Parameters:
portType
-symbolTable
-- Returns:
-
getGenerator
Method getGenerator- Specified by:
getGenerator
in interfaceGeneratorFactory
- Parameters:
binding
-symbolTable
-- Returns:
-
getGenerator
Method getGenerator- Specified by:
getGenerator
in interfaceGeneratorFactory
- Parameters:
service
-symbolTable
-- Returns:
-
getGenerator
Method getGenerator- Specified by:
getGenerator
in interfaceGeneratorFactory
- Parameters:
type
-symbolTable
-- Returns:
-
getGenerator
Method getGenerator- Specified by:
getGenerator
in interfaceGeneratorFactory
- Parameters:
definition
-symbolTable
-- Returns:
-
addGenerator
Method addGenerator- Parameters:
wsdlClass
-generator
-
-
javifyNames
Fill in the names of each SymTabEntry with the javaified name. Note: This method also ensures that anonymous types are given unique java type names.- Parameters:
symbolTable
-
-
javifyTypeEntryName
protected int javifyTypeEntryName(SymbolTable symbolTable, TypeEntry entry, HashMap anonQNames, int uniqueNum) Refactored to call recursively for JAX-RPC 1.1 spec 4.2.5. -
getExceptionJavaNameHook
-
determineInterfaceNames
Method determineInterfaceNames- Parameters:
symbolTable
-
-
getServiceEndpointInterfaceJavaNameHook
protected String getServiceEndpointInterfaceJavaNameHook(PortTypeEntry ptEntry, BindingEntry bEntry) -
getServiceInterfaceJavaNameHook
-
getPortJavaNameHook
-
resolveNameClashes
Messages, PortTypes, Bindings, and Services can share the same name. If they do in this Definition, force their names to be suffixed with _PortType and _Service, respectively.- Parameters:
symbolTable
-
-
setAllReferencesToTrue
protected void setAllReferencesToTrue()The --all flag is set on the command line (or generateAll(true) is called on WSDL2Java). Set all symbols as referenced (except nonSOAP bindings which we don't know how to deal with). -
ignoreNonSOAPBindings
If a binding's type is not TYPE_SOAP, then we don't use that binding or that binding's portType.- Parameters:
symbolTable
-
-
constructSignatures
Method constructSignatures- Parameters:
symbolTable
-
-
getOperationJavaNameHook
-
getReturnTypeJavaNameHook
-
getParameterTypeJavaNameHook
-
determineIfHoldersNeeded
Find all inout/out parameters and add a flag to the Type of that parameter saying a holder is needed.- Parameters:
symbolTable
-
-
setBaseTypeMapping
Method setBaseTypeMapping- Specified by:
setBaseTypeMapping
in interfaceGeneratorFactory
- Parameters:
btm
-
-
getBaseTypeMapping
Method getBaseTypeMapping- Specified by:
getBaseTypeMapping
in interfaceGeneratorFactory
- Returns:
-
include
Determines whether the QName supplied should be generated by comparing the namespace for the QName against the included and excluded names.- if both the includes and excludes are both empty, the element is generated
- if the namespace is in the includes, the element is generated
- if the namespace is not in the excludes and the includes are empty, the element will be generated.
- if the namespace is only in the excludes, the element is not generated
- if the namespace is not in the includes and the includes are not empty, the element is not generated
- Parameters:
qName
-- Returns:
-