xref: /petsc/src/sys/fileio/fpath.c (revision 6c8deb012547580a5f44ebdd80b7830052c72993)
17d0a6c19SBarry Smith 
2e5c89e4eSSatish Balay /*
3e5c89e4eSSatish Balay       Code for opening and closing files.
4e5c89e4eSSatish Balay */
5c6db04a5SJed Brown #include <petscsys.h>
6e5c89e4eSSatish Balay #if defined(PETSC_HAVE_PWD_H)
7e5c89e4eSSatish Balay #include <pwd.h>
8e5c89e4eSSatish Balay #endif
9e5c89e4eSSatish Balay #include <ctype.h>
10e5c89e4eSSatish Balay #include <sys/stat.h>
11e5c89e4eSSatish Balay #if defined(PETSC_HAVE_UNISTD_H)
12e5c89e4eSSatish Balay #include <unistd.h>
13e5c89e4eSSatish Balay #endif
14e5c89e4eSSatish Balay #if defined(PETSC_HAVE_SYS_UTSNAME_H)
15e5c89e4eSSatish Balay #include <sys/utsname.h>
16e5c89e4eSSatish Balay #endif
17e5c89e4eSSatish Balay #include <fcntl.h>
18e5c89e4eSSatish Balay #if defined(PETSC_HAVE_SYS_SYSTEMINFO_H)
19e5c89e4eSSatish Balay #include <sys/systeminfo.h>
20e5c89e4eSSatish Balay #endif
21e5c89e4eSSatish Balay 
22e5c89e4eSSatish Balay #undef __FUNCT__
23e5c89e4eSSatish Balay #define __FUNCT__ "PetscGetFullPath"
24e5c89e4eSSatish Balay /*@C
25e5c89e4eSSatish Balay    PetscGetFullPath - Given a filename, returns the fully qualified file name.
26e5c89e4eSSatish Balay 
27e5c89e4eSSatish Balay    Not Collective
28e5c89e4eSSatish Balay 
29e5c89e4eSSatish Balay    Input Parameters:
30e5c89e4eSSatish Balay +  path     - pathname to qualify
31e5c89e4eSSatish Balay .  fullpath - pointer to buffer to hold full pathname
32e5c89e4eSSatish Balay -  flen     - size of fullpath
33e5c89e4eSSatish Balay 
34e5c89e4eSSatish Balay    Level: developer
35e5c89e4eSSatish Balay 
36e5c89e4eSSatish Balay    Concepts: full path
37e5c89e4eSSatish Balay    Concepts: path^full
38e5c89e4eSSatish Balay 
39e5c89e4eSSatish Balay .seealso: PetscGetRelativePath()
40e5c89e4eSSatish Balay @*/
417087cfbeSBarry Smith PetscErrorCode  PetscGetFullPath(const char path[],char fullpath[],size_t flen)
42e5c89e4eSSatish Balay {
43e5c89e4eSSatish Balay   PetscErrorCode ierr;
44e5c89e4eSSatish Balay   size_t         ln;
45ace3abfcSBarry Smith   PetscBool      flg;
46e5c89e4eSSatish Balay 
47e5c89e4eSSatish Balay   PetscFunctionBegin;
48e5c89e4eSSatish Balay   if (path[0] == '/') {
49e5c89e4eSSatish Balay     ierr = PetscStrncmp("/tmp_mnt/",path,9,&flg);CHKERRQ(ierr);
50e5c89e4eSSatish Balay     if (flg) {ierr = PetscStrncpy(fullpath,path + 8,flen);CHKERRQ(ierr);}
51e5c89e4eSSatish Balay     else     {ierr = PetscStrncpy(fullpath,path,flen);CHKERRQ(ierr);}
52*6c8deb01SJed Brown     fullpath[flen-1] = 0;
53e5c89e4eSSatish Balay     PetscFunctionReturn(0);
54e5c89e4eSSatish Balay   }
55e5c89e4eSSatish Balay 
56*6c8deb01SJed Brown   ierr = PetscStrncpy(fullpath,path,flen);CHKERRQ(ierr);
57*6c8deb01SJed Brown   fullpath[flen-1] = 0;
58e5c89e4eSSatish Balay   /* Remove the various "special" forms (~username/ and ~/) */
59e5c89e4eSSatish Balay   if (fullpath[0] == '~') {
6045082d64SJed Brown     char tmppath[PETSC_MAX_PATH_LEN],*rest;
61e5c89e4eSSatish Balay     if (fullpath[1] == '/') {
6245082d64SJed Brown       ierr = PetscGetHomeDirectory(tmppath,PETSC_MAX_PATH_LEN);CHKERRQ(ierr);
6345082d64SJed Brown       rest = fullpath + 2;
64e5c89e4eSSatish Balay     } else {
6545082d64SJed Brown #if defined(PETSC_HAVE_PWD_H)
6645082d64SJed Brown       struct passwd  *pwde;
67e5c89e4eSSatish Balay       char *p,*name;
68e5c89e4eSSatish Balay 
69e5c89e4eSSatish Balay       /* Find username */
70e5c89e4eSSatish Balay       name = fullpath + 1;
71e5c89e4eSSatish Balay       p    = name;
72e5c89e4eSSatish Balay       while (*p && *p != '/') p++;
7345082d64SJed Brown       *p   = 0;
7445082d64SJed Brown       rest = p + 1;
75e5c89e4eSSatish Balay       pwde = getpwnam(name);
76e5c89e4eSSatish Balay       if (!pwde) PetscFunctionReturn(0);
77e5c89e4eSSatish Balay 
78e5c89e4eSSatish Balay       ierr = PetscStrcpy(tmppath,pwde->pw_dir);CHKERRQ(ierr);
7945082d64SJed Brown #else
8045082d64SJed Brown       PetscFunctionReturn(0);
8145082d64SJed Brown #endif
8245082d64SJed Brown     }
83e5c89e4eSSatish Balay     ierr = PetscStrlen(tmppath,&ln);CHKERRQ(ierr);
84e5c89e4eSSatish Balay     if (tmppath[ln-1] != '/') {ierr = PetscStrcat(tmppath+ln-1,"/");CHKERRQ(ierr);}
8545082d64SJed Brown     ierr = PetscStrcat(tmppath,rest);CHKERRQ(ierr);
86e5c89e4eSSatish Balay     ierr = PetscStrncpy(fullpath,tmppath,flen);CHKERRQ(ierr);
87*6c8deb01SJed Brown     fullpath[flen-1] = 0;
88*6c8deb01SJed Brown   } else {
89*6c8deb01SJed Brown     ierr = PetscGetWorkingDirectory(fullpath,flen);CHKERRQ(ierr);
90*6c8deb01SJed Brown     ierr = PetscStrlen(fullpath,&ln);CHKERRQ(ierr);
91*6c8deb01SJed Brown     ierr = PetscStrncpy(fullpath+ln,"/",flen - ln);CHKERRQ(ierr);
92*6c8deb01SJed Brown     fullpath[flen-1] = 0;
93*6c8deb01SJed Brown     ierr = PetscStrlen(fullpath,&ln);CHKERRQ(ierr);
94*6c8deb01SJed Brown     if (path[0] == '.' && path[1] == '/') {
95*6c8deb01SJed Brown       ierr = PetscStrncat(fullpath,path+2,flen - ln - 1);CHKERRQ(ierr);
96*6c8deb01SJed Brown     } else {
97*6c8deb01SJed Brown       ierr = PetscStrncat(fullpath,path,flen - ln - 1);CHKERRQ(ierr);
98e5c89e4eSSatish Balay     }
99*6c8deb01SJed Brown     fullpath[flen-1] = 0;
100*6c8deb01SJed Brown   }
101*6c8deb01SJed Brown 
102e5c89e4eSSatish Balay   /* Remove the automounter part of the path */
103e5c89e4eSSatish Balay   ierr = PetscStrncmp(fullpath,"/tmp_mnt/",9,&flg);CHKERRQ(ierr);
104e5c89e4eSSatish Balay   if (flg) {
105e5c89e4eSSatish Balay     char tmppath[PETSC_MAX_PATH_LEN];
106e5c89e4eSSatish Balay     ierr = PetscStrcpy(tmppath,fullpath + 8);CHKERRQ(ierr);
107e5c89e4eSSatish Balay     ierr = PetscStrcpy(fullpath,tmppath);CHKERRQ(ierr);
108e5c89e4eSSatish Balay   }
109e5c89e4eSSatish Balay   /* We could try to handle things like the removal of .. etc */
110e5c89e4eSSatish Balay   PetscFunctionReturn(0);
111e5c89e4eSSatish Balay }
112