Actual source code: prefix.c
1: /*
2: Provides utility routines for manulating any type of PETSc object.
3: */
4: #include <petsc/private/petscimpl.h>
6: /*@C
7: PetscObjectGetOptions - Gets the options database used by the object that has been set with `PetscObjectSetOptions()`
9: Collective
11: Input Parameter:
12: . obj - any PETSc object, for example a `Vec`, `Mat` or `KSP`.
14: Output Parameter:
15: . options - the options database
17: Level: advanced
19: Note:
20: If this is not called the object will use the default options database
22: Developer Notes:
23: This functionality is not used in PETSc and should, perhaps, be removed
25: .seealso: `PetscOptionsCreate()`, `PetscOptionsDestroy()`, `PetscObjectSetOptionsPrefix()`, `PetscObjectAppendOptionsPrefix()`, `PetscObjectPrependOptionsPrefix()`,
26: `PetscObjectGetOptionsPrefix()`, `PetscObjectSetOptions()`
27: @*/
28: PetscErrorCode PetscObjectGetOptions(PetscObject obj, PetscOptions *options)
29: {
30: PetscFunctionBegin;
32: *options = obj->options;
33: PetscFunctionReturn(PETSC_SUCCESS);
34: }
36: /*@C
37: PetscObjectSetOptions - Sets the options database used by the object. Call immediately after creating the object.
39: Collective
41: Input Parameters:
42: + obj - any PETSc object, for example a `Vec`, `Mat` or `KSP`.
43: - options - the options database, use NULL for default
45: Level: advanced
47: Note:
48: If this is not called the object will use the default options database
50: Developer Notes:
51: This functionality is not used in PETSc and should, perhaps, be removed
53: .seealso: `PetscOptionsCreate()`, `PetscOptionsDestroy()`, `PetscObjectSetOptionsPrefix()`, `PetscObjectAppendOptionsPrefix()`, `PetscObjectPrependOptionsPrefix()`,
54: `PetscObjectGetOptionsPrefix()`, `PetscObjectGetOptions()`
55: @*/
56: PetscErrorCode PetscObjectSetOptions(PetscObject obj, PetscOptions options)
57: {
58: PetscFunctionBegin;
60: obj->options = options;
61: PetscFunctionReturn(PETSC_SUCCESS);
62: }
64: /*@C
65: PetscObjectSetOptionsPrefix - Sets the prefix used for searching for all
66: options for the given object in the database.
68: Collective
70: Input Parameters:
71: + obj - any PETSc object, for example a `Vec`, `Mat` or `KSP`.
72: - prefix - the prefix string to prepend to option requests of the object.
74: Level: advanced
76: Note:
77: A hyphen (-) must NOT be given at the beginning of the prefix name.
78: The first character of all runtime options is AUTOMATICALLY the
79: hyphen.
81: .seealso: `PetscOptionsCreate()`, `PetscOptionsDestroy()`, `PetscObjectAppendOptionsPrefix()`, `PetscObjectPrependOptionsPrefix()`,
82: `PetscObjectGetOptionsPrefix()`, `TSSetOptionsPrefix()`, `SNESSetOptionsPrefix()`, `KSPSetOptionsPrefix()`
83: @*/
84: PetscErrorCode PetscObjectSetOptionsPrefix(PetscObject obj, const char prefix[])
85: {
86: PetscFunctionBegin;
88: if (prefix) {
89: PetscAssertPointer(prefix, 2);
90: PetscCheck(prefix[0] != '-', PETSC_COMM_SELF, PETSC_ERR_ARG_WRONG, "Options prefix should not begin with a hyphen");
91: if (prefix != obj->prefix) {
92: PetscCall(PetscFree(obj->prefix));
93: PetscCall(PetscStrallocpy(prefix, &obj->prefix));
94: }
95: } else PetscCall(PetscFree(obj->prefix));
96: PetscFunctionReturn(PETSC_SUCCESS);
97: }
99: /*@C
100: PetscObjectAppendOptionsPrefix - Appends to the prefix used for searching for options for the given object in the database.
102: Input Parameters:
103: + obj - any PETSc object, for example a `Vec`, `Mat` or `KSP`.
104: - prefix - the prefix string to prepend to option requests of the object.
106: Level: advanced
108: Note:
109: A hyphen (-) must NOT be given at the beginning of the prefix name.
110: The first character of all runtime options is AUTOMATICALLY the
111: hyphen.
113: .seealso: `PetscOptionsCreate()`, `PetscOptionsDestroy()`, `PetscObjectSetOptionsPrefix()`, `PetscObjectPrependOptionsPrefix()`,
114: `PetscObjectGetOptionsPrefix()`, `TSAppendOptionsPrefix()`, `SNESAppendOptionsPrefix()`, `KSPAppendOptionsPrefix()`
115: @*/
116: PetscErrorCode PetscObjectAppendOptionsPrefix(PetscObject obj, const char prefix[])
117: {
118: size_t len1, len2, new_len;
120: PetscFunctionBegin;
122: if (!prefix) PetscFunctionReturn(PETSC_SUCCESS);
123: if (!obj->prefix) {
124: PetscCall(PetscObjectSetOptionsPrefix(obj, prefix));
125: PetscFunctionReturn(PETSC_SUCCESS);
126: }
127: PetscCheck(prefix[0] != '-', PETSC_COMM_SELF, PETSC_ERR_ARG_WRONG, "Options prefix should not begin with a hyphen");
129: PetscCall(PetscStrlen(obj->prefix, &len1));
130: PetscCall(PetscStrlen(prefix, &len2));
131: new_len = len1 + len2 + 1;
132: PetscCall(PetscRealloc(new_len * sizeof(*(obj->prefix)), &obj->prefix));
133: PetscCall(PetscStrncpy(obj->prefix + len1, prefix, len2 + 1));
134: PetscFunctionReturn(PETSC_SUCCESS);
135: }
137: /*@C
138: PetscObjectGetOptionsPrefix - Gets the prefix of the `PetscObject` used for searching in the options database
140: Input Parameter:
141: . obj - any PETSc object, for example a `Vec`, `Mat` or `KSP`.
143: Output Parameter:
144: . prefix - pointer to the prefix string used is returned
146: Level: advanced
148: .seealso: `PetscOptionsCreate()`, `PetscOptionsDestroy()`, `PetscObjectSetOptionsPrefix()`, `PetscObjectAppendOptionsPrefix()`, `PetscObjectPrependOptionsPrefix()`,
149: `TSGetOptionsPrefix()`, `SNESGetOptionsPrefix()`, `KSPGetOptionsPrefix()`
150: @*/
151: PetscErrorCode PetscObjectGetOptionsPrefix(PetscObject obj, const char *prefix[])
152: {
153: PetscFunctionBegin;
155: PetscAssertPointer(prefix, 2);
156: *prefix = obj->prefix;
157: PetscFunctionReturn(PETSC_SUCCESS);
158: }
160: /*@C
161: PetscObjectPrependOptionsPrefix - Sets the prefix used for searching for options of for this object in the database.
163: Input Parameters:
164: + obj - any PETSc object, for example a `Vec`, `Mat` or `KSP`.
165: - prefix - the prefix string to prepend to option requests of the object.
167: Level: advanced
169: Note:
170: A hyphen (-) must NOT be given at the beginning of the prefix name.
171: The first character of all runtime options is AUTOMATICALLY the
172: hyphen.
174: .seealso: `PetscOptionsCreate()`, `PetscOptionsDestroy()`, `PetscObjectSetOptionsPrefix()`, `PetscObjectAppendOptionsPrefix()`,
175: `PetscObjectGetOptionsPrefix()`
176: @*/
177: PetscErrorCode PetscObjectPrependOptionsPrefix(PetscObject obj, const char prefix[])
178: {
179: char *buf;
180: size_t len1, len2, new_len;
182: PetscFunctionBegin;
184: if (!prefix) PetscFunctionReturn(PETSC_SUCCESS);
185: if (!obj->prefix) {
186: PetscCall(PetscObjectSetOptionsPrefix(obj, prefix));
187: PetscFunctionReturn(PETSC_SUCCESS);
188: }
189: PetscCheck(prefix[0] != '-', PETSC_COMM_SELF, PETSC_ERR_ARG_WRONG, "Options prefix should not begin with a hyphen");
191: PetscCall(PetscStrlen(prefix, &len1));
192: PetscCall(PetscStrlen(obj->prefix, &len2));
193: buf = obj->prefix;
194: new_len = len1 + len2 + 1;
195: PetscCall(PetscMalloc1(new_len, &obj->prefix));
196: PetscCall(PetscStrncpy(obj->prefix, prefix, len1 + 1));
197: PetscCall(PetscStrncpy(obj->prefix + len1, buf, len2 + 1));
198: PetscCall(PetscFree(buf));
199: PetscFunctionReturn(PETSC_SUCCESS);
200: }