#include "grid.h" int GridRegisterDestroy(void)
GridSerializeRegister(char *name, char *path, char *func_name, int (*serialize_func)(MPI_Comm, Grid *, PetscViewer, PetscTruth))
Not Collective
name | - The name of a new user-defined serialization routine | |
path | - The path (either absolute or relative) of the library containing this routine | |
func_name | - The name of the serialization routine | |
serialize_func | - The serialization routine itself |
If dynamic libraries are used, then the fourth input argument (serialize_func) is ignored.
GridSerializeRegisterDynamic("my_store", "/home/username/my_lib/lib/libO/solaris/libmy.a", "MyStoreFunc", MyStoreFunc);
Then, your serialization can be chosen with the procedural interface via
GridSetSerializeType(grid, "my_store")or at runtime via the option
-grid_serialize_type my_store
Note: $PETSC_ARCH and $BOPT occuring in pathname will be replaced with appropriate values.
PetscFunctionBegin; ierr = PetscStrcpy(fullname, path); CHKERRQ(ierr); ierr = PetscStrcat(fullname, ":"); CHKERRQ(ierr); ierr = PetscStrcat(fullname, name); CHKERRQ(ierr); ierr = PetscFListAdd(&GridSerializeList, sname, fullname, (void (*)(void)) function); CHKERRQ(ierr); PetscFunctionReturn(0); }
/*-------------------------------------------------------------------------------------------------------------------*/ #undef __FUNCT__ #define __FUNCT__ "GridRegisterDestroy" /*@C GridRegisterDestroy - Frees the list of creation routines for grids that were registered by GridRegister().
Not collective
Level:advanced
Location:src/grid/interface/gridreg.c
Index of all Grid routines
Table of Contents for all manual pages
Index of all manual pages