Package com.unboundid.ldap.sdk.persist
Class GenerateSchemaFromSource
- java.lang.Object
-
- com.unboundid.util.CommandLineTool
-
- com.unboundid.ldap.sdk.persist.GenerateSchemaFromSource
-
- All Implemented Interfaces:
java.io.Serializable
@Mutable @ThreadSafety(level=NOT_THREADSAFE) public final class GenerateSchemaFromSource extends CommandLineTool implements java.io.Serializable
This class provides a tool which can be used to generate LDAP attribute type and object class definitions which may be used to store objects created from a specified Java class. The given class must be included in the classpath of the JVM used to invoke the tool, and must be marked with theLDAPObjectannotation.- See Also:
- Serialized Form
-
-
Constructor Summary
Constructors Constructor Description GenerateSchemaFromSource(java.io.OutputStream outStream, java.io.OutputStream errStream)Creates a new instance of this tool.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddToolArguments(ArgumentParser parser)Adds the command-line arguments supported for use with this tool to the provided argument parser.booleandefaultsToInteractiveMode()Indicates whether this tool defaults to launching in interactive mode if the tool is invoked without any command-line arguments.ResultCodedoToolProcessing()Performs the core set of processing for this tool.java.util.LinkedHashMap<java.lang.String[],java.lang.String>getExampleUsages()Retrieves a set of information that may be used to generate example usage information.java.lang.StringgetToolDescription()Retrieves a human-readable description for this tool.java.lang.StringgetToolName()Retrieves the name of this tool.java.lang.StringgetToolVersion()Retrieves the version string for this tool.static voidmain(java.lang.String[] args)Parse the provided command line arguments and perform the appropriate processing.static ResultCodemain(java.lang.String[] args, java.io.OutputStream outStream, java.io.OutputStream errStream)Parse the provided command line arguments and perform the appropriate processing.booleansupportsInteractiveMode()Indicates whether this tool should provide support for an interactive mode, in which the tool offers a mode in which the arguments can be provided in a text-driven menu rather than requiring them to be given on the command line.booleansupportsPropertiesFile()Indicates whether this tool supports the use of a properties file for specifying default values for arguments that aren't specified on the command line.-
Methods inherited from class com.unboundid.util.CommandLineTool
addEnableSSLDebuggingArgument, createArgumentParser, doExtendedArgumentValidation, doShutdownHookProcessing, err, getAdditionalDescriptionParagraphs, getErr, getMaxTrailingArguments, getMinTrailingArguments, getOriginalErr, getOriginalOut, getOut, getPasswordFileReader, getToolCompletionMessage, getTrailingArgumentsPlaceholder, logToolInvocationByDefault, out, registerShutdownHook, requestToolArgumentsInteractively, runTool, supportsOutputFile, wrapErr, wrapOut
-
-
-
-
Constructor Detail
-
GenerateSchemaFromSource
public GenerateSchemaFromSource(@Nullable java.io.OutputStream outStream, @Nullable java.io.OutputStream errStream)
Creates a new instance of this tool.- Parameters:
outStream- The output stream to which standard out should be written. It may benullif output should be suppressed.errStream- The output stream to which standard error should be written. It may benullif error messages should be suppressed.
-
-
Method Detail
-
main
public static void main(@NotNull java.lang.String[] args)
Parse the provided command line arguments and perform the appropriate processing.- Parameters:
args- The command line arguments provided to this program.
-
main
@NotNull public static ResultCode main(@NotNull java.lang.String[] args, @Nullable java.io.OutputStream outStream, @Nullable java.io.OutputStream errStream)
Parse the provided command line arguments and perform the appropriate processing.- Parameters:
args- The command line arguments provided to this program.outStream- The output stream to which standard out should be written. It may benullif output should be suppressed.errStream- The output stream to which standard error should be written. It may benullif error messages should be suppressed.- Returns:
- A result code indicating whether the processing was successful.
-
getToolName
@NotNull public java.lang.String getToolName()
Retrieves the name of this tool. It should be the name of the command used to invoke this tool.- Specified by:
getToolNamein classCommandLineTool- Returns:
- The name for this tool.
-
getToolDescription
@NotNull public java.lang.String getToolDescription()
Retrieves a human-readable description for this tool. If the description should include multiple paragraphs, then this method should return the text for the first paragraph, and theCommandLineTool.getAdditionalDescriptionParagraphs()method should be used to return the text for the subsequent paragraphs.- Specified by:
getToolDescriptionin classCommandLineTool- Returns:
- A human-readable description for this tool.
-
getToolVersion
@NotNull public java.lang.String getToolVersion()
Retrieves the version string for this tool.- Overrides:
getToolVersionin classCommandLineTool- Returns:
- The version string for this tool.
-
supportsInteractiveMode
public boolean supportsInteractiveMode()
Indicates whether this tool should provide support for an interactive mode, in which the tool offers a mode in which the arguments can be provided in a text-driven menu rather than requiring them to be given on the command line. If interactive mode is supported, it may be invoked using the "--interactive" argument. Alternately, if interactive mode is supported anddefaultsToInteractiveMode()returnstrue, then interactive mode may be invoked by simply launching the tool without any arguments.- Overrides:
supportsInteractiveModein classCommandLineTool- Returns:
trueif this tool supports interactive mode, orfalseif not.
-
defaultsToInteractiveMode
public boolean defaultsToInteractiveMode()
Indicates whether this tool defaults to launching in interactive mode if the tool is invoked without any command-line arguments. This will only be used ifsupportsInteractiveMode()returnstrue.- Overrides:
defaultsToInteractiveModein classCommandLineTool- Returns:
trueif this tool defaults to using interactive mode if launched without any command-line arguments, orfalseif not.
-
supportsPropertiesFile
public boolean supportsPropertiesFile()
Indicates whether this tool supports the use of a properties file for specifying default values for arguments that aren't specified on the command line.- Overrides:
supportsPropertiesFilein classCommandLineTool- Returns:
trueif this tool supports the use of a properties file for specifying default values for arguments that aren't specified on the command line, orfalseif not.
-
addToolArguments
public void addToolArguments(@NotNull ArgumentParser parser) throws ArgumentException
Adds the command-line arguments supported for use with this tool to the provided argument parser. The tool may need to retain references to the arguments (and/or the argument parser, if trailing arguments are allowed) to it in order to obtain their values for use in later processing.- Specified by:
addToolArgumentsin classCommandLineTool- Parameters:
parser- The argument parser to which the arguments are to be added.- Throws:
ArgumentException- If a problem occurs while adding any of the tool-specific arguments to the provided argument parser.
-
doToolProcessing
@NotNull public ResultCode doToolProcessing()
Performs the core set of processing for this tool.- Specified by:
doToolProcessingin classCommandLineTool- Returns:
- A result code that indicates whether the processing completed successfully.
-
getExampleUsages
@NotNull public java.util.LinkedHashMap<java.lang.String[],java.lang.String> getExampleUsages()
Retrieves a set of information that may be used to generate example usage information. Each element in the returned map should consist of a map between an example set of arguments and a string that describes the behavior of the tool when invoked with that set of arguments.- Overrides:
getExampleUsagesin classCommandLineTool- Returns:
- A set of information that may be used to generate example usage
information. It may be
nullor empty if no example usage information is available.
-
-