xref: /petsc/src/sys/fileio/fpath.c (revision 45082d6442ec9e1b1f93dc9865927cf3ea3aa1d4)
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);}
52e5c89e4eSSatish Balay     PetscFunctionReturn(0);
53e5c89e4eSSatish Balay   }
54e5c89e4eSSatish Balay   ierr = PetscGetWorkingDirectory(fullpath,flen);CHKERRQ(ierr);
55e5c89e4eSSatish Balay   ierr = PetscStrlen(fullpath,&ln);CHKERRQ(ierr);
56e5c89e4eSSatish Balay   ierr = PetscStrncat(fullpath,"/",flen - ln);CHKERRQ(ierr);
57e5c89e4eSSatish Balay   if (path[0] == '.' && path[1] == '/') {
58e5c89e4eSSatish Balay     ierr = PetscStrlen(fullpath,&ln);CHKERRQ(ierr);
59e5c89e4eSSatish Balay     ierr = PetscStrncat(fullpath,path+2,flen - ln - 1);CHKERRQ(ierr);
60e5c89e4eSSatish Balay   } else {
61e5c89e4eSSatish Balay     ierr = PetscStrlen(fullpath,&ln);CHKERRQ(ierr);
62e5c89e4eSSatish Balay     ierr = PetscStrncat(fullpath,path,flen - ln - 1);CHKERRQ(ierr);
63e5c89e4eSSatish Balay   }
64e5c89e4eSSatish Balay 
65e5c89e4eSSatish Balay   /* Remove the various "special" forms (~username/ and ~/) */
66e5c89e4eSSatish Balay   if (fullpath[0] == '~') {
67*45082d64SJed Brown     char tmppath[PETSC_MAX_PATH_LEN],*rest;
68e5c89e4eSSatish Balay     if (fullpath[1] == '/') {
69*45082d64SJed Brown       ierr = PetscGetHomeDirectory(tmppath,PETSC_MAX_PATH_LEN);CHKERRQ(ierr);
70*45082d64SJed Brown       rest = fullpath + 2;
71e5c89e4eSSatish Balay     } else {
72*45082d64SJed Brown #if defined(PETSC_HAVE_PWD_H)
73*45082d64SJed Brown       struct passwd  *pwde;
74e5c89e4eSSatish Balay       char *p,*name;
75e5c89e4eSSatish Balay 
76e5c89e4eSSatish Balay       /* Find username */
77e5c89e4eSSatish Balay       name = fullpath + 1;
78e5c89e4eSSatish Balay       p    = name;
79e5c89e4eSSatish Balay       while (*p && *p != '/') p++;
80*45082d64SJed Brown       *p   = 0;
81*45082d64SJed Brown       rest = p + 1;
82e5c89e4eSSatish Balay       pwde = getpwnam(name);
83e5c89e4eSSatish Balay       if (!pwde) PetscFunctionReturn(0);
84e5c89e4eSSatish Balay 
85e5c89e4eSSatish Balay       ierr = PetscStrcpy(tmppath,pwde->pw_dir);CHKERRQ(ierr);
86*45082d64SJed Brown #else
87*45082d64SJed Brown       PetscFunctionReturn(0);
88*45082d64SJed Brown #endif
89*45082d64SJed Brown     }
90e5c89e4eSSatish Balay     ierr = PetscStrlen(tmppath,&ln);CHKERRQ(ierr);
91e5c89e4eSSatish Balay     if (tmppath[ln-1] != '/') {ierr = PetscStrcat(tmppath+ln-1,"/");CHKERRQ(ierr);}
92*45082d64SJed Brown     ierr = PetscStrcat(tmppath,rest);CHKERRQ(ierr);
93e5c89e4eSSatish Balay     ierr = PetscStrncpy(fullpath,tmppath,flen);CHKERRQ(ierr);
94e5c89e4eSSatish Balay   }
95e5c89e4eSSatish Balay   /* Remove the automounter part of the path */
96e5c89e4eSSatish Balay   ierr = PetscStrncmp(fullpath,"/tmp_mnt/",9,&flg);CHKERRQ(ierr);
97e5c89e4eSSatish Balay   if (flg) {
98e5c89e4eSSatish Balay     char tmppath[PETSC_MAX_PATH_LEN];
99e5c89e4eSSatish Balay     ierr = PetscStrcpy(tmppath,fullpath + 8);CHKERRQ(ierr);
100e5c89e4eSSatish Balay     ierr = PetscStrcpy(fullpath,tmppath);CHKERRQ(ierr);
101e5c89e4eSSatish Balay   }
102e5c89e4eSSatish Balay   /* We could try to handle things like the removal of .. etc */
103e5c89e4eSSatish Balay   PetscFunctionReturn(0);
104e5c89e4eSSatish Balay }
105