* cygpath.cc (main): Add -a -o and -c options.

(doit): Ditto.
This commit is contained in:
Christopher Faylor 2000-04-13 05:23:30 +00:00
parent ac5ec41ef6
commit 418068d4b0
2 changed files with 71 additions and 13 deletions

View File

@ -1,3 +1,8 @@
Thu Apr 13 01:22:35 2000 Christopher Faylor <cgf@cygnus.com>
* cygpath.cc (main): Add -a -o and -c options.
(doit): Ditto.
Mon Apr 10 22:56:07 2000 Christopher Faylor <cgf@cygnus.com> Mon Apr 10 22:56:07 2000 Christopher Faylor <cgf@cygnus.com>
* cygpath.cc (main): Add -f option for processing a group of paths from * cygpath.cc (main): Add -f option for processing a group of paths from

View File

@ -16,14 +16,21 @@ details. */
#include <io.h> #include <io.h>
#include <sys/fcntl.h> #include <sys/fcntl.h>
#include <sys/cygwin.h> #include <sys/cygwin.h>
#include <ctype.h>
#include <windows.h>
static char *prog_name; static char *prog_name;
static char *file_arg; static char *file_arg;
static char *close_arg;
static int path_flag, unix_flag, windows_flag, absolute_flag;
static struct option long_options[] = static struct option long_options[] =
{ {
{ (char *) "help", no_argument, NULL, 'h' }, { (char *) "help", no_argument, NULL, 'h' },
{ (char *) "absolute", no_argument, NULL, 'a'},
{ (char *) "option", no_argument, NULL, 'o'},
{ (char *) "path", no_argument, NULL, 'p' }, { (char *) "path", no_argument, NULL, 'p' },
{ (char *) "close", required_argument, (int *) &close_arg, 'c'},
{ (char *) "unix", no_argument, NULL, 'u' }, { (char *) "unix", no_argument, NULL, 'u' },
{ (char *) "file", required_argument, (int *) &file_arg, 'f'}, { (char *) "file", required_argument, (int *) &file_arg, 'f'},
{ (char *) "version", no_argument, NULL, 'v' }, { (char *) "version", no_argument, NULL, 'v' },
@ -36,16 +43,18 @@ usage (FILE *stream, int status)
{ {
fprintf (stream, "\ fprintf (stream, "\
Usage: %s [-p|--path] (-u|--unix)|(-w|--windows) filename\n\ Usage: %s [-p|--path] (-u|--unix)|(-w|--windows) filename\n\
-f|--file read file for path information\n\ -a|--absolute output absolute path\n\
-u|--unix print Unix form of filename\n\ -c|--close handle close handle (for use in captured process)\n\
-w|--windows print Windows form of filename\n\ -f|--file file read file for path information\n\
-p|--path filename argument is a path\n", -u|--unix print Unix form of filename\n\
-w|--windows print Windows form of filename\n\
-p|--path filename argument is a path\n",
prog_name); prog_name);
exit (status); exit (status);
} }
static void static void
doit (char *filename, int path_flag, int unix_flag, int windows_flag) doit (char *filename)
{ {
char *buf; char *buf;
size_t len; size_t len;
@ -92,9 +101,9 @@ doit (char *filename, int path_flag, int unix_flag, int windows_flag)
else else
{ {
if (unix_flag) if (unix_flag)
cygwin_conv_to_posix_path (filename, buf); (absolute_flag ? cygwin_conv_to_full_posix_path : cygwin_conv_to_posix_path) (filename, buf);
else else
cygwin_conv_to_win32_path (filename, buf); (absolute_flag ? cygwin_conv_to_full_win32_path : cygwin_conv_to_win32_path) (filename, buf);
} }
puts (buf); puts (buf);
@ -103,8 +112,8 @@ doit (char *filename, int path_flag, int unix_flag, int windows_flag)
int int
main (int argc, char **argv) main (int argc, char **argv)
{ {
int path_flag, unix_flag, windows_flag;
int c; int c;
int options_from_file_flag;
char *filename; char *filename;
prog_name = strrchr (argv[0], '/'); prog_name = strrchr (argv[0], '/');
@ -116,15 +125,28 @@ main (int argc, char **argv)
path_flag = 0; path_flag = 0;
unix_flag = 0; unix_flag = 0;
windows_flag = 0; windows_flag = 0;
while ((c = getopt_long (argc, argv, (char *) "hf:puvw", long_options, (int *) NULL)) options_from_file_flag = 0;
while ((c = getopt_long (argc, argv, (char *) "hac:f:opuvw", long_options, (int *) NULL))
!= EOF) != EOF)
{ {
switch (c) switch (c)
{ {
case 'a':
absolute_flag = 1;
break;
case 'c':
CloseHandle ((HANDLE) strtoul (optarg, NULL, 16));
break;
case 'f': case 'f':
file_arg = optarg; file_arg = optarg;
break; break;
case 'o':
options_from_file_flag = 1;
break;
case 'p': case 'p':
path_flag = 1; path_flag = 1;
break; break;
@ -156,7 +178,10 @@ main (int argc, char **argv)
} }
} }
if (! unix_flag && ! windows_flag) if (options_from_file_flag && !file_arg)
usage (stderr, 1);
if (! unix_flag && ! windows_flag && !options_from_file_flag)
usage (stderr, 1); usage (stderr, 1);
if (!file_arg) if (!file_arg)
@ -165,7 +190,7 @@ main (int argc, char **argv)
usage (stderr, 1); usage (stderr, 1);
filename = argv[optind]; filename = argv[optind];
doit (filename, path_flag, unix_flag, windows_flag); doit (filename);
} }
else else
{ {
@ -188,12 +213,40 @@ main (int argc, char **argv)
exit (1); exit (1);
} }
setbuf (stdout, NULL);
while (fgets (buf, sizeof (buf), fp) != NULL) while (fgets (buf, sizeof (buf), fp) != NULL)
{ {
char *p = strchr (buf, '\n'); char *s = buf;
char *p = strchr (s, '\n');
if (p) if (p)
*p = '\0'; *p = '\0';
doit (buf, path_flag, unix_flag, windows_flag); if (options_from_file_flag && *s == '-')
{
char c;
for (c = *++s; c && !isspace (c); c = *++s)
switch (c)
{
case 'a':
absolute_flag = 1;
break;
case 'w':
unix_flag = 0;
windows_flag = 1;
break;
case 'u':
windows_flag = 0;
unix_flag = 1;
break;
case 'p':
path_flag = 1;
}
if (*s)
do
s++;
while (*s && isspace (*s));
}
if (*s)
doit (s);
} }
} }