]>
diplodocus.org Git - nmh/blob - sbr/path.c
1 /* path.c -- return a pathname
3 * This code is Copyright (c) 2002, by the authors of nmh. See the
4 * COPYRIGHT file in the root directory of the nmh distribution for
5 * complete copyright information.
10 #include "m_maildir.h"
22 static char *expath(char *,int);
23 static void compath(char *);
26 /* Return value must be free(3)'d. */
30 return path(name
+ 1, *name
== '+' ? TFOLDER
: TSUBCWF
);
34 /* Return value must be free(3)'d. */
36 path(char *name
, int flag
)
40 p
= expath(name
, flag
);
41 last
= p
+ strlen(p
) - 1;
42 if (last
> p
&& *last
== '/')
49 /* Return value must be free(3)'d. */
51 expath (char *name
, int flag
)
56 if (flag
== TSUBCWF
) {
57 snprintf (buffer
, sizeof(buffer
), "%s/%s", getfolder (1), name
);
58 name
= m_mailpath (buffer
);
60 snprintf (buffer
, sizeof(buffer
), "%s/", m_maildir (""));
61 if (ssequal (buffer
, name
)) {
63 name
= mh_xstrdup(name
+ strlen(buffer
));
71 && (!has_prefix(name
, CWD
)
73 && strcmp (name
, DOTDOT
)
74 && !has_prefix(name
, PWD
))))
75 return mh_xstrdup(name
);
80 if (strcmp (name
, DOT
) == 0 || strcmp (name
, CWD
) == 0)
81 return mh_xstrdup(pwds
);
83 ep
= pwds
+ strlen (pwds
);
84 if ((cp
= strrchr(pwds
, '/')) == NULL
)
89 if (has_prefix(name
, CWD
))
92 if (strcmp (name
, DOTDOT
) == 0 || strcmp (name
, PWD
) == 0) {
93 snprintf (buffer
, sizeof(buffer
), "%.*s", (int)(cp
- pwds
), pwds
);
94 return mh_xstrdup(buffer
);
97 if (has_prefix(name
, PWD
))
102 snprintf (buffer
, sizeof(buffer
), "%.*s/%s", (int)(cp
- pwds
), pwds
, name
);
103 return mh_xstrdup(buffer
);
128 for (dp
= cp
; *dp
== '/'; dp
++)
134 if (strcmp (cp
, DOT
) == 0) {
140 if (strcmp (cp
, DOTDOT
) == 0) {
141 for (cp
-= 2; cp
> f
; cp
--)
149 if (has_prefix(cp
, PWD
)) {
150 for (dp
= cp
- 2; dp
> f
; dp
--)
155 strcpy (dp
, cp
+ LEN(PWD
) - 1);
159 if (has_prefix(cp
, CWD
)) {
160 strcpy (cp
- 1, cp
+ LEN(CWD
) - 1);