Package com.chemaxon.calculations.cli
Class CalculatorPluginOutput<P extends CalculatorPlugin>
java.lang.Object
chemaxon.marvin.plugin.CalculatorPluginService<P>
com.chemaxon.calculations.cli.CalculatorPluginOutput<P>
- All Implemented Interfaces:
- CalculatorResultAccess
@PublicApi
public class CalculatorPluginOutput<P extends CalculatorPlugin>
extends CalculatorPluginService<P>
implements CalculatorResultAccess
Class providing plugin output in table form.
 The default implementation provides the following output:
 
 
 where 
| id | <type1> | <type2> | <type3invalid input: '>' | ... | 
| <id1> | <result11> | <result12> | <result13> | ... | 
| <id2> | <result21> | <result22> | <result23> | ... | 
| ... | ... | ... | ... | ... | 
type1, type2, ... are the result types,
 id1, id2, ... are the molecule ID-s fetched from the given ID tag of the
 input SDF file or molecule indices if no such tag is given,
 the resultij is the result string for the i-th molecule and the j-th result type.
 Other output formats can be implemented by subclassing this class and returning the class name in
 the plugin-specific implementation of chemaxon.plugin.CalculatorPlugin.getOutputClassName().- Since:
- Marvin 3.0
- 
Field SummaryFields
- 
Constructor SummaryConstructorsConstructorDescriptionDefault constructor.Constructor that sets plugin.
- 
Method SummaryModifier and TypeMethodDescriptionvoidclose()Closes the output.voidclose(int opts) Closes the output.getCachedResults(Molecule target, boolean stringResult) Returns cached results, separated from the plugin object, so that no further enqueries needed to the plugin to get the result.Returns the table header.final PReturns the calculator plugin object.Returns the plugin parameter table (this should be set in the plugin).Returns the calculation remark.Returns the result string for the given molecule.intReturns the domain for the first result type.final StringReturns the plugin calculation error message, error or warning.getResultMolecule(Molecule target) Returns the decorated result molecule for the given target molecule.Molecule[]getResultMolecules(Molecule target) Returns the result molecules for the given target molecule.protected StringgetResults(Object type) Returns result items for the given result type.doublegetSpecResult(Molecule target, String arg) Deprecated, for removal: This API element is subject to removal in a future version.final ThrowableReturns the throwable object.booleanReturnstrueif molecule output.booleanisOK()Returnstrueif the calculation has run without error.booleanReturnstrueif stream output.voidsetOutputParameters(Object[] types) Prepares the output based on the result type string.voidSets the output stream.voidsetParameters(Properties params) Sets the parameter table.final voidsetPlugin(CalculatorPlugin plugin) Deprecated, for removal: This API element is subject to removal in a future version.usesetPluginChecked(CalculatorPlugin)insteadfinal voidsetPluginChecked(P plugin) Sets the calculator plugin object.voidsetSeparator(String separator) Sets the separator string.final voidsetThrowable(Throwable throwable) Sets the throwable object.
- 
Field Details- 
pluginThe CalculatorPlugin object.
- 
paramsThe plugin parameter table.
- 
separatorThe separator string separating the results for different result types.
 
- 
- 
Constructor Details- 
CalculatorPluginOutputpublic CalculatorPluginOutput()Default constructor.
- 
CalculatorPluginOutputConstructor that sets plugin.- Parameters:
- plugin- is the plugin
 
 
- 
- 
Method Details- 
setPlugin@Deprecated(forRemoval=true) @SubjectToRemoval(date=JUL_01_2025) public final void setPlugin(CalculatorPlugin plugin) Deprecated, for removal: This API element is subject to removal in a future version.usesetPluginChecked(CalculatorPlugin)insteadSets the calculator plugin object.- Parameters:
- plugin- is the CalculatorPlugin object
 
- 
setPluginCheckedSets the calculator plugin object.- Parameters:
- plugin- is the CalculatorPlugin object
 
- 
getPluginDescription copied from class:CalculatorPluginServiceReturns the calculator plugin object.- Specified by:
- getPluginin class- CalculatorPluginService<P extends CalculatorPlugin>
- Returns:
- the calculator plugin object
 
- 
setThrowableSets the throwable object.- Parameters:
- throwable- is the CalculatorPlugin object
 
- 
getThrowableReturns the throwable object.- Specified by:
- getThrowablein interface- CalculatorResultAccess
- Returns:
- the throwable plugin object
 
- 
setSeparatorSets the separator string.- Parameters:
- separator- is the separator string
 
- 
setParametersSets the parameter table.- Parameters:
- params- is the parameter table
- Throws:
- PluginException- on error
 
- 
getPluginParametersReturns the plugin parameter table (this should be set in the plugin). The default implementation returns the given parameter table itself.- Returns:
- the original parameter table if it is the same, a new table with the plugin params otherwise
- Throws:
- PluginException- on error
 
- 
setOutputParametersPrepares the output based on the result type string. The default implementation does nothing.- Parameters:
- types- the result types
- Throws:
- PluginException- on error
 
- 
isMolecularpublic boolean isMolecular()Returnstrueif molecule output. The default implementation returnsfalse.- Returns:
- trueif molecule output
 
- 
isStreamOutputpublic boolean isStreamOutput()Returnstrueif stream output. The default implementation returnsfalse.- Returns:
- trueif stream output
 
- 
setOutputStreamSets the output stream. Used for molecule output. The default implementation does nothing.- Parameters:
- os- the output stream
- Throws:
- IOException
 
- 
closeCloses the output. The default implementation callsclose(int)withMolExporter.C_CLOSE_STREAMparameter.- Throws:
- IOException
 
- 
closeCloses the output. The default implementation does nothing.- Parameters:
- opts- closing options,- MolExporter.C_CLOSE_STREAMor- MolExporter.C_FLUSH_STREAM
- Throws:
- IOException
- Since:
- Marvin 5.1.1
 
- 
getCachedResultspublic final CalculatorPluginCachedResults getCachedResults(Molecule target, boolean stringResult) throws PluginException Returns cached results, separated from the plugin object, so that no further enqueries needed to the plugin to get the result.- Parameters:
- target- the target molecule
- stringResult- is- trueif string result is needed,- falseif decorated molecule is needed
- Returns:
- the cached results
- Throws:
- PluginException
- Since:
- Marvin 5.2
 
- 
getResultMessageReturns the plugin calculation error message, error or warning.- Specified by:
- getResultMessagein interface- CalculatorResultAccess
- Returns:
- the plugin calculation error message
 
- 
getRemarkReturns the calculation remark.- Specified by:
- getRemarkin interface- CalculatorResultAccess
- Returns:
- the calculation remark
 
- 
isOKpublic boolean isOK()Returnstrueif the calculation has run without error.- Specified by:
- isOKin interface- CalculatorResultAccess
- Returns:
- trueif the calculation has run without error
 
- 
getHeaderReturns the table header. The default implementation returns "id" and the result types.- Specified by:
- getHeaderin interface- CalculatorResultAccess
- Returns:
- the table header
 
- 
getResultReturns the result string for the given molecule. The default implementation returns the result strings corresponding to the result types.- Specified by:
- getResultin interface- CalculatorResultAccess
- Parameters:
- target- is the target molecule
- Returns:
- the result row
- Throws:
- PluginException- on error
 
- 
getResultsReturns result items for the given result type.- Parameters:
- type- is the result type
- Returns:
- result items separated by ';'
- Throws:
- PluginException- on error
 
- 
getResultMoleculeReturns the decorated result molecule for the given target molecule. Used in case of MRV output (-M, --mrv-output).- Specified by:
- getResultMoleculein interface- CalculatorResultAccess
- Parameters:
- target- is the target molecule
- Returns:
- the result molecule
- Throws:
- PluginException- on error
 
- 
getResultMoleculesReturns the result molecules for the given target molecule. The default implementation returnsnull.- Specified by:
- getResultMoleculesin interface- CalculatorResultAccess
- Parameters:
- target- is the target molecules
- Returns:
- the result molecules
- Throws:
- PluginException- on error
 
- 
getResultDomainpublic int getResultDomain()Returns the domain for the first result type.- Returns:
- the domain for the first result type:
         CalculatorPlugin.ATOM,CalculatorPlugin.MOLECULEorCalculatorPlugin.MOLECULES
 
- 
getSpecResult@Deprecated(forRemoval=true) @SubjectToRemoval(date=JUL_01_2025) public double getSpecResult(Molecule target, String arg) throws PluginException Deprecated, for removal: This API element is subject to removal in a future version.This method depends on the now deprecatedCalculatorPlugin.getResult(Object, String)method, so this is deprecated as well and will be removed.Returns a specific plugin result corresponding to the given molecule and argument string. The default implementation returns the result value returned byCalculatorPlugin.getResult(int index)(converted todouble) with index given in the argument string: the argument string format is<result index>.- Parameters:
- target- is the target molecule
- arg- is the argument string
- Returns:
- the queried plugin result
- Throws:
- PluginException- in case of plugin calculation error
 
 
- 
CalculatorPlugin.getResult(Object, String)method, so this is deprecated as well and will be removed.