| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235 | 
							- /*=============================================================================
 
-   Library: CTK
 
-   Copyright (c) 2010 Brigham and Women's Hospital (BWH) All Rights Reserved.
 
-   Licensed under the Apache License, Version 2.0 (the "License");
 
-   you may not use this file except in compliance with the License.
 
-   You may obtain a copy of the License at
 
-     http://www.apache.org/licenses/LICENSE-2.0
 
-   Unless required by applicable law or agreed to in writing, software
 
-   distributed under the License is distributed on an "AS IS" BASIS,
 
-   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
-   See the License for the specific language governing permissions and
 
-   limitations under the License.
 
- =============================================================================*/
 
- #ifndef __ctkCmdLineModuleParameter_h
 
- #define __ctkCmdLineModuleParameter_h
 
- #include "ctkCommandLineModulesCoreExport.h"
 
- #include <QSharedDataPointer>
 
- class QTextStream;
 
- class QStringList;
 
- struct ctkCmdLineModuleParameterPrivate;
 
- /** 
 
-  * \class ctkCmdLineModuleParameter
 
-  * \brief Single parameter to a module, like a threshold of a filter.
 
-  * \ingroup CommandLineModulesCore_API
 
-  *
 
-  *
 
-  * ctkCmdLineModuleParameter describes a single parameter for a
 
-  * module. Information on the parameter type, name, flag, label,
 
-  * description, channel, index, default, and constraints can be
 
-  * retrieved.
 
-  */
 
- class CTK_CMDLINEMODULECORE_EXPORT ctkCmdLineModuleParameter
 
- {
 
- public:
 
-   ctkCmdLineModuleParameter(const ctkCmdLineModuleParameter& other);
 
-   ~ctkCmdLineModuleParameter();
 
-   ctkCmdLineModuleParameter& operator=(const ctkCmdLineModuleParameter& other);
 
-   /**
 
-    * @return The tag name, e.g. "integer" or "image".
 
-    */
 
-   QString tag() const;
 
-   /**
 
-    * @return The type of the parameter, e.g. "scalar" or "vector" for image parameters.
 
-    */
 
-   QString type() const;
 
-   /**
 
-    * @return <code>true</code> if the parameter is declared hidden, <code>false</code>
 
-    *         otherwise.
 
-    */
 
-   bool hidden() const;
 
-   /**
 
-    * Simple return types are parameters on the output channel with no
 
-    * flags and with a dummy index of 1000.
 
-    *
 
-    * @return <code>true</code> if the parameter is a simple return type,
 
-    *         <code>false</code> otherwise.
 
-    */
 
-   bool isReturnParameter() const;
 
-   /**
 
-    * @return <code>true</code> if the parameter has a flag (long or short),
 
-    *         <code>false</code> otherwise.
 
-    */
 
-   bool isFlagParameter() const;
 
-   /**
 
-    * @return <code>true</code> if the parameter has an index, <code>false</code> otherwise.
 
-    */
 
-   bool isIndexParameter() const;
 
-   /**
 
-    * @return The parameter name.
 
-    */
 
-   QString name() const;
 
-   /**
 
-    * @return The (possibly empty) long flag for this parameter.
 
-    */
 
-   QString longFlag() const;
 
-   /**
 
-    * @return A (possibly empty) comma separated string of aliases for the long flag.
 
-    */
 
-   QString longFlagAliasesAsString() const;
 
-   /**
 
-    * @return A (possibly empty) list of long flag aliases.
 
-    */
 
-   QStringList longFlagAliases() const;
 
-   /**
 
-    * @return A (possibly empty) comma separated string of deprecated long flag aliases.
 
-    */
 
-   QString deprecatedLongFlagAliasesAsString() const;
 
-   /**
 
-    * @return A (possibly empty) list of deprectated long flag aliases.
 
-    */
 
-   QStringList deprecatedLongFlagAliases() const;
 
-   /**
 
-    * @return The human-readable name of this parameter.
 
-    */
 
-   QString label() const;
 
-   /**
 
-    * @return <code>true</code> if this parameter imposes constraints on the set of allowed values.
 
-    */
 
-   bool constraints() const;
 
-   /**
 
-    * @return The maximum value constraint.
 
-    */
 
-   QString maximum() const;
 
-   /**
 
-    * @return The minimum value constraint.
 
-    */
 
-   QString minimum() const;
 
-   /**
 
-    * @return The value step size constraint.
 
-    */
 
-   QString step() const;
 
-   /**
 
-    * @return A longer description of this parameter.
 
-    */
 
-   QString description() const;
 
-   /**
 
-    * @return The string "input" for input parameters and "output" for output parameters.
 
-    */
 
-   QString channel() const;
 
-   /**
 
-    * @return The parameter index or <code>-1</code> if this is not an indexed parameter.
 
-    * @sa flag()
 
-    * @sa longFlag()
 
-    */
 
-   int index() const;
 
-   /**
 
-    * @return The default value.
 
-    */
 
-   QString defaultValue() const;
 
-   /**
 
-    * @return The (possibly empty) flag for this parameter.
 
-    * @sa index()
 
-    */
 
-   QString flag() const;
 
-   /**
 
-    * @return A (possibly empty) comma separated string of flag aliases.
 
-    */
 
-   QString flagAliasesAsString() const;
 
-   /**
 
-    * @return A (possibly empty) list of flag aliases.
 
-    */
 
-   QStringList flagAliases() const;
 
-   /**
 
-    * @return A (possibly empty) comma separated string of deprecated flag aliases.
 
-    */
 
-   QString deprecatedFlagAliasesAsString() const;
 
-   /**
 
-    * @return A (possibly empty) list of deprecated flag aliases.
 
-    */
 
-   QStringList deprecatedFlagAliases() const;
 
-   /**
 
-    * @return <code>true</code> if this parameter can appear multiple time in the argument list,
 
-    *         <code>false</code> otherwise.
 
-    */
 
-   bool multiple() const;
 
-   /**
 
-    * @return A (possibly empty) comma separated list of file extensions (e.g. "*.nrrd,*.mhd") for
 
-    *         the "file", "image", or "geometry" parameter tags.
 
-    */
 
-   QString fileExtensionsAsString() const;
 
-   /**
 
-    * @return A (possibly empty) list of file extensions.
 
-    * @sa fileExtensionsAsString()
 
-    */
 
-   QStringList fileExtensions() const;
 
-   /**
 
-    * @return The coordinate system (either "lps", "ras", oder "ijk") for the "point" or "region"
 
-    *         parameter tags.
 
-    */
 
-   QString coordinateSystem() const;
 
-   /**
 
-    * @return The list of valid elements for enumeration parameters (e.g. "string-enumeration").
 
-    */
 
-   QStringList elements() const;
 
- private:
 
-   friend struct ctkCmdLineModuleParameterParser;
 
-   friend class ctkCmdLineModuleXmlParser;
 
-   ctkCmdLineModuleParameter();
 
-   QSharedDataPointer<ctkCmdLineModuleParameterPrivate> d;
 
- };
 
- CTK_CMDLINEMODULECORE_EXPORT QTextStream& operator<<(QTextStream& os, const ctkCmdLineModuleParameter& parameter);
 
- #endif
 
 
  |