aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authormux <mux@FreeBSD.org>2006-02-23 09:25:09 +0800
committermux <mux@FreeBSD.org>2006-02-23 09:25:09 +0800
commit8c109b25058a993d1559fad0eb32baba45b4a56d (patch)
tree194545fdd71fb701499a2e1b1c47fe465b0683ee /net
parent6b2368f8f72ccf19aa242ecf32e9a188fcb4a353 (diff)
downloadfreebsd-ports-graphics-8c109b25058a993d1559fad0eb32baba45b4a56d.tar.gz
freebsd-ports-graphics-8c109b25058a993d1559fad0eb32baba45b4a56d.tar.zst
freebsd-ports-graphics-8c109b25058a993d1559fad0eb32baba45b4a56d.zip
Fix a last minute bug by importing a patch from csup's CVS. We were not
retrying anymore when the server rejects us at login time.
Diffstat (limited to 'net')
-rw-r--r--net/csup/Makefile1
-rw-r--r--net/csup/files/patch-proto.c139
2 files changed, 140 insertions, 0 deletions
diff --git a/net/csup/Makefile b/net/csup/Makefile
index 98ef60ea434..9a7b19c51c7 100644
--- a/net/csup/Makefile
+++ b/net/csup/Makefile
@@ -8,6 +8,7 @@
PORTNAME= csup
PORTVERSION= 20060223
+PORTREVISION= 1
CATEGORIES= net devel
MASTER_SITES= http://www.mu.org/~mux/
DISTNAME= ${PORTNAME}-snap-${PORTVERSION}
diff --git a/net/csup/files/patch-proto.c b/net/csup/files/patch-proto.c
new file mode 100644
index 00000000000..ea005c85c36
--- /dev/null
+++ b/net/csup/files/patch-proto.c
@@ -0,0 +1,139 @@
+--- proto.c.bak 22 Feb 2006 23:22:04 -0000 1.75
++++ proto.c 23 Feb 2006 01:20:53 -0000 1.76
+@@ -23,7 +23,7 @@
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+- * $FreeBSD: /tmp/pcvs/ports/net/csup/files/Attic/patch-proto.c,v 1.1 2006-02-23 01:25:09 mux Exp $
++ * $FreeBSD: /tmp/pcvs/ports/net/csup/files/Attic/patch-proto.c,v 1.1 2006-02-23 01:25:09 mux Exp $
+ */
+
+ #include <sys/param.h>
+@@ -196,15 +196,15 @@ proto_greet(struct config *config)
+ if (msg == NULL)
+ goto bad;
+ lprintf(-1, "Rejected by server: %s\n", msg);
+- return (-1);
++ return (STATUS_TRANSIENTFAILURE);
+ } else
+ goto bad;
+ lprintf(2, "Server software version: %s\n",
+ swver != NULL ? swver : ".");
+- return (0);
++ return (STATUS_SUCCESS);
+ bad:
+ lprintf(-1, "Invalid greeting from server\n");
+- return (-1);
++ return (STATUS_FAILURE);
+ }
+
+ /* Negotiate protocol version with the server. */
+@@ -236,12 +236,12 @@ proto_negproto(struct config *config)
+ if (maj != PROTO_MAJ || min != PROTO_MIN) {
+ lprintf(-1, "Server protocol version %d.%d not supported "
+ "by client\n", maj, min);
+- return (1);
++ return (STATUS_FAILURE);
+ }
+- return (0);
++ return (STATUS_SUCCESS);
+ bad:
+ lprintf(-1, "Invalid PROTO command from server\n");
+- return (1);
++ return (STATUS_FAILURE);
+ }
+
+ static int
+@@ -265,24 +265,24 @@ proto_login(struct config *config)
+ if (strcmp(realm, ".") != 0 || strcmp(challenge, ".") != 0) {
+ lprintf(-1, "Authentication required by the server and not "
+ "supported by client\n");
+- return (1);
++ return (STATUS_FAILURE);
+ }
+ proto_printf(s, "AUTHMD5 . . .\n");
+ stream_flush(s);
+ line = stream_getln(s, NULL);
+ cmd = proto_get_ascii(&line);
+ if (strcmp(cmd, "OK") == 0)
+- return (0);
++ return (STATUS_SUCCESS);
+ if (strcmp(cmd, "!") == 0) {
+ msg = proto_get_rest(&line);
+ if (msg == NULL)
+ goto bad;
+ lprintf(-1, "Server error: %s\n", msg);
+- return (1);
++ return (STATUS_FAILURE);
+ }
+ bad:
+ lprintf(-1, "Invalid server reply to AUTHMD5\n");
+- return (1);
++ return (STATUS_FAILURE);
+ }
+
+ /*
+@@ -327,10 +327,10 @@ proto_fileattr(struct config *config)
+ if (line == NULL || strcmp(line, ".") != 0)
+ goto bad;
+ memcpy(config->fasupport, support, sizeof(config->fasupport));
+- return (0);
++ return (STATUS_SUCCESS);
+ bad:
+ lprintf(-1, "Protocol error negotiating attribute support\n");
+- return (1);
++ return (STATUS_FAILURE);
+ }
+
+ /*
+@@ -422,10 +422,10 @@ proto_xchgcoll(struct config *config)
+ if (line == NULL)
+ goto bad;
+ }
+- return (0);
++ return (STATUS_SUCCESS);
+ bad:
+ lprintf(-1, "Protocol error during collection exchange\n");
+- return (1);
++ return (STATUS_FAILURE);
+ }
+
+ static struct mux *
+@@ -482,7 +482,7 @@ proto_run(struct config *config)
+ struct killer killer;
+ struct threads *workers;
+ struct mux *m;
+- int error, i, status;
++ int i, status;
+
+ /*
+ * We pass NULL for the close() function because we'll reuse
+@@ -490,17 +490,17 @@ proto_run(struct config *config)
+ */
+ config->server = stream_open_fd(config->socket, stream_read_fd,
+ stream_write_fd, NULL);
+- error = proto_greet(config);
+- if (!error)
+- error = proto_negproto(config);
+- if (!error)
+- error = proto_login(config);
+- if (!error)
+- error = proto_fileattr(config);
+- if (!error)
+- error = proto_xchgcoll(config);
+- if (error)
+- return (STATUS_FAILURE);
++ status = proto_greet(config);
++ if (status == STATUS_SUCCESS)
++ status = proto_negproto(config);
++ if (status == STATUS_SUCCESS)
++ status = proto_login(config);
++ if (status == STATUS_SUCCESS)
++ status = proto_fileattr(config);
++ if (status == STATUS_SUCCESS)
++ status = proto_xchgcoll(config);
++ if (status != STATUS_SUCCESS)
++ return (status);
+
+ /* Multi-threaded action starts here. */
+ m = proto_mux(config);