Add define for Kirk Smith's USR Courier driver. Change default baud
[unix-history] / usr / src / usr.bin / window / tttermcap.c
index 044b643..5e5114e 100644 (file)
@@ -1,10 +1,18 @@
 #ifndef lint
 #ifndef lint
-static char sccsid[] = "@(#)tttermcap.c        3.4 %G%";
+static char sccsid[] = "@(#)tttermcap.c        3.6 %G%";
 #endif
 
 #endif
 
+/*
+ * Copyright (c) 1983 Regents of the University of California,
+ * All rights reserved.  Redistribution permitted subject to
+ * the terms of the Berkeley Software License Agreement.
+ */
+
 #include "tt.h"
 
 char *tgetstr();
 #include "tt.h"
 
 char *tgetstr();
+char *tgoto();
+char *malloc();
 
 tttputc(c)
 {
 
 tttputc(c)
 {
@@ -16,18 +24,46 @@ ttxputc(c)
        *tt_strp++ = c;
 }
 
        *tt_strp++ = c;
 }
 
-char *
+struct tt_str *
+tttgetstr(str)
+       char *str;
+{
+       register struct tt_str *s;
+
+       if ((str = tgetstr(str, &tt_strp)) == 0)
+               return 0;
+       if ((s = (struct tt_str *) malloc(sizeof *s)) == 0)
+               return 0;
+       s->ts_str = str;
+       s->ts_n = tt_strp - s->ts_str - 1;
+       return s;
+}
+
+struct tt_str *
 ttxgetstr(str)
 ttxgetstr(str)
-char *str;
+       char *str;
 {
 {
+       register struct tt_str *s;
        char buf[100];
        char *bufp = buf;
 
        char buf[100];
        char *bufp = buf;
 
-       str = tgetstr(str, &bufp);
-       if (str == 0)
+       if (tgetstr(str, &bufp) == 0)
+               return 0;
+       if ((s = (struct tt_str *) malloc(sizeof *s)) == 0)
                return 0;
                return 0;
-       str = tt_strp;
+       s->ts_str = tt_strp;
        tputs(buf, 1, ttxputc);
        tputs(buf, 1, ttxputc);
-       ttxputc(0);
-       return str;
+       s->ts_n = tt_strp - s->ts_str;
+       *tt_strp++ = 0;
+       return s;
+}
+
+tttgoto(s, col, row)
+       struct tt_str *s;
+{
+       register char *p = s->ts_str;
+
+       ttputs(tgoto(p, col, row));
+       for (p += s->ts_n; *--p == 0;)
+               ttputc(0);
 }
 }