2: /* 3: Code for manipulating files. 4: */ 5: #include <petscsys.h> 7: /*@C 8: PetscGetHomeDirectory - Returns the name of the user's home directory 10: Not Collective 12: Input Parameter: 13: . maxlen - maximum length allowed 15: Output Parameter: 16: . dir - contains the home directory. Must be long enough to hold the name. 18: Level: developer 20: Notes: 21: If PETSc cannot determine the home directory it makes `dir` an empty string 23: On Microsoft Windows machines the environmental variable `HOME` specifies the home directory. 25: .seealso: `PetscGetTmp()`, `PetscSharedTmp()`, `PetscGetWorkingDirectory()` 26: @*/ 27: PetscErrorCode PetscGetHomeDirectory(char dir[], size_t maxlen) 28: { 29: const char *d1; 31: PetscFunctionBegin; 32: d1 = getenv("HOME"); 33: if (d1) { 34: PetscCall(PetscStrncpy(dir, d1, maxlen)); 35: } else if (maxlen > 0) dir[0] = 0; 36: PetscFunctionReturn(PETSC_SUCCESS); 37: } 39: /*@C 40: PetscFixFilename - Fixes a file name so that it is correct for both Unix and 41: Microsoft Windows by using the correct / or \ to separate directories. 43: Not Collective 45: Input Parameter: 46: . filein - name of file to be fixed 48: Output Parameter: 49: . fileout - the fixed name. Should long enough to hold the filename. 51: Level: developer 53: @*/ 54: PetscErrorCode PetscFixFilename(const char filein[], char fileout[]) 55: { 56: size_t i, n; 58: PetscFunctionBegin; 59: if (!filein || !fileout) PetscFunctionReturn(PETSC_SUCCESS); 61: PetscCall(PetscStrlen(filein, &n)); 62: for (i = 0; i < n; i++) { 63: if (filein[i] == PETSC_REPLACE_DIR_SEPARATOR) fileout[i] = PETSC_DIR_SEPARATOR; 64: else fileout[i] = filein[i]; 65: } 66: fileout[n] = 0; 67: PetscFunctionReturn(PETSC_SUCCESS); 68: }