Просмотр исходного кода

provide a BSD'ish strsep(3) to get built under Solaris

Ralf S. Engelschall 23 лет назад
Родитель
Сommit
358e2c5748
2 измененных файлов с 125 добавлено и 1 удалено
  1. 124 0
      cvsps/cvsps.patch
  2. 1 1
      cvsps/cvsps.spec

+ 124 - 0
cvsps/cvsps.patch

@@ -28,3 +28,127 @@
  
  install:
  	[ -d $(prefix)/bin ] || mkdir -p $(prefix)/bin
+--- util.h.orig	Fri Apr 11 16:06:01 2003
++++ util.h	Fri Jul  4 15:23:50 2003
+@@ -19,5 +19,6 @@
+ void timing_stop(const char *);
+ int my_system(const char *);
+ int escape_filename(char *, int, const char *);
++char *my_strsep(char **, const char *);
+ 
+ #endif /* UTIL_H */
+--- util.c.orig	Fri Apr 11 16:06:01 2003
++++ util.c	Fri Jul  4 15:23:31 2003
+@@ -241,3 +241,31 @@
+ 
+     return (*src == 0) ? 0 : -1;
+ }
++
++char *my_strsep(char **stringp, const char *delim)
++{
++	char *s;
++	const char *spanp;
++	int c, sc;
++	char *tok;
++
++	if ((s = *stringp) == NULL)
++		return NULL;
++	for (tok = s;;) {
++		c = *s++;
++		spanp = delim;
++		do {
++			if ((sc = *spanp++) == c) {
++				if (c == 0)
++					s = NULL;
++				else
++					s[-1] = 0;
++				*stringp = s;
++				return tok;
++			}
++		} while (sc != 0);
++	}
++	/* NOTREACHED */
++    return NULL;
++}
++
+--- cache.c.orig	Fri Apr 11 16:06:01 2003
++++ cache.c	Fri Jul  4 15:24:33 2003
+@@ -361,7 +361,7 @@
+ 
+     strcpy(buff, p_buff);
+ 
+-    while ((s = strsep(&p, ";")))
++    while ((s = my_strsep(&p, ";")))
+     {
+ 	char * c = strchr(s, ':');
+ 
+--- cvs_direct.c.orig	Fri Apr 11 16:06:02 2003
++++ cvs_direct.c	Fri Jul  4 15:25:08 2003
+@@ -92,12 +92,12 @@
+ 
+     strcpy(root, p_root);
+ 
+-    tok = strsep(&p, ":");
++    tok = my_strsep(&p, ":");
+ 
+     /* if root string looks like :pserver:... then the first token will be empty */
+     if (strlen(tok) == 0)
+     {
+-	char * method = strsep(&p, ":");
++	char * method = my_strsep(&p, ":");
+ 	if (strcmp(method, "pserver") == 0)
+ 	{
+ 	    ctx = open_ctx_pserver(ctx, p);
+@@ -185,14 +185,14 @@
+ 
+     strcpy(root, p_root);
+ 
+-    tok = strsep(&p, ":");
++    tok = my_strsep(&p, ":");
+     if (strlen(tok) == 0 || !p)
+     {
+ 	debug(DEBUG_APPERROR, "parse error on third token");
+ 	goto out_free_err;
+     }
+ 
+-    tok2 = strsep(&tok, "@");
++    tok2 = my_strsep(&tok, "@");
+     if (!strlen(tok2) || (!tok || !strlen(tok)))
+     {
+ 	debug(DEBUG_APPERROR, "parse error on user@server in pserver");
+@@ -272,7 +272,7 @@
+     strcpy(root, p_root);
+ 
+     /* if there's a ':', it's remote */
+-    tok = strsep(&p, ":");
++    tok = my_strsep(&p, ":");
+ 
+     if (p)
+     {
+@@ -281,7 +281,7 @@
+ 	if (!cvs_rsh)
+ 	    cvs_rsh = "rsh";
+ 
+-	tok2 = strsep(&tok, "@");
++	tok2 = my_strsep(&tok, "@");
+ 
+ 	if (tok)
+ 	    snprintf(execcmd, PATH_MAX, "%s -l %s %s %s server", cvs_rsh, tok2, tok, cvs_server);
+@@ -771,7 +771,7 @@
+ static int parse_patch_arg(char * arg, char ** str)
+ {
+     char *tok, *tok2 = "";
+-    tok = strsep(str, " ");
++    tok = my_strsep(str, " ");
+     if (!tok)
+ 	return 0;
+ 
+@@ -791,7 +791,7 @@
+     /* see if command wants two args and they're separated by ' ' */
+     if (tok[2] == 0 && strchr("BdDFgiorVxYz", tok[1]))
+     {
+-	tok2 = strsep(str, " ");
++	tok2 = my_strsep(str, " ");
+ 	if (!tok2)
+ 	{
+ 	    debug(DEBUG_APPERROR, "diff_opts parse_error: argument %s requires two arguments", tok);

+ 1 - 1
cvsps/cvsps.spec

@@ -33,7 +33,7 @@ Distribution: OpenPKG [EVAL]
 Group:        SCM
 License:      GPL
 Version:      2.0rc1
-Release:      20030702
+Release:      20030704
 
 #   list of sources
 Source0:      http://www.cobite.com/cvsps/cvsps-%{version}.tar.gz