xref: /petsc/include/petscbag.h (revision 6dd63270497ad23dcf16ae500a87ff2b2a0b7474)
1 #pragma once
2 
3 #include <petscsys.h>
4 
5 /* MANSEC = Sys */
6 /* SUBMANSEC = Bag */
7 
8 /*S
9    PetscBag - PETSc object that manages a collection of user data including parameters.
10               A bag is essentially a C struct with serialization (you can save it and load it from files).
11 
12    Level: beginner
13 
14    Sample Usage:
15 .vb
16       typedef struct {
17          PetscInt     height;
18          PetscScalar  root;
19          PetscReal    byebye;
20       } MyParameters;
21 
22       PetscBag     bag;
23       MyParameters *params;
24 
25       PetscCall(PetscBagCreate(PETSC_COMM_WORLD,sizeof(MyParameters),&bag));
26       PetscCall(PetscBagGetData(bag,(void **)&params));
27       PetscCall(PetscBagSetName(bag,"MyParameters"));
28       PetscCall(PetscBagRegisterInt(bag,&params.height,22,"height","Height of the water tower"));
29 .ve
30    Note:
31   `PetscBag` is a C struct, it is not a `PetscObject`
32 
33 .seealso: `PetscBagSetName()`, `PetscBagGetName()`, `PetscBagView()`, `PetscBagLoad()`, `PetscBagGetData()`
34           `PetscBagRegisterReal()`, `PetscBagRegisterInt()`, `PetscBagRegisterBool()`, `PetscBagRegisterScalar()`
35           `PetscBagSetFromOptions()`, `PetscBagRegisterVec()`, `PetscBagCreate()`, `PetscBagDestroy()`, `PetscBagRegisterEnum()`
36 S*/
37 typedef struct _n_PetscBag     *PetscBag;
38 typedef struct _n_PetscBagItem *PetscBagItem;
39 
40 PETSC_EXTERN PetscErrorCode PetscBagCreate(MPI_Comm, size_t, PetscBag *);
41 PETSC_EXTERN PetscErrorCode PetscBagDestroy(PetscBag *);
42 PETSC_EXTERN PetscErrorCode PetscBagGetData(PetscBag, void *);
43 PETSC_EXTERN PetscErrorCode PetscBagRegisterReal(PetscBag, void *, PetscReal, const char *, const char *);
44 PETSC_EXTERN PetscErrorCode PetscBagRegisterRealArray(PetscBag, void *, PetscInt, const char *, const char *);
45 PETSC_EXTERN PetscErrorCode PetscBagRegisterString(PetscBag, void *, PetscInt, const char *, const char *, const char *);
46 PETSC_EXTERN PetscErrorCode PetscBagRegisterScalar(PetscBag, void *, PetscScalar, const char *, const char *);
47 PETSC_EXTERN PetscErrorCode PetscBagRegisterInt(PetscBag, void *, PetscInt, const char *, const char *);
48 PETSC_EXTERN PetscErrorCode PetscBagRegisterInt64(PetscBag, void *, PetscInt64, const char *, const char *);
49 PETSC_EXTERN PetscErrorCode PetscBagRegisterIntArray(PetscBag, void *, PetscInt, const char *, const char *);
50 PETSC_EXTERN PetscErrorCode PetscBagRegisterEnum(PetscBag, void *, const char *const *, PetscEnum, const char *, const char *);
51 PETSC_EXTERN PetscErrorCode PetscBagRegisterBool(PetscBag, void *, PetscBool, const char *, const char *);
52 PETSC_EXTERN PetscErrorCode PetscBagRegisterBoolArray(PetscBag, void *, PetscInt, const char *, const char *);
53 PETSC_EXTERN PetscErrorCode PetscBagGetNames(PetscBag, const char *[]);
54 
55 PETSC_EXTERN PetscErrorCode PetscBagSetFromOptions(PetscBag);
56 PETSC_EXTERN PetscErrorCode PetscBagGetName(PetscBag, const char **);
57 PETSC_EXTERN PetscErrorCode PetscBagSetName(PetscBag, const char *, const char *);
58 PETSC_EXTERN PetscErrorCode PetscBagSetOptionsPrefix(PetscBag, const char *);
59 
60 PETSC_EXTERN PetscErrorCode PetscBagView(PetscBag, PetscViewer);
61 PETSC_EXTERN PetscErrorCode PetscBagLoad(PetscViewer, PetscBag);
62 PETSC_EXTERN PetscErrorCode PetscBagViewFromOptions(PetscBag, PetscObject, const char[]);
63 
64 #define PETSC_BAG_FILE_CLASSID 1211219
65