xref: /petsc/include/petscoptions.h (revision 080f0011773203ad8803837596fa1e3f25ef47ae)
1f26ada1bSBarry Smith /*
237f753daSBarry Smith    Routines to determine options set in the options database.
3f26ada1bSBarry Smith */
426bd1501SBarry Smith #if !defined(PETSCOPTIONS_H)
526bd1501SBarry Smith #define PETSCOPTIONS_H
62c8e378dSBarry Smith #include <petscsys.h>
7c619b03eSJed Brown #include <petscviewertypes.h>
83a3b2205SBarry Smith 
9c5929fdfSBarry Smith typedef struct _n_PetscOptions* PetscOptions;
10c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsCreate(PetscOptions*);
11b4205f0bSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsPush(PetscOptions);
12b4205f0bSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsPop(void);
13c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsDestroy(PetscOptions*);
142d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsCreateDefault(void);
152d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsDestroyDefault(void);
16c5929fdfSBarry Smith 
172d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsHasHelp(PetscOptions,PetscBool*);
18c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsHasName(PetscOptions,const char[],const char[],PetscBool*);
19c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetBool(PetscOptions,const char[],const char [],PetscBool*,PetscBool*);
202d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsGetInt(PetscOptions,const char[],const char [],PetscInt*,PetscBool*);
212d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsGetEnum(PetscOptions,const char[],const char[],const char*const*,PetscEnum*,PetscBool*);
222d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsGetEList(PetscOptions,const char[],const char[],const char*const*,PetscInt,PetscInt*,PetscBool*);
23c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetReal(PetscOptions,const char[],const char[],PetscReal*,PetscBool*);
24c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetScalar(PetscOptions,const char[],const char[],PetscScalar*,PetscBool*);
252d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsGetString(PetscOptions,const char[],const char[],char[],size_t,PetscBool*);
262d747510SLisandro Dalcin 
272d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsGetBoolArray(PetscOptions,const char[],const char[],PetscBool [],PetscInt*,PetscBool*);
282d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsGetEnumArray(PetscOptions,const char[],const char[],const char*const*,PetscEnum*,PetscInt*,PetscBool*);
29c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetIntArray(PetscOptions,const char[],const char[],PetscInt[],PetscInt*,PetscBool*);
30c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetRealArray(PetscOptions,const char[],const char[],PetscReal[],PetscInt*,PetscBool*);
31c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetScalarArray(PetscOptions,const char[],const char[],PetscScalar[],PetscInt*,PetscBool*);
32c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetStringArray(PetscOptions,const char[],const char[],char*[],PetscInt*,PetscBool*);
333a3b2205SBarry Smith 
342d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsValidKey(const char[],PetscBool*);
35c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsSetAlias(PetscOptions,const char[],const char[]);
36c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsSetValue(PetscOptions,const char[],const char[]);
37c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsClearValue(PetscOptions,const char[]);
382d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsFindPair(PetscOptions,const char[],const char[],const char*[],PetscBool*);
393a3b2205SBarry Smith 
402d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsGetAll(PetscOptions,char*[]);
41c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsAllUsed(PetscOptions,PetscInt*);
422d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsUsed(PetscOptions,const char[],PetscBool*);
43c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsLeft(PetscOptions);
441ab23d95SFande Kong PETSC_EXTERN PetscErrorCode PetscOptionsLeftGet(PetscOptions,PetscInt*,char***,char***);
455b191818SFande Kong PETSC_EXTERN PetscErrorCode PetscOptionsLeftRestore(PetscOptions,PetscInt*,char***,char***);
46c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsView(PetscOptions,PetscViewer);
474b0e389bSBarry Smith 
482d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsReject(PetscOptions,const char[],const char[],const char[]);
49c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsInsert(PetscOptions,int*,char***,const char[]);
50c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsInsertFile(MPI_Comm,PetscOptions,const char[],PetscBool );
513bcbd388SSean Farley #if defined(PETSC_HAVE_YAML)
52826011d7SBlaise Bourdin PETSC_EXTERN PetscErrorCode PetscOptionsInsertFileYAML(MPI_Comm,const char[],PetscBool);
533bcbd388SSean Farley #endif
54c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsInsertString(PetscOptions,const char[]);
55*080f0011SToby Isaac #if defined(PETSC_HAVE_YAML)
56*080f0011SToby Isaac PETSC_EXTERN PetscErrorCode PetscOptionsInsertStringYAML(PetscOptions,const char[]);
57*080f0011SToby Isaac #endif
58c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsClear(PetscOptions);
59c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsPrefixPush(PetscOptions,const char[]);
60c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsPrefixPop(PetscOptions);
615d0dffe5SBarry Smith 
62014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetenv(MPI_Comm,const char[],char[],size_t,PetscBool*);
632d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsStringToBool(const char[],PetscBool*);
64014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsStringToInt(const char[],PetscInt*);
65014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsStringToReal(const char[],PetscReal*);
662d747510SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscOptionsStringToScalar(const char[],PetscScalar*);
672e8a6d31SBarry Smith 
68014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsMonitorSet(PetscErrorCode (*)(const char[], const char[], void*), void*, PetscErrorCode (*)(void**));
69014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsMonitorCancel(void);
70014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsMonitorDefault(const char[], const char[], void*);
71081c24baSBoyana Norris 
7284761bfeSJed Brown PETSC_EXTERN PetscErrorCode PetscObjectSetOptions(PetscObject,PetscOptions);
7384761bfeSJed Brown PETSC_EXTERN PetscErrorCode PetscObjectGetOptions(PetscObject,PetscOptions*);
7484761bfeSJed Brown 
75014dd563SJed Brown PETSC_EXTERN PetscBool PetscOptionsPublish;
76e55864a3SBarry Smith 
77e55864a3SBarry Smith 
78e55864a3SBarry Smith /*
79e55864a3SBarry Smith     See manual page for PetscOptionsBegin()
804416b707SBarry Smith 
814416b707SBarry Smith     PetscOptionsItem and PetscOptionsItems are a single option (such as ksp_type) and a collection of such single
824416b707SBarry Smith   options being handled with a PetscOptionsBegin/End()
834416b707SBarry Smith 
84e55864a3SBarry Smith */
85050cccc3SHong Zhang typedef enum {OPTION_INT,OPTION_BOOL,OPTION_REAL,OPTION_FLIST,OPTION_STRING,OPTION_REAL_ARRAY,OPTION_SCALAR_ARRAY,OPTION_HEAD,OPTION_INT_ARRAY,OPTION_ELIST,OPTION_BOOL_ARRAY,OPTION_STRING_ARRAY} PetscOptionType;
864416b707SBarry Smith typedef struct _n_PetscOptionItem* PetscOptionItem;
874416b707SBarry Smith struct _n_PetscOptionItem{
88e55864a3SBarry Smith   char              *option;
89e55864a3SBarry Smith   char              *text;
90e55864a3SBarry Smith   void              *data;         /* used to hold the default value and then any value it is changed to by GUI */
91e55864a3SBarry Smith   PetscFunctionList flist;         /* used for available values for PetscOptionsList() */
92e55864a3SBarry Smith   const char *const *list;        /* used for available values for PetscOptionsEList() */
93e55864a3SBarry Smith   char              nlist;         /* number of entries in list */
94e55864a3SBarry Smith   char              *man;
95e55864a3SBarry Smith   size_t            arraylength;   /* number of entries in data in the case that it is an array (of PetscInt etc) */
96e55864a3SBarry Smith   PetscBool         set;           /* the user has changed this value in the GUI */
97e55864a3SBarry Smith   PetscOptionType   type;
984416b707SBarry Smith   PetscOptionItem   next;
99e55864a3SBarry Smith   char              *pman;
100e55864a3SBarry Smith   void              *edata;
101e55864a3SBarry Smith };
102e55864a3SBarry Smith 
1034416b707SBarry Smith typedef struct _p_PetscOptionItems {
104e55864a3SBarry Smith   PetscInt         count;
1054416b707SBarry Smith   PetscOptionItem  next;
106e55864a3SBarry Smith   char             *prefix,*pprefix;
107e55864a3SBarry Smith   char             *title;
108e55864a3SBarry Smith   MPI_Comm         comm;
109e55864a3SBarry Smith   PetscBool        printhelp,changedmethod,alreadyprinted;
110e55864a3SBarry Smith   PetscObject      object;
111c5929fdfSBarry Smith   PetscOptions     options;
1124416b707SBarry Smith } PetscOptionItems;
11330de9b25SBarry Smith 
1148c6bf8b2SFande Kong 
11530de9b25SBarry Smith /*MC
11630de9b25SBarry Smith     PetscOptionsBegin - Begins a set of queries on the options database that are related and should be
1171957e957SBarry Smith      displayed on the same window of a GUI that allows the user to set the options interactively. Often one should
1181957e957SBarry Smith      use PetscObjectOptionsBegin() rather than this call.
11930de9b25SBarry Smith 
120f2ba6396SBarry Smith    Synopsis:
121aaa7dc30SBarry Smith     #include <petscoptions.h>
122f2ba6396SBarry Smith     PetscErrorCode PetscOptionsBegin(MPI_Comm comm,const char prefix[],const char title[],const char mansec[])
12330de9b25SBarry Smith 
124fb455bf4SPatrick Sanan     Collective
12530de9b25SBarry Smith 
12630de9b25SBarry Smith   Input Parameters:
12730de9b25SBarry Smith +   comm - communicator that shares GUI
12876280437SVaclav Hapla .   prefix - options prefix for all options displayed on window (optional)
12930de9b25SBarry Smith .   title - short descriptive text, for example "Krylov Solver Options"
13076280437SVaclav Hapla -   mansec - section of manual pages for options, for example KSP (optional)
13130de9b25SBarry Smith 
13230de9b25SBarry Smith   Level: intermediate
13330de9b25SBarry Smith 
13495452b02SPatrick Sanan   Notes:
135fb455bf4SPatrick Sanan     The set of queries needs to be ended by a call to PetscOptionsEnd().
136fb455bf4SPatrick Sanan 
137fb455bf4SPatrick Sanan     One can add subheadings with PetscOptionsHead().
13830de9b25SBarry Smith 
13995452b02SPatrick Sanan   Developer Notes:
14095452b02SPatrick Sanan       PetscOptionsPublish is set in PetscOptionsCheckInitial_Private() with -saws_options. When PetscOptionsPublish is set the
141fb455bf4SPatrick Sanan       loop between PetscOptionsBegin() and PetscOptionsEnd() is run THREE times with PetscOptionsPublishCount of values -1,0,1.
142fb455bf4SPatrick Sanan       Otherwise the loop is run ONCE with a PetscOptionsPublishCount of 1.
143fb455bf4SPatrick Sanan +      \-1 - PetscOptionsInt() etc. just call PetscOptionsGetInt() etc.
144fb455bf4SPatrick Sanan .      0  - The GUI objects are created in PetscOptionsInt() etc. and displayed in PetscOptionsEnd() and the options
145fb455bf4SPatrick Sanan                database updated with user changes; PetscOptionsGetInt() etc. are also called.
146fb455bf4SPatrick Sanan -      1 - PetscOptionsInt() etc. again call PetscOptionsGetInt() etc. (possibly getting new values), in addition the help message and
147fb455bf4SPatrick Sanan               default values are printed if -help was given.
148fb455bf4SPatrick Sanan       When PetscOptionsObject.changedmethod is set this causes PetscOptionsPublishCount to be reset to -2 (so in the next loop iteration it is -1)
149fb455bf4SPatrick Sanan       and the whole process is repeated. This is to handle when, for example, the KSPType is changed thus changing the list of
150fb455bf4SPatrick Sanan       options available so they need to be redisplayed so the user can change the. Changing PetscOptionsObjects.changedmethod is never
151fb455bf4SPatrick Sanan       currently set.
152aee2cecaSBarry Smith 
15330de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
154acfcf0e5SJed Brown           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool()
155acfcf0e5SJed Brown           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsBool(),
15630de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
15730de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
158acfcf0e5SJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
159a264d7a6SBarry Smith           PetscOptionsFList(), PetscOptionsEList(), PetscObjectOptionsBegin()
16030de9b25SBarry Smith 
16130de9b25SBarry Smith M*/
1623194b578SJed Brown #define    PetscOptionsBegin(comm,prefix,mess,sec) 0; do {\
1634416b707SBarry Smith              PetscOptionItems PetscOptionsObjectBase;\
1644416b707SBarry Smith              PetscOptionItems *PetscOptionsObject = &PetscOptionsObjectBase; \
1654416b707SBarry Smith              PetscMemzero(PetscOptionsObject,sizeof(PetscOptionItems)); \
166e55864a3SBarry Smith              for (PetscOptionsObject->count=(PetscOptionsPublish?-1:1); PetscOptionsObject->count<2; PetscOptionsObject->count++) {\
167e83a5d19SLisandro Dalcin              PetscErrorCode _5_ierr = PetscOptionsBegin_Private(PetscOptionsObject,comm,prefix,mess,sec);CHKERRQ(_5_ierr)
16830de9b25SBarry Smith 
1695fefd1ebSJed Brown /*MC
1705fefd1ebSJed Brown     PetscObjectOptionsBegin - Begins a set of queries on the options database that are related and should be
1715fefd1ebSJed Brown      displayed on the same window of a GUI that allows the user to set the options interactively.
1725fefd1ebSJed Brown 
173f2ba6396SBarry Smith    Synopsis:
174aaa7dc30SBarry Smith     #include <petscoptions.h>
175f2ba6396SBarry Smith     PetscErrorCode PetscObjectOptionsBegin(PetscObject obj)
1765fefd1ebSJed Brown 
177d083f849SBarry Smith     Collective on obj
1785fefd1ebSJed Brown 
1795fefd1ebSJed Brown   Input Parameters:
1805fefd1ebSJed Brown .   obj - object to set options for
1815fefd1ebSJed Brown 
1825fefd1ebSJed Brown   Level: intermediate
1835fefd1ebSJed Brown 
18495452b02SPatrick Sanan   Notes:
18595452b02SPatrick Sanan     Needs to be ended by a call the PetscOptionsEnd()
1865fefd1ebSJed Brown          Can add subheadings with PetscOptionsHead()
1875fefd1ebSJed Brown 
1885fefd1ebSJed Brown .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
1895fefd1ebSJed Brown           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool()
1905fefd1ebSJed Brown           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsBool(),
1915fefd1ebSJed Brown           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
1925fefd1ebSJed Brown           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
1935fefd1ebSJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
194a264d7a6SBarry Smith           PetscOptionsFList(), PetscOptionsEList()
1955fefd1ebSJed Brown 
1965fefd1ebSJed Brown M*/
1973194b578SJed Brown #define PetscObjectOptionsBegin(obj) 0; do {                            \
1984416b707SBarry Smith              PetscOptionItems PetscOptionsObjectBase;\
1994416b707SBarry Smith              PetscOptionItems *PetscOptionsObject = &PetscOptionsObjectBase; \
200c5929fdfSBarry Smith              PetscOptionsObject->options = ((PetscObject)obj)->options; \
201e55864a3SBarry Smith              for (PetscOptionsObject->count=(PetscOptionsPublish?-1:1); PetscOptionsObject->count<2; PetscOptionsObject->count++) {\
202e83a5d19SLisandro Dalcin              PetscErrorCode _5_ierr = PetscObjectOptionsBegin_Private(PetscOptionsObject,obj);CHKERRQ(_5_ierr)
2033194b578SJed Brown 
20430de9b25SBarry Smith /*MC
20530de9b25SBarry Smith     PetscOptionsEnd - Ends a set of queries on the options database that are related and should be
20630de9b25SBarry Smith      displayed on the same window of a GUI that allows the user to set the options interactively.
20730de9b25SBarry Smith 
208d083f849SBarry Smith     Collective on the comm used in PetscOptionsBegin() or obj used in PetscObjectOptionsBegin()
20930de9b25SBarry Smith 
210f2ba6396SBarry Smith    Synopsis:
211aaa7dc30SBarry Smith      #include <petscoptions.h>
212f2ba6396SBarry Smith      PetscErrorCode PetscOptionsEnd(void)
21330de9b25SBarry Smith 
21430de9b25SBarry Smith   Level: intermediate
21530de9b25SBarry Smith 
21695452b02SPatrick Sanan   Notes:
21795452b02SPatrick Sanan     Needs to be preceded by a call to PetscOptionsBegin() or PetscObjectOptionsBegin()
21830de9b25SBarry Smith 
21930de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
220acfcf0e5SJed Brown           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool()
221acfcf0e5SJed Brown           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsBool(),
22230de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
22330de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
224acfcf0e5SJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
225a264d7a6SBarry Smith           PetscOptionsFList(), PetscOptionsEList(), PetscObjectOptionsBegin()
22630de9b25SBarry Smith 
22730de9b25SBarry Smith M*/
228e55864a3SBarry Smith #define    PetscOptionsEnd() _5_ierr = PetscOptionsEnd_Private(PetscOptionsObject);CHKERRQ(_5_ierr);}} while (0)
22930de9b25SBarry Smith 
2304416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsBegin_Private(PetscOptionItems *,MPI_Comm,const char[],const char[],const char[]);
2314416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscObjectOptionsBegin_Private(PetscOptionItems *,PetscObject);
2324416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsEnd_Private(PetscOptionItems *);
2334416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsHead(PetscOptionItems *,const char[]);
23430de9b25SBarry Smith 
23530de9b25SBarry Smith /*MC
23630de9b25SBarry Smith      PetscOptionsTail - Ends a section of options begun with PetscOptionsHead()
23730de9b25SBarry Smith             See, for example, KSPSetFromOptions_GMRES().
23830de9b25SBarry Smith 
239d083f849SBarry Smith     Collective on the comm used in PetscOptionsBegin() or obj used in PetscObjectOptionsBegin()
24030de9b25SBarry Smith 
241f2ba6396SBarry Smith    Synopsis:
242aaa7dc30SBarry Smith      #include <petscoptions.h>
243f2ba6396SBarry Smith      PetscErrorCode PetscOptionsTail(void)
24430de9b25SBarry Smith 
24530de9b25SBarry Smith   Level: intermediate
24630de9b25SBarry Smith 
24795452b02SPatrick Sanan    Notes:
24895452b02SPatrick Sanan     Must be between a PetscOptionsBegin()/PetscObjectOptionsBegin() and a PetscOptionsEnd()
24930de9b25SBarry Smith 
25030de9b25SBarry Smith           Must be preceded by a call to PetscOptionsHead() in the same function.
25130de9b25SBarry Smith 
252b52f573bSBarry Smith           This needs to be used only if the code below PetscOptionsTail() can be run ONLY once.
253b52f573bSBarry Smith       See, for example, PCSetFromOptions_Composite(). This is a return(0) in it for early exit
254b52f573bSBarry Smith       from the function.
255b52f573bSBarry Smith 
25656752e42SBarry Smith           This is only for use with the PETSc options GUI
257b52f573bSBarry Smith 
25830de9b25SBarry Smith .seealso: PetscOptionsGetInt(), PetscOptionsGetReal(),
259acfcf0e5SJed Brown            PetscOptionsHasName(), PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool(),
26030de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
26130de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
262acfcf0e5SJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
263a264d7a6SBarry Smith           PetscOptionsFList(), PetscOptionsEList(), PetscOptionsEnum()
26430de9b25SBarry Smith M*/
265e83a5d19SLisandro Dalcin #define    PetscOptionsTail() 0; do {if (PetscOptionsObject->count != 1) PetscFunctionReturn(0);} while(0)
266186905e3SBarry Smith 
267e55864a3SBarry Smith #define PetscOptionsEnum(a,b,c,d,e,f,g) PetscOptionsEnum_Private(PetscOptionsObject,a,b,c,d,e,f,g)
2685a856986SBarry Smith #define PetscOptionsInt(a,b,c,d,e,f) PetscOptionsInt_Private(PetscOptionsObject,a,b,c,d,e,f,PETSC_MIN_INT,PETSC_MAX_INT)
2695a856986SBarry Smith #define PetscOptionsBoundedInt(a,b,c,d,e,f,g) PetscOptionsInt_Private(PetscOptionsObject,a,b,c,d,e,f,g,PETSC_MAX_INT)
2705a856986SBarry Smith #define PetscOptionsRangeInt(a,b,c,d,e,f,g,h) PetscOptionsInt_Private(PetscOptionsObject,a,b,c,d,e,f,g,h)
271e55864a3SBarry Smith #define PetscOptionsReal(a,b,c,d,e,f) PetscOptionsReal_Private(PetscOptionsObject,a,b,c,d,e,f)
272e55864a3SBarry Smith #define PetscOptionsScalar(a,b,c,d,e,f) PetscOptionsScalar_Private(PetscOptionsObject,a,b,c,d,e,f)
273e55864a3SBarry Smith #define PetscOptionsName(a,b,c,d) PetscOptionsName_Private(PetscOptionsObject,a,b,c,d)
274e55864a3SBarry Smith #define PetscOptionsString(a,b,c,d,e,f,g) PetscOptionsString_Private(PetscOptionsObject,a,b,c,d,e,f,g)
275e55864a3SBarry Smith #define PetscOptionsBool(a,b,c,d,e,f) PetscOptionsBool_Private(PetscOptionsObject,a,b,c,d,e,f)
276e55864a3SBarry Smith #define PetscOptionsBoolGroupBegin(a,b,c,d) PetscOptionsBoolGroupBegin_Private(PetscOptionsObject,a,b,c,d)
277e55864a3SBarry Smith #define PetscOptionsBoolGroup(a,b,c,d) PetscOptionsBoolGroup_Private(PetscOptionsObject,a,b,c,d)
278e55864a3SBarry Smith #define PetscOptionsBoolGroupEnd(a,b,c,d) PetscOptionsBoolGroupEnd_Private(PetscOptionsObject,a,b,c,d)
27983355fc5SBarry Smith #define PetscOptionsFList(a,b,c,d,e,f,g,h) PetscOptionsFList_Private(PetscOptionsObject,a,b,c,d,e,f,g,h)
280e55864a3SBarry Smith #define PetscOptionsEList(a,b,c,d,e,f,g,h) PetscOptionsEList_Private(PetscOptionsObject,a,b,c,d,e,f,g,h)
281e55864a3SBarry Smith #define PetscOptionsRealArray(a,b,c,d,e,f) PetscOptionsRealArray_Private(PetscOptionsObject,a,b,c,d,e,f)
282050cccc3SHong Zhang #define PetscOptionsScalarArray(a,b,c,d,e,f) PetscOptionsScalarArray_Private(PetscOptionsObject,a,b,c,d,e,f)
283e55864a3SBarry Smith #define PetscOptionsIntArray(a,b,c,d,e,f) PetscOptionsIntArray_Private(PetscOptionsObject,a,b,c,d,e,f)
284e55864a3SBarry Smith #define PetscOptionsStringArray(a,b,c,d,e,f) PetscOptionsStringArray_Private(PetscOptionsObject,a,b,c,d,e,f)
285e55864a3SBarry Smith #define PetscOptionsBoolArray(a,b,c,d,e,f) PetscOptionsBoolArray_Private(PetscOptionsObject,a,b,c,d,e,f)
286d3e47460SLisandro Dalcin #define PetscOptionsEnumArray(a,b,c,d,e,f,g) PetscOptionsEnumArray_Private(PetscOptionsObject,a,b,c,d,e,f,g)
2879f3a6782SPatrick Sanan #define PetscOptionsDeprecated(a,b,c,d) PetscOptionsDeprecated_Private(PetscOptionsObject,a,b,c,d)
288b0bdc838SStefano Zampini #define PetscOptionsDeprecatedNoObject(a,b,c,d) PetscOptionsDeprecated_Private(NULL,a,b,c,d)
289e55864a3SBarry Smith 
290e55864a3SBarry Smith 
2914416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsEnum_Private(PetscOptionItems*,const char[],const char[],const char[],const char *const*,PetscEnum,PetscEnum*,PetscBool*);
2925a856986SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsInt_Private(PetscOptionItems*,const char[],const char[],const char[],PetscInt,PetscInt*,PetscBool*,PetscInt,PetscInt);
2934416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsReal_Private(PetscOptionItems*,const char[],const char[],const char[],PetscReal,PetscReal*,PetscBool*);
2944416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsScalar_Private(PetscOptionItems*,const char[],const char[],const char[],PetscScalar,PetscScalar*,PetscBool*);
2954416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsName_Private(PetscOptionItems*,const char[],const char[],const char[],PetscBool*);
2964416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsString_Private(PetscOptionItems*,const char[],const char[],const char[],const char[],char*,size_t,PetscBool*);
2974416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsBool_Private(PetscOptionItems*,const char[],const char[],const char[],PetscBool ,PetscBool*,PetscBool*);
2984416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsBoolGroupBegin_Private(PetscOptionItems*,const char[],const char[],const char[],PetscBool*);
2994416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsBoolGroup_Private(PetscOptionItems*,const char[],const char[],const char[],PetscBool*);
3004416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsBoolGroupEnd_Private(PetscOptionItems*,const char[],const char[],const char[],PetscBool*);
3014416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsFList_Private(PetscOptionItems*,const char[],const char[],const char[],PetscFunctionList,const char[],char[],size_t,PetscBool*);
3024416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsEList_Private(PetscOptionItems*,const char[],const char[],const char[],const char*const*,PetscInt,const char[],PetscInt*,PetscBool*);
3034416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsRealArray_Private(PetscOptionItems*,const char[],const char[],const char[],PetscReal[],PetscInt*,PetscBool*);
3044416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsScalarArray_Private(PetscOptionItems*,const char[],const char[],const char[],PetscScalar[],PetscInt*,PetscBool*);
3054416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsIntArray_Private(PetscOptionItems*,const char[],const char[],const char[],PetscInt[],PetscInt*,PetscBool*);
3064416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsStringArray_Private(PetscOptionItems*,const char[],const char[],const char[],char*[],PetscInt*,PetscBool*);
3074416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsBoolArray_Private(PetscOptionItems*,const char[],const char[],const char[],PetscBool [],PetscInt*,PetscBool*);
3084416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsEnumArray_Private(PetscOptionItems*,const char[],const char[],const char[],const char *const*,PetscEnum[],PetscInt*,PetscBool*);
3099f3a6782SPatrick Sanan PETSC_EXTERN PetscErrorCode PetscOptionsDeprecated_Private(PetscOptionItems*,const char[],const char[],const char[],const char[]);
310cffb1e40SBarry Smith 
311e9fa29b7SSatish Balay 
312c5929fdfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsSetFromOptions(PetscOptions);
313e04113cfSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsSAWsDestroy(void);
314f8d0b74dSMatthew Knepley 
315447ac60bSBarry Smith PETSC_EXTERN PetscErrorCode PetscObjectAddOptionsHandler(PetscObject,PetscErrorCode (*)(PetscOptionItems*,PetscObject,void*),PetscErrorCode (*)(PetscObject,void*),void*);
316447ac60bSBarry Smith PETSC_EXTERN PetscErrorCode PetscObjectProcessOptionsHandlers(PetscOptionItems*,PetscObject);
317447ac60bSBarry Smith PETSC_EXTERN PetscErrorCode PetscObjectDestroyOptionsHandlers(PetscObject);
318447ac60bSBarry Smith 
3193a3b2205SBarry Smith #endif
320