summaryrefslogtreecommitdiff
path: root/usr.bin/rcs/merge.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/rcs/merge.c')
-rw-r--r--usr.bin/rcs/merge.c88
1 files changed, 88 insertions, 0 deletions
diff --git a/usr.bin/rcs/merge.c b/usr.bin/rcs/merge.c
new file mode 100644
index 00000000000..b879aacfc2b
--- /dev/null
+++ b/usr.bin/rcs/merge.c
@@ -0,0 +1,88 @@
+/* $OpenBSD: merge.c,v 1.1 2006/05/10 14:28:17 xsa Exp $ */
+/*
+ * Copyright (c) 2006 Xavier Santolaria <xsa@openbsd.org>
+ * All rights reserved.
+ *
+ * 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. The name of the author may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
+ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
+ * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
+ * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+ * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include "includes.h"
+
+#include "rcsprog.h"
+#include "diff.h"
+
+int
+merge_main(int argc, char **argv)
+{
+ int ch, flags, labels;
+ char *label[3];
+ extern char *optarg;
+ extern int optind;
+
+ flags = labels = 0;
+
+ /*
+ * Using getopt(3) and not rcs_getopt() because merge(1)
+ * allows spaces between options and their arguments.
+ * Thus staying compatible with former implementation.
+ */
+ while ((ch = getopt(argc, argv, "AEeL:pqV")) != -1) {
+ switch(ch) {
+ case 'A': case 'E': case 'e':
+ break;
+ case 'L':
+ if (3 <= labels)
+ errx(D_ERROR, "too many -L options");
+ label[labels++] = optarg;
+ break;
+ case 'p':
+ flags |= PIPEOUT;
+ break;
+ case 'q':
+ flags |= QUIET;
+ break;
+ case 'V':
+ printf("%s\n", rcs_version);
+ exit(0);
+ default:
+ (usage)();
+ exit(D_ERROR);
+ }
+ }
+ argc -= optind;
+ argv += optind;
+
+ if (argc != 3) {
+ warnx("%s arguments", (argc < 3) ? "not enough" : "too many");
+ (usage)();
+ exit(D_ERROR);
+ }
+
+ return (0);
+}
+
+void
+merge_usage(void)
+{
+ (void)fprintf(stderr,
+ "usage: merge [-AeEpqV] [-L lab [-L lab [-L lab]]] "
+ "file1 file2 file3\n");
+}