1 #include <petsc/private/fortranimpl.h> 2 #include <petscdm.h> 3 #include <petscviewer.h> 4 5 #if defined(PETSC_HAVE_FORTRAN_CAPS) 6 #define dmcreateinterpolation_ DMCREATEINTERPOLATION 7 #define dmview_ DMVIEW 8 #define dmsetoptionsprefix_ DMSETOPTIONSPREFIX 9 #define dmsettype_ DMSETTYPE 10 #define dmgettype_ DMGETTYPE 11 #define dmsetmattype_ DMSETMATTYPE 12 #define dmsetvectype_ DMSETVECTYPE 13 #define dmgetmattype_ DMGETMATTYPE 14 #define dmgetvectype_ DMGETVECTYPE 15 #define dmlabelview_ DMLABELVIEW 16 #define dmcreatelabel_ DMCREATELABEL 17 #define dmhaslabel_ DMHASLABEL 18 #define dmgetlabelvalue_ DMGETLABELVALUE 19 #define dmsetlabelvalue_ DMSETLABELVALUE 20 #define dmgetlabelsize_ DMGETLABELSIZE 21 #define dmgetlabelidis_ DMGETLABELIDIS 22 #define dmgetlabelname_ DMGETLABELNAME 23 #define dmgetlabel_ DMGETLABEL 24 #define dmgetstratumsize_ DMGETSTRATUMSIZE 25 #define dmgetstratumis_ DMGETSTRATUMIS 26 #define dmsetstratumis_ DMSETSTRATUMIS 27 #define dmremovelabel_ DMREMOVELABEL 28 #define dmviewfromoptions_ DMVIEWFROMOPTIONS 29 #define dmcreatesuperdm_ DMCREATESUPERDM 30 #define dmdestroy_ DMDESTROY 31 #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE) 32 #define dmcreateinterpolation_ dmcreateinterpolation 33 #define dmview_ dmview 34 #define dmsetoptionsprefix_ dmsetoptionsprefix 35 #define dmsettype_ dmsettype 36 #define dmgettype_ dmgettype 37 #define dmsetmattype_ dmsetmattype 38 #define dmsetvectype_ dmsetvectype 39 #define dmgetmattype_ dmgetmattype 40 #define dmgetvectype_ dmgetvectype 41 #define dmlabelview_ dmlabelview 42 #define dmcreatelabel_ dmcreatelabel 43 #define dmhaslabel_ dmhaslabel 44 #define dmgetlabelvalue_ dmgetlabelvalue 45 #define dmsetlabelvalue_ dmsetlabelvalue 46 #define dmgetlabelsize_ dmlabelsize 47 #define dmgetlabelidis_ dmlabelidis 48 #define dmgetlabelname_ dmgetlabelname 49 #define dmgetlabel_ dmgetlabel 50 #define dmgetstratumsize_ dmgetstratumsize 51 #define dmgetstratumis_ dmgetstratumis 52 #define dmsetstratumis_ dmsetstratumis 53 #define dmremovelabel_ dmremovelabel 54 #define dmviewfromoptions_ dmviewfromoptions 55 #define dmcreatesuperdm_ dmreatesuperdm 56 #define dmdestroy_ dmdestroy 57 #endif 58 59 PETSC_EXTERN void dmgetmattype_(DM *mm,char* name,PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 60 { 61 const char *tname; 62 63 *ierr = DMGetMatType(*mm,&tname);if (*ierr) return; 64 if (name != PETSC_NULL_CHARACTER_Fortran) { 65 *ierr = PetscStrncpy(name,tname,len);if (*ierr) return; 66 } 67 FIXRETURNCHAR(PETSC_TRUE,name,len); 68 } 69 70 PETSC_EXTERN void dmgetvectype_(DM *mm,char* name,PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 71 { 72 const char *tname; 73 74 *ierr = DMGetVecType(*mm,&tname);if (*ierr) return; 75 if (name != PETSC_NULL_CHARACTER_Fortran) { 76 *ierr = PetscStrncpy(name,tname,len);if (*ierr) return; 77 } 78 FIXRETURNCHAR(PETSC_TRUE,name,len); 79 } 80 81 PETSC_EXTERN void dmview_(DM *da,PetscViewer *vin,PetscErrorCode *ierr) 82 { 83 PetscViewer v; 84 PetscPatchDefaultViewers_Fortran(vin,v); 85 *ierr = DMView(*da,v); 86 } 87 88 PETSC_EXTERN void dmsetoptionsprefix_(DM *dm,char* prefix, PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 89 { 90 char *t; 91 92 FIXCHAR(prefix,len,t); 93 *ierr = DMSetOptionsPrefix(*dm,t);if (*ierr) return; 94 FREECHAR(prefix,t); 95 } 96 97 PETSC_EXTERN void dmsettype_(DM *x,char* type_name,PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 98 { 99 char *t; 100 101 FIXCHAR(type_name,len,t); 102 *ierr = DMSetType(*x,t);if (*ierr) return; 103 FREECHAR(type_name,t); 104 } 105 106 PETSC_EXTERN void dmgettype_(DM *mm,char* name,PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 107 { 108 const char *tname; 109 110 *ierr = DMGetType(*mm,&tname);if (*ierr) return; 111 if (name != PETSC_NULL_CHARACTER_Fortran) { 112 *ierr = PetscStrncpy(name,tname,len);if (*ierr) return; 113 } 114 FIXRETURNCHAR(PETSC_TRUE,name,len); 115 116 } 117 118 PETSC_EXTERN void dmsetmattype_(DM *dm,char* prefix, PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 119 { 120 char *t; 121 122 FIXCHAR(prefix,len,t); 123 *ierr = DMSetMatType(*dm,t);if (*ierr) return; 124 FREECHAR(prefix,t); 125 } 126 127 128 PETSC_EXTERN void dmsetvectype_(DM *dm,char* prefix, PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 129 { 130 char *t; 131 132 FIXCHAR(prefix,len,t); 133 *ierr = DMSetVecType(*dm,t);if (*ierr) return; 134 FREECHAR(prefix,t); 135 } 136 137 PETSC_EXTERN void dmcreatelabel_(DM *dm, char* name, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 138 { 139 char *lname; 140 141 FIXCHAR(name, lenN, lname); 142 *ierr = DMCreateLabel(*dm, lname);if (*ierr) return; 143 FREECHAR(name, lname); 144 } 145 146 PETSC_EXTERN void dmhaslabel_(DM *dm, char* name, PetscBool *hasLabel, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 147 { 148 char *lname; 149 150 FIXCHAR(name, lenN, lname); 151 *ierr = DMHasLabel(*dm, lname, hasLabel);if (*ierr) return; 152 FREECHAR(name, lname); 153 } 154 155 PETSC_EXTERN void dmgetlabelvalue_(DM *dm, char* name, PetscInt *point, PetscInt *value, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 156 { 157 char *lname; 158 159 FIXCHAR(name, lenN, lname); 160 *ierr = DMGetLabelValue(*dm, lname, *point, value);if (*ierr) return; 161 FREECHAR(name, lname); 162 } 163 164 PETSC_EXTERN void dmsetlabelvalue_(DM *dm, char* name, PetscInt *point, PetscInt *value, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 165 { 166 char *lname; 167 168 FIXCHAR(name, lenN, lname); 169 *ierr = DMSetLabelValue(*dm, lname, *point, *value);if (*ierr) return; 170 FREECHAR(name, lname); 171 } 172 173 PETSC_EXTERN void dmgetlabelsize_(DM *dm, char* name, PetscInt *size, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 174 { 175 char *lname; 176 177 FIXCHAR(name, lenN, lname); 178 *ierr = DMGetLabelSize(*dm, lname, size);if (*ierr) return; 179 FREECHAR(name, lname); 180 } 181 182 PETSC_EXTERN void dmgetlabelidis_(DM *dm, char* name, IS *ids, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 183 { 184 char *lname; 185 186 FIXCHAR(name, lenN, lname); 187 *ierr = DMGetLabelIdIS(*dm, lname, ids);if (*ierr) return; 188 FREECHAR(name, lname); 189 } 190 191 PETSC_EXTERN void dmgetlabelname_(DM *dm,PetscInt *n,char* name,PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 192 { 193 const char *tmp; 194 *ierr = DMGetLabelName(*dm,*n,&tmp); 195 *ierr = PetscStrncpy(name,tmp,len);if (*ierr) return; 196 FIXRETURNCHAR(PETSC_TRUE,name,len); 197 } 198 199 PETSC_EXTERN void dmgetlabel_(DM *dm, char* name, DMLabel *label, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 200 { 201 char *lname; 202 203 FIXCHAR(name, lenN, lname); 204 *ierr = DMGetLabel(*dm, lname, label);if (*ierr) return; 205 FREECHAR(name, lname); 206 } 207 208 PETSC_EXTERN void dmgetstratumsize_(DM *dm, char* name, PetscInt *value, PetscInt *size, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 209 { 210 char *lname; 211 212 FIXCHAR(name, lenN, lname); 213 *ierr = DMGetStratumSize(*dm, lname, *value, size);if (*ierr) return; 214 FREECHAR(name, lname); 215 } 216 217 PETSC_EXTERN void dmgetstratumis_(DM *dm, char* name, PetscInt *value, IS *is, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 218 { 219 char *lname; 220 221 FIXCHAR(name, lenN, lname); 222 *ierr = DMGetStratumIS(*dm, lname, *value, is);if (*ierr) return; 223 if (is && !*is) *is = (IS)0; 224 FREECHAR(name, lname); 225 } 226 227 PETSC_EXTERN void dmsetstratumis_(DM *dm, char* name, PetscInt *value, IS *is, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 228 { 229 char *lname; 230 231 FIXCHAR(name, lenN, lname); 232 *ierr = DMSetStratumIS(*dm, lname, *value, *is);if (*ierr) return; 233 FREECHAR(name, lname); 234 } 235 236 PETSC_EXTERN void dmremovelabel_(DM *dm, char* name, DMLabel *label, int *ierr,PETSC_FORTRAN_CHARLEN_T lenN) 237 { 238 char *lname; 239 240 FIXCHAR(name, lenN, lname); 241 *ierr = DMRemoveLabel(*dm, lname, label);if (*ierr) return; 242 FREECHAR(name, lname); 243 } 244 245 PETSC_EXTERN void dmviewfromoptions_(DM *dm,PetscObject obj,char* type,PetscErrorCode *ierr,PETSC_FORTRAN_CHARLEN_T len) 246 { 247 char *t; 248 249 FIXCHAR(type,len,t); 250 CHKFORTRANNULLOBJECT(obj); 251 *ierr = DMViewFromOptions(*dm,obj,t);if (*ierr) return; 252 FREECHAR(type,t); 253 } 254 255 PETSC_EXTERN void dmcreateinterpolation_(DM *dmc,DM *dmf,Mat *mat,Vec *vec, int *ierr) 256 { 257 CHKFORTRANNULLOBJECT(vec); 258 *ierr = DMCreateInterpolation(*dmc,*dmf,mat,vec); 259 } 260 261 PETSC_EXTERN void dmcreatesuperdm_(DM dms[], PetscInt *len, IS ***is, DM *superdm, int *ierr) 262 { 263 *ierr = DMCreateSuperDM(dms, *len, *is, superdm); 264 } 265 266 PETSC_EXTERN void dmdestroy_(DM *x,int *ierr) 267 { 268 PETSC_FORTRAN_OBJECT_F_DESTROYED_TO_C_NULL(x); 269 *ierr = DMDestroy(x); if (*ierr) return; 270 PETSC_FORTRAN_OBJECT_C_NULL_TO_F_DESTROYED(x); 271 } 272