1993-08-26 01:19:55 +00:00
|
|
|
#ifndef lint
|
1997-10-08 07:48:21 +00:00
|
|
|
static const char rcsid[] =
|
1999-08-28 01:35:59 +00:00
|
|
|
"$FreeBSD$";
|
1993-08-26 01:19:55 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* FreeBSD install - a package for the installation and maintainance
|
|
|
|
* of non-core utilities.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* Jordan K. Hubbard
|
|
|
|
* 18 July 1993
|
|
|
|
*
|
|
|
|
* Miscellaneous string utilities.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "lib.h"
|
|
|
|
|
1994-11-17 10:51:51 +00:00
|
|
|
/* Return the filename portion of a path */
|
|
|
|
char *
|
|
|
|
basename_of(char *str)
|
|
|
|
{
|
|
|
|
char *basename = str + strlen(str) - 1;
|
|
|
|
|
|
|
|
while (basename != str && basename[-1] != '/')
|
|
|
|
--basename;
|
|
|
|
return basename;
|
|
|
|
}
|
|
|
|
|
1995-10-25 15:38:37 +00:00
|
|
|
char *
|
|
|
|
strconcat(char *s1, char *s2)
|
|
|
|
{
|
|
|
|
static char tmp[FILENAME_MAX];
|
|
|
|
|
|
|
|
tmp[0] = '\0';
|
|
|
|
strncpy(tmp, s1 ? s1 : s2, FILENAME_MAX);
|
|
|
|
if (s1 && s2)
|
|
|
|
strncat(tmp, s2, FILENAME_MAX - strlen(tmp));
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
|
1994-11-17 10:51:51 +00:00
|
|
|
/* Get a string parameter as a file spec or as a "contents follow -" spec */
|
1993-08-26 01:19:55 +00:00
|
|
|
char *
|
|
|
|
get_dash_string(char **str)
|
|
|
|
{
|
|
|
|
char *s = *str;
|
|
|
|
|
|
|
|
if (*s == '-')
|
|
|
|
*str = copy_string(s + 1);
|
|
|
|
else
|
1995-04-26 15:08:23 +00:00
|
|
|
*str = fileGetContents(s);
|
1993-08-26 01:19:55 +00:00
|
|
|
return *str;
|
|
|
|
}
|
|
|
|
|
1994-11-17 10:51:51 +00:00
|
|
|
/* Rather Obvious */
|
1993-08-26 01:19:55 +00:00
|
|
|
char *
|
|
|
|
copy_string(char *str)
|
|
|
|
{
|
|
|
|
char *ret;
|
|
|
|
|
|
|
|
if (!str)
|
|
|
|
ret = NULL;
|
|
|
|
else {
|
|
|
|
ret = (char *)malloc(strlen(str) + 1);
|
|
|
|
strcpy(ret, str);
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Return TRUE if 'str' ends in suffix 'suff' */
|
|
|
|
Boolean
|
|
|
|
suffix(char *str, char *suff)
|
|
|
|
{
|
|
|
|
char *idx;
|
|
|
|
Boolean ret = FALSE;
|
|
|
|
|
2000-10-22 09:53:27 +00:00
|
|
|
idx = strrchr(str, '.');
|
1993-08-26 01:19:55 +00:00
|
|
|
if (idx && !strcmp(idx + 1, suff))
|
|
|
|
ret = TRUE;
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Assuming str has a suffix, brutally murder it! */
|
|
|
|
void
|
|
|
|
nuke_suffix(char *str)
|
|
|
|
{
|
|
|
|
char *idx;
|
|
|
|
|
2000-10-22 09:53:27 +00:00
|
|
|
idx = strrchr(str, '.');
|
1993-08-26 01:19:55 +00:00
|
|
|
if (idx)
|
|
|
|
*idx = '\0'; /* Yow! Don't try this on a const! */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Lowercase a whole string */
|
|
|
|
void
|
|
|
|
str_lowercase(char *str)
|
|
|
|
{
|
|
|
|
while (*str) {
|
|
|
|
*str = tolower(*str);
|
|
|
|
++str;
|
|
|
|
}
|
|
|
|
}
|
2001-03-23 18:45:24 +00:00
|
|
|
|
|
|
|
char *
|
|
|
|
get_string(char *str, int max, FILE *fp)
|
|
|
|
{
|
|
|
|
int len;
|
|
|
|
|
|
|
|
if (!str)
|
|
|
|
return NULL;
|
|
|
|
str[0] = '\0';
|
|
|
|
while (fgets(str, max, fp)) {
|
|
|
|
len = strlen(str);
|
|
|
|
while (len && isspace(str[len - 1]))
|
|
|
|
str[--len] = '\0';
|
|
|
|
if (len)
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|