summaryrefslogtreecommitdiffstats
path: root/usr.bin/tip
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>1996-03-04 10:46:29 +0000
committerache <ache@FreeBSD.org>1996-03-04 10:46:29 +0000
commitffc84438c15eb96fea8025b948000f5e7ece8bf8 (patch)
tree7eb6bf880ed7fc18b6c264fbac517e6547c0959d /usr.bin/tip
parentdb042deee509655d1b7e993d4ee283cbda3ceac0 (diff)
downloadFreeBSD-src-ffc84438c15eb96fea8025b948000f5e7ece8bf8.zip
FreeBSD-src-ffc84438c15eb96fea8025b948000f5e7ece8bf8.tar.gz
Eliminate multiply uucplock.c copies
Diffstat (limited to 'usr.bin/tip')
-rw-r--r--usr.bin/tip/tip/Makefile3
-rw-r--r--usr.bin/tip/tip/uucplock.c146
2 files changed, 3 insertions, 146 deletions
diff --git a/usr.bin/tip/tip/Makefile b/usr.bin/tip/tip/Makefile
index 702b52b..c97a929 100644
--- a/usr.bin/tip/tip/Makefile
+++ b/usr.bin/tip/tip/Makefile
@@ -14,6 +14,7 @@ LIBACU=${.CURDIR}/../libacu/libacu.a
.endif
PROG= tip
+CFLAGS+=-DUSE_PERROR
LDADD+= $(LIBACU)
LINKS= ${BINDIR}/tip
MAN1= tip.1
@@ -21,4 +22,6 @@ MAN5= modems.5
SRCS= acu.c acutab.c cmds.c cmdtab.c cu.c hunt.c log.c partab.c \
remote.c tip.c tipout.c uucplock.c value.c vars.c
+.PATH: ${.CURDIR}/../../../sbin/startslip
+
.include <bsd.prog.mk>
diff --git a/usr.bin/tip/tip/uucplock.c b/usr.bin/tip/tip/uucplock.c
deleted file mode 100644
index 5c78bd4..0000000
--- a/usr.bin/tip/tip/uucplock.c
+++ /dev/null
@@ -1,146 +0,0 @@
-/*
- * Copyright (c) 1988, 1993
- * The Regents of the University of California. 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. 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.
- * 3. All advertising materials mentioning features or use of this software
- * must display the following acknowledgement:
- * This product includes software developed by the University of
- * California, Berkeley and its contributors.
- * 4. Neither the name of the University nor the names of its contributors
- * may be used to endorse or promote products derived from this software
- * without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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.
- */
-
-#ifndef lint
-static char sccsid[] = "@(#)uucplock.c 8.1 (Berkeley) 6/6/93";
-#endif /* not lint */
-
-#include <sys/types.h>
-#include <sys/file.h>
-#include <sys/dir.h>
-#include <errno.h>
-
-#include "tipconf.h"
-#include "pathnames.h"
-
-/* Forward declarations */
-static int put_pid (int fd, int pid);
-static int get_pid (int fd);
-
-/*
- * uucp style locking routines
- * return: 0 - success
- * -1 - failure
- */
-
-uu_lock (char *ttyname)
-{
- int fd, pid;
- char tbuf[sizeof(_PATH_LOCKDIRNAME) + MAXNAMLEN];
- off_t lseek();
-
- (void)sprintf(tbuf, _PATH_LOCKDIRNAME, ttyname);
- fd = open(tbuf, O_RDWR|O_CREAT|O_EXCL, 0660);
- if (fd < 0) {
- /*
- * file is already locked
- * check to see if the process holding the lock still exists
- */
- fd = open(tbuf, O_RDWR, 0);
- if (fd < 0) {
- perror("lock open");
- return(-1);
- }
- if ((pid = get_pid (fd)) == -1) {
- (void)close(fd);
- perror("lock read");
- return(-1);
- }
-
- if (kill(pid, 0) == 0 || errno != ESRCH) {
- (void)close(fd); /* process is still running */
- return(-1);
- }
- /*
- * The process that locked the file isn't running, so
- * we'll lock it ourselves
- */
- if (lseek(fd, 0L, L_SET) < 0) {
- (void)close(fd);
- perror("lock lseek");
- return(-1);
- }
- /* fall out and finish the locking process */
- }
- pid = getpid();
- if (!put_pid (fd, pid)) {
- (void)close(fd);
- (void)unlink(tbuf);
- perror("lock write");
- return(-1);
- }
- (void)close(fd);
- return(0);
-}
-
-uu_unlock (char *ttyname)
-{
- char tbuf[sizeof(_PATH_LOCKDIRNAME) + MAXNAMLEN];
-
- (void)sprintf(tbuf, _PATH_LOCKDIRNAME, ttyname);
- return(unlink(tbuf));
-}
-
-static int put_pid (int fd, int pid)
-{
-#if HAVE_V2_LOCKFILES
- return write (fd, (char *)&pid, sizeof (pid)) == sizeof (pid);
-#else
- char buf [32];
- int len;
- len = sprintf (buf, "%10ld\n", (long) pid);
- return write (fd, buf, len) == len;
-#endif
-}
-
-static int get_pid (int fd)
-{
- int bytes_read, pid;
-#if HAVE_V2_LOCKFILES
- bytes_read = read (fd, &pid, sizeof (pid));
- if (bytes_read != sizeof (pid))
- pid = -1;
-#else
- char buf [32];
- bytes_read = read (fd, buf, sizeof (buf) - 1);
- if (bytes_read > 0) {
- buf [bytes_read] = '\0';
- pid = strtol (buf, (char **) NULL, 10);
- }
- else
- pid = -1;
-#endif
- return pid;
-}
-
-/* end of uucplock.c */
OpenPOWER on IntegriCloud