mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-03-04 14:06:13 +08:00
* cygpath.cc: Reformat.
* cygpath.cc (print_version): New function. (main): Accommodate new version function. Initialize 'o' to prevent warning. * cygcheck.cc (main): Eliminate non-GNU formatting glitch.
This commit is contained in:
parent
9420d2b833
commit
6a34460970
@ -1,3 +1,17 @@
|
|||||||
|
2002-03-06 Christopher Faylor <cgf@redhat.com>
|
||||||
|
|
||||||
|
* cygpath.cc: Reformat.
|
||||||
|
|
||||||
|
2002-02-27 Joshua Daniel Franklin <joshuadfranklin@yahoo.com>
|
||||||
|
|
||||||
|
* cygpath.cc (print_version): New function.
|
||||||
|
(main): Accommodate new version function. Initialize 'o' to prevent
|
||||||
|
warning.
|
||||||
|
|
||||||
|
2002-02-27 Christopher Faylor <cgf@redhat.com>
|
||||||
|
|
||||||
|
* cygcheck.cc (main): Eliminate non-GNU formatting glitch.
|
||||||
|
|
||||||
2002-02-27 Christopher Faylor <cgf@redhat.com>
|
2002-02-27 Christopher Faylor <cgf@redhat.com>
|
||||||
|
|
||||||
* ssp.c (help_desk): Fix compiler warning.
|
* ssp.c (help_desk): Fix compiler warning.
|
||||||
|
@ -21,35 +21,36 @@ details. */
|
|||||||
#include <sys/cygwin.h>
|
#include <sys/cygwin.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
|
static const char version[] = "$Revision$";
|
||||||
|
|
||||||
static char *prog_name;
|
static char *prog_name;
|
||||||
static char *file_arg;
|
static char *file_arg;
|
||||||
static char *close_arg;
|
static char *close_arg;
|
||||||
static int path_flag, unix_flag, windows_flag, absolute_flag;
|
static int path_flag, unix_flag, windows_flag, absolute_flag;
|
||||||
static int shortname_flag, ignore_flag, allusers_flag, output_flag;
|
static int shortname_flag, ignore_flag, allusers_flag, output_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 *) "absolute", no_argument, NULL, 'a'},
|
{(char *) "option", no_argument, NULL, 'o'},
|
||||||
{ (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 *) "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' },
|
{(char *) "windows", no_argument, NULL, 'w'},
|
||||||
{ (char *) "windows", no_argument, NULL, 'w' },
|
{(char *) "short-name", no_argument, NULL, 's'},
|
||||||
{ (char *) "short-name", no_argument, NULL, 's' },
|
{(char *) "windir", no_argument, NULL, 'W'},
|
||||||
{ (char *) "windir", no_argument, NULL, 'W' },
|
{(char *) "sysdir", no_argument, NULL, 'S'},
|
||||||
{ (char *) "sysdir", no_argument, NULL, 'S' },
|
{(char *) "ignore", no_argument, NULL, 'i'},
|
||||||
{ (char *) "ignore", no_argument, NULL, 'i' },
|
{(char *) "allusers", no_argument, NULL, 'A'},
|
||||||
{ (char *) "allusers", no_argument, NULL, 'A' },
|
{(char *) "desktop", no_argument, NULL, 'D'},
|
||||||
{ (char *) "desktop", no_argument, NULL, 'D' },
|
{(char *) "smprograms", no_argument, NULL, 'P'},
|
||||||
{ (char *) "smprograms", no_argument, NULL, 'P' },
|
{0, no_argument, 0, 0}
|
||||||
{ 0, no_argument, 0, 0 }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static void
|
static void
|
||||||
usage (FILE *stream, int status)
|
usage (FILE * stream, int status)
|
||||||
{
|
{
|
||||||
if (!ignore_flag || !status)
|
if (!ignore_flag || !status)
|
||||||
fprintf (stream, "\
|
fprintf (stream, "\
|
||||||
@ -67,8 +68,7 @@ Usage: %s [-p|--path] (-u|--unix)|(-w|--windows [-s|--short-name]) filename\n\
|
|||||||
-D|--desktop output `Desktop' directory and exit\n\
|
-D|--desktop output `Desktop' directory and exit\n\
|
||||||
-P|--smprograms output Start Menu `Programs' directory and exit\n\
|
-P|--smprograms output Start Menu `Programs' directory and exit\n\
|
||||||
-S|--sysdir output system directory and exit\n\
|
-S|--sysdir output system directory and exit\n\
|
||||||
-W|--windir output `Windows' directory and exit\n",
|
-W|--windir output `Windows' directory and exit\n", prog_name);
|
||||||
prog_name);
|
|
||||||
exit (ignore_flag ? 0 : status);
|
exit (ignore_flag ? 0 : status);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -92,23 +92,25 @@ get_short_paths (char *path)
|
|||||||
len = GetShortPathName (next, NULL, 0);
|
len = GetShortPathName (next, NULL, 0);
|
||||||
if (len == ERROR_INVALID_PARAMETER)
|
if (len == ERROR_INVALID_PARAMETER)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name, next);
|
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name,
|
||||||
|
next);
|
||||||
exit (2);
|
exit (2);
|
||||||
}
|
}
|
||||||
acc += len+1;
|
acc += len + 1;
|
||||||
}
|
}
|
||||||
sptr = sbuf = (char *) malloc(acc+1);
|
sptr = sbuf = (char *) malloc (acc + 1);
|
||||||
if (sbuf == NULL)
|
if (sbuf == NULL)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: out of memory\n", prog_name);
|
fprintf (stderr, "%s: out of memory\n", prog_name);
|
||||||
exit (1);
|
exit (1);
|
||||||
}
|
}
|
||||||
ptr = path;
|
ptr = path;
|
||||||
for(;;)
|
for (;;)
|
||||||
{
|
{
|
||||||
if (GetShortPathName (ptr, sptr, acc) == ERROR_INVALID_PARAMETER)
|
if (GetShortPathName (ptr, sptr, acc) == ERROR_INVALID_PARAMETER)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name, ptr);
|
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name,
|
||||||
|
ptr);
|
||||||
exit (2);
|
exit (2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,10 +131,11 @@ get_short_name (const char *filename)
|
|||||||
DWORD len = GetShortPathName (filename, NULL, 0);
|
DWORD len = GetShortPathName (filename, NULL, 0);
|
||||||
if (len == ERROR_INVALID_PARAMETER)
|
if (len == ERROR_INVALID_PARAMETER)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name, filename);
|
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name,
|
||||||
|
filename);
|
||||||
exit (2);
|
exit (2);
|
||||||
}
|
}
|
||||||
sbuf = (char *) malloc(++len);
|
sbuf = (char *) malloc (++len);
|
||||||
if (sbuf == NULL)
|
if (sbuf == NULL)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: out of memory\n", prog_name);
|
fprintf (stderr, "%s: out of memory\n", prog_name);
|
||||||
@ -140,7 +143,8 @@ get_short_name (const char *filename)
|
|||||||
}
|
}
|
||||||
if (GetShortPathName (filename, sbuf, len) == ERROR_INVALID_PARAMETER)
|
if (GetShortPathName (filename, sbuf, len) == ERROR_INVALID_PARAMETER)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name, filename);
|
fprintf (stderr, "%s: cannot create short name of %s\n", prog_name,
|
||||||
|
filename);
|
||||||
exit (2);
|
exit (2);
|
||||||
}
|
}
|
||||||
return sbuf;
|
return sbuf;
|
||||||
@ -152,13 +156,11 @@ doit (char *filename)
|
|||||||
char *buf;
|
char *buf;
|
||||||
size_t len;
|
size_t len;
|
||||||
int retval;
|
int retval;
|
||||||
int (*conv_func)(const char *, char *);
|
int (*conv_func) (const char *, char *);
|
||||||
|
|
||||||
if (path_flag)
|
if (path_flag)
|
||||||
{
|
{
|
||||||
if (cygwin_posix_path_list_p (filename)
|
if (cygwin_posix_path_list_p (filename) ? unix_flag : windows_flag)
|
||||||
? unix_flag
|
|
||||||
: windows_flag)
|
|
||||||
{
|
{
|
||||||
/* The path is already in the right format. */
|
/* The path is already in the right format. */
|
||||||
puts (filename);
|
puts (filename);
|
||||||
@ -166,14 +168,14 @@ doit (char *filename)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! path_flag)
|
if (!path_flag)
|
||||||
{
|
{
|
||||||
len = strlen (filename) + 100;
|
len = strlen (filename) + 100;
|
||||||
if (len == 100)
|
if (len == 100)
|
||||||
{
|
{
|
||||||
if (!ignore_flag)
|
if (!ignore_flag)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "%s: can't convert empty path\n", prog_name);
|
fprintf (stderr, "%s: can't convert empty path\n", prog_name);
|
||||||
exit (1);
|
exit (1);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -231,10 +233,32 @@ doit (char *filename)
|
|||||||
puts (buf);
|
puts (buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
print_version ()
|
||||||
|
{
|
||||||
|
const char *v = strchr (version, ':');
|
||||||
|
int len;
|
||||||
|
if (!v)
|
||||||
|
{
|
||||||
|
v = "?";
|
||||||
|
len = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
v += 2;
|
||||||
|
len = strchr (v, ' ') - v;
|
||||||
|
}
|
||||||
|
printf ("\
|
||||||
|
cygpath (cygwin) %.*s\n\
|
||||||
|
Path Conversion Utility\n\
|
||||||
|
Copyright 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.\n\
|
||||||
|
Compiled on %s", len, v, __DATE__);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char **argv)
|
main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
int c, o;
|
int c, o = 0;
|
||||||
int options_from_file_flag;
|
int options_from_file_flag;
|
||||||
char *filename;
|
char *filename;
|
||||||
char buf[MAX_PATH], buf2[MAX_PATH];
|
char buf[MAX_PATH], buf2[MAX_PATH];
|
||||||
@ -257,8 +281,9 @@ main (int argc, char **argv)
|
|||||||
options_from_file_flag = 0;
|
options_from_file_flag = 0;
|
||||||
allusers_flag = 0;
|
allusers_flag = 0;
|
||||||
output_flag = 0;
|
output_flag = 0;
|
||||||
while ((c = getopt_long (argc, argv, (char *) "hac:f:opsSuvwWiDPA", long_options, (int *) NULL))
|
while ((c =
|
||||||
!= EOF)
|
getopt_long (argc, argv, (char *) "hac:f:opsSuvwWiDPA",
|
||||||
|
long_options, (int *) NULL)) != EOF)
|
||||||
{
|
{
|
||||||
switch (c)
|
switch (c)
|
||||||
{
|
{
|
||||||
@ -341,8 +366,7 @@ main (int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'v':
|
case 'v':
|
||||||
printf ("Cygwin path conversion version 1.2\n");
|
print_version ();
|
||||||
printf ("Copyright 1998-2002 Red Hat, Inc.\n");
|
|
||||||
exit (0);
|
exit (0);
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -354,72 +378,76 @@ main (int argc, char **argv)
|
|||||||
|
|
||||||
if (output_flag)
|
if (output_flag)
|
||||||
{
|
{
|
||||||
switch(o) {
|
switch (o)
|
||||||
|
{
|
||||||
case 'D':
|
case 'D':
|
||||||
if (!allusers_flag)
|
if (!allusers_flag)
|
||||||
SHGetSpecialFolderLocation(NULL, CSIDL_DESKTOPDIRECTORY,&id);
|
SHGetSpecialFolderLocation (NULL, CSIDL_DESKTOPDIRECTORY, &id);
|
||||||
else
|
else
|
||||||
SHGetSpecialFolderLocation(NULL, CSIDL_COMMON_DESKTOPDIRECTORY,&id);
|
SHGetSpecialFolderLocation (NULL, CSIDL_COMMON_DESKTOPDIRECTORY,
|
||||||
SHGetPathFromIDList(id, buf);
|
&id);
|
||||||
|
SHGetPathFromIDList (id, buf);
|
||||||
/* This if clause is a Fix for Win95 without any "All Users" */
|
/* This if clause is a Fix for Win95 without any "All Users" */
|
||||||
if ( strlen(buf) == 0 ) {
|
if (strlen (buf) == 0)
|
||||||
SHGetSpecialFolderLocation(NULL, CSIDL_DESKTOPDIRECTORY,&id);
|
{
|
||||||
SHGetPathFromIDList(id, buf);
|
SHGetSpecialFolderLocation (NULL, CSIDL_DESKTOPDIRECTORY, &id);
|
||||||
|
SHGetPathFromIDList (id, buf);
|
||||||
}
|
}
|
||||||
if (!windows_flag)
|
if (!windows_flag)
|
||||||
cygwin_conv_to_posix_path(buf, buf2);
|
cygwin_conv_to_posix_path (buf, buf2);
|
||||||
else
|
else
|
||||||
strcpy(buf2, buf);
|
strcpy (buf2, buf);
|
||||||
printf("%s\n", buf2);
|
printf ("%s\n", buf2);
|
||||||
exit(0);
|
exit (0);
|
||||||
|
|
||||||
case 'P':
|
case 'P':
|
||||||
if (!allusers_flag)
|
if (!allusers_flag)
|
||||||
SHGetSpecialFolderLocation(NULL, CSIDL_PROGRAMS, &id);
|
SHGetSpecialFolderLocation (NULL, CSIDL_PROGRAMS, &id);
|
||||||
else
|
else
|
||||||
SHGetSpecialFolderLocation(NULL, CSIDL_COMMON_PROGRAMS, &id);
|
SHGetSpecialFolderLocation (NULL, CSIDL_COMMON_PROGRAMS, &id);
|
||||||
SHGetPathFromIDList(id, buf);
|
SHGetPathFromIDList (id, buf);
|
||||||
/* This if clause is a Fix for Win95 without any "All Users" */
|
/* This if clause is a Fix for Win95 without any "All Users" */
|
||||||
if ( strlen(buf) == 0 ) {
|
if (strlen (buf) == 0)
|
||||||
SHGetSpecialFolderLocation(NULL, CSIDL_PROGRAMS, &id);
|
{
|
||||||
SHGetPathFromIDList(id, buf);
|
SHGetSpecialFolderLocation (NULL, CSIDL_PROGRAMS, &id);
|
||||||
|
SHGetPathFromIDList (id, buf);
|
||||||
}
|
}
|
||||||
if (!windows_flag)
|
if (!windows_flag)
|
||||||
cygwin_conv_to_posix_path(buf, buf2);
|
cygwin_conv_to_posix_path (buf, buf2);
|
||||||
else
|
else
|
||||||
strcpy(buf2, buf);
|
strcpy (buf2, buf);
|
||||||
printf("%s\n", buf2);
|
printf ("%s\n", buf2);
|
||||||
exit(0);
|
exit (0);
|
||||||
|
|
||||||
case 'S':
|
case 'S':
|
||||||
GetSystemDirectory(buf, MAX_PATH);
|
GetSystemDirectory (buf, MAX_PATH);
|
||||||
FindFirstFile(buf, &w32_fd);
|
FindFirstFile (buf, &w32_fd);
|
||||||
strcpy(strrchr(buf, '\\')+1, w32_fd.cFileName);
|
strcpy (strrchr (buf, '\\') + 1, w32_fd.cFileName);
|
||||||
if (!windows_flag)
|
if (!windows_flag)
|
||||||
cygwin_conv_to_posix_path(buf, buf2);
|
cygwin_conv_to_posix_path (buf, buf2);
|
||||||
else
|
else
|
||||||
strcpy(buf2, buf);
|
strcpy (buf2, buf);
|
||||||
printf("%s\n", buf2);
|
printf ("%s\n", buf2);
|
||||||
exit(0);
|
exit (0);
|
||||||
|
|
||||||
case 'W':
|
case 'W':
|
||||||
GetWindowsDirectory(buf, MAX_PATH);
|
GetWindowsDirectory (buf, MAX_PATH);
|
||||||
if (!windows_flag)
|
if (!windows_flag)
|
||||||
cygwin_conv_to_posix_path(buf, buf2);
|
cygwin_conv_to_posix_path (buf, buf2);
|
||||||
else
|
else
|
||||||
strcpy(buf2, buf);
|
strcpy (buf2, buf);
|
||||||
printf("%s\n", buf2);
|
printf ("%s\n", buf2);
|
||||||
exit(0);
|
exit (0);
|
||||||
|
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "ERROR: main: switch(o)!\n");
|
fprintf (stderr, "ERROR: main: switch (o)!\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (options_from_file_flag && !file_arg)
|
if (options_from_file_flag && !file_arg)
|
||||||
usage (stderr, 1);
|
usage (stderr, 1);
|
||||||
|
|
||||||
if (! unix_flag && ! windows_flag && !options_from_file_flag)
|
if (!unix_flag && !windows_flag && !options_from_file_flag)
|
||||||
usage (stderr, 1);
|
usage (stderr, 1);
|
||||||
|
|
||||||
if (!file_arg)
|
if (!file_arg)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user