diff options
author | db <db@FreeBSD.org> | 2007-12-22 00:55:15 +0800 |
---|---|---|
committer | db <db@FreeBSD.org> | 2007-12-22 00:55:15 +0800 |
commit | cb1d3355978cef9bb2bf7796eaf510f840e2f146 (patch) | |
tree | 0e8e227ce11a10305d8ee8df845b84419e50b91f | |
parent | a98ef94dd8c66fb00a99bb099c4633622b71d8e3 (diff) | |
download | freebsd-ports-gnome-cb1d3355978cef9bb2bf7796eaf510f840e2f146.tar.gz freebsd-ports-gnome-cb1d3355978cef9bb2bf7796eaf510f840e2f146.tar.zst freebsd-ports-gnome-cb1d3355978cef9bb2bf7796eaf510f840e2f146.zip |
The KB contest logging computer program runs on the Linux operating system
with the Gnome desktop. The program is under development, and currently
supports the CQ WW, CQ WPX, and ARRL DX contests, plus Field Day.
Features include on-the-fly dupe checking, CW and voice message keying,
super check partial, packet (Telnet and rf nodes), networking, and
radio control (currently for the FT-1000 only). The program is designed
to be used by U.S. stations, with some support for Canadian stations.
New features and contests are being added regularly, and I will consider
adding support for DX stations if there is sufficient demand.
(The port version has bug fixes and some modifications for Canadian stations.
- db)
Submitted by: self
-rw-r--r-- | comms/Makefile | 1 | ||||
-rw-r--r-- | comms/kb/Makefile | 49 | ||||
-rw-r--r-- | comms/kb/distinfo | 6 | ||||
-rw-r--r-- | comms/kb/files/Makefile | 16 | ||||
-rw-r--r-- | comms/kb/files/bsd_bells.c | 163 | ||||
-rw-r--r-- | comms/kb/files/kb | 7 | ||||
-rw-r--r-- | comms/kb/files/kbserver | 34 | ||||
-rw-r--r-- | comms/kb/files/patch-boxes.c | 35 | ||||
-rw-r--r-- | comms/kb/files/patch-elogs.c | 915 | ||||
-rw-r--r-- | comms/kb/files/patch-fields.c | 15 | ||||
-rw-r--r-- | comms/kb/files/patch-globs.h | 27 | ||||
-rw-r--r-- | comms/kb/files/patch-init.c | 150 | ||||
-rw-r--r-- | comms/kb/files/patch-io.c | 533 | ||||
-rw-r--r-- | comms/kb/files/patch-kb.c | 32 | ||||
-rw-r--r-- | comms/kb/files/patch-support.c | 86 | ||||
-rw-r--r-- | comms/kb/files/pkg_message | 8 | ||||
-rw-r--r-- | comms/kb/pkg-descr | 14 | ||||
-rw-r--r-- | comms/kb/pkg-plist | 15 |
18 files changed, 2106 insertions, 0 deletions
diff --git a/comms/Makefile b/comms/Makefile index f8874579869d..25bb23c21eaa 100644 --- a/comms/Makefile +++ b/comms/Makefile @@ -48,6 +48,7 @@ SUBDIR += java-commapi-freebsd SUBDIR += jerm SUBDIR += kallers + SUBDIR += kb SUBDIR += kermit SUBDIR += klog SUBDIR += kmobiletools diff --git a/comms/kb/Makefile b/comms/kb/Makefile new file mode 100644 index 000000000000..f67740970bf4 --- /dev/null +++ b/comms/kb/Makefile @@ -0,0 +1,49 @@ +# New ports collection makefile for: kb +# Date created: June 5, 2007 +# Whom: Diane Bruce <db@db.net> +# +# $FreeBSD$ + +PORTNAME= kb +PORTVERSION= 7.09 +CATEGORIES= comms hamradio +MASTER_SITES= http://www.db.net/downloads/ \ + ${MASTER_SITE_LOCAL} +MASTER_SITE_SUBDIR= db +DISTFILES= kb_src-${PORTVERSION}.tar.gz kb_inst-${PORTVERSION}.tar.gz + +MAINTAINER= db@FreeBSD.org +COMMENT= Amateur Radio contest logger + +USE_XLIB= yes +USE_GNOME= libgnome gtk20 libbonobo +NO_WRKSUBDIR= yes +PKGMESSAGE= ${FILESDIR}/pkg_message + +pre-configure: + @${CP} ${FILESDIR}/Makefile ${WRKSRC} +.if exists(/usr/include/dev/speaker/speaker.h) + @${REINPLACE_CMD} -e 's|-UBSDSOUND|-DBSDSOUND="<dev/speaker/speaker.h>"|' ${WRKSRC}/Makefile +.elif exists(/usr/include/machine/speaker.h) + @${REINPLACE_CMD} -e 's|-UBSDSOUND|-DBSDSOUND="<machine/speaker.h>"|' ${WRKSRC}/Makefile +.endif + @${RM} ${WRKSRC}/kb_server + @${RM} ${WRKSRC}/kb + @${CP} ${FILESDIR}/bsd_bells.c ${WRKSRC} + +do-install: + @${INSTALL_SCRIPT} ${FILESDIR}/kbserver ${LOCALBASE}/etc/rc.d + ${INSTALL_SCRIPT} ${FILESDIR}/kb ${LOCALBASE}/bin + ${INSTALL_PROGRAM} ${WRKSRC}/kb ${LOCALBASE}/bin/kb_bin + ${INSTALL_PROGRAM} ${WRKSRC}/kb_server ${LOCALBASE}/sbin + ${MKDIR} ${DATADIR} +.for f in ${WRKSRC}/COUNTY.CQP ${WRKSRC}/DEFAULT.INI \ + ${WRKSRC}/CALL_LIB.LST ${WRKSRC}/CALL_SS.LST \ + ${WRKSRC}/CALL_FD.LST ${WRKSRC}/HELP.LST \ + ${WRKSRC}/COUNTRY.LST ${WRKSRC}/HELPFD.LST \ + ${WRKSRC}/SECTION.LST ${WRKSRC}/STATE.LST + ${INSTALL_DATA} ${WRKSRC}/$f ${DATADIR} +.endfor + @${CAT} ${PKGMESSAGE} + +.include <bsd.port.mk> diff --git a/comms/kb/distinfo b/comms/kb/distinfo new file mode 100644 index 000000000000..0de283044f71 --- /dev/null +++ b/comms/kb/distinfo @@ -0,0 +1,6 @@ +MD5 (kb_src-7.09.tar.gz) = 2ac7a11e18c245278800f00b9bf3d300 +SHA256 (kb_src-7.09.tar.gz) = 7b6a7a8c8fbe01fbe1086f5b783414b056bf1d5db5945d086a3e7e6de1bfa6f8 +SIZE (kb_src-7.09.tar.gz) = 93896 +MD5 (kb_inst-7.09.tar.gz) = 1984eb53d5ba56b43c188f07de9ae3dd +SHA256 (kb_inst-7.09.tar.gz) = 0890702b3ee182d056e9a33055aa4519fded84b15a67556279173865c1eb10d2 +SIZE (kb_inst-7.09.tar.gz) = 199940 diff --git a/comms/kb/files/Makefile b/comms/kb/files/Makefile new file mode 100644 index 000000000000..8d3d0025cbc1 --- /dev/null +++ b/comms/kb/files/Makefile @@ -0,0 +1,16 @@ +# Makefile for: kb +# +# $FreeBSD$ + +LIBS+= `pkg-config --cflags --libs gtk+-2.0` +LIBS+= `pkg-config --cflags --libs libgnome-2.0` +LIBS+= `pkg-config --cflags --libs bonobo-activation-2.0` + +all: kb_server kb + +kb_server: kb_server.c + ${CC} ${CFLAGS} -o kb_server kb_server.c -lm + +kb: boxes.c fboxes.c kb.c radio.c bsd_bells.c fields.c sboxes.c \ + couzon.c init.c kb_server.c support.c elogs.c io.c network.c tree.c + ${CC} ${CFLAGS} -I. ${LIBS} kb.c -UBSDSOUND -o kb diff --git a/comms/kb/files/bsd_bells.c b/comms/kb/files/bsd_bells.c new file mode 100644 index 000000000000..86661c57bac2 --- /dev/null +++ b/comms/kb/files/bsd_bells.c @@ -0,0 +1,163 @@ +#ifdef DEBUG_BELLS +#include <stdio.h> +#include <stdlib.h> +#include <dev/speaker/speaker.h> +#include <fcntl.h> +#include "kb_bells.h" +#define MAX_BELLS (SPEED_CHANGE_SOUND+1) +int fd_bells; + +static void bsd_play_bells(int isound); +main() +{ + int i; + fd_bells = open("/dev/speaker",O_RDWR); + + if(fd_bells<0) { + fprintf(stderr,"kldload speaker.ko\n"); + exit(-1); + } + + for(i=1;i < MAX_BELLS;i++) { + printf("%d \n", i); + bsd_play_bells(i); + getchar(); + } +} +#endif + +static void bsd_play_bells(int isound) +{ + tone_t tones; + + switch(isound) + { + case BELL_SOUND : + play_bell_sound (); + break; + case DUPE_SOUND : + play_dupe_sound (); + break; + case MESSAGE_SOUND : + play_message_sound (); + break; + case BAND_CHANGE_SOUND : + play_band_change_sound (); + break; + case SINGLE_MULT_SOUND : + play_single_mult_sound (); + break; + case DOUBLE_MULT_SOUND : + play_double_mult_sound (); + break; + case BAD_CALL_SOUND : + play_bad_call_sound (); + break; + case BAD_KEY_SOUND : + play_bad_key_sound (); + break; + case SPEED_CHANGE_SOUND : + play_speed_change_sound (); + break; + default: + break; + } +} +#define DELAY_TO_HZ(x) (x/4) +play_bell_sound() +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0x474); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_dupe_sound () +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0xfe0); + tones.duration = 12; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0x17c8); + tones.duration = 12; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_message_sound() +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0xd58); + tones.duration = 12; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0x8e8); + tones.duration = 12; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0xd58); + tones.duration = 12; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_band_change_sound() +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0x710); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = 0; + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0x710); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = 0; + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_single_mult_sound() +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0x8e8); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0x6ac); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_double_mult_sound() +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0x8e8); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0x6ac); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = 0; + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0x8e8); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); + tones.frequency = DELAY_TO_HZ(0x6ac); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_bad_call_sound () +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0x11d0); + tones.duration = 38; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_bad_key_sound() +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0x17cc); + tones.duration = 42; + ioctl(fd_bells, SPKRTONE, &tones); +} +play_speed_change_sound() +{ + tone_t tones; + tones.frequency = DELAY_TO_HZ(0x710); + tones.duration = 6; + ioctl(fd_bells, SPKRTONE, &tones); +} + diff --git a/comms/kb/files/kb b/comms/kb/files/kb new file mode 100644 index 000000000000..43865762c67d --- /dev/null +++ b/comms/kb/files/kb @@ -0,0 +1,7 @@ +#!/bin/sh +if [ ! -e ~/.kb ] ; then + mkdir ~/.kb +fi +cp -f /usr/local/share/kb/* ~/.kb +cd ~/.kb +exec kb_bin diff --git a/comms/kb/files/kbserver b/comms/kb/files/kbserver new file mode 100644 index 000000000000..4c83805581e4 --- /dev/null +++ b/comms/kb/files/kbserver @@ -0,0 +1,34 @@ +#! /bin/sh +# +# PROVIDE: kbserver +# REQUIRE: NETWORKING +# +# Add the following lines to /etc/rc.conf to enable kb_server +# +#kbserver_enable="YES" + +. /etc/rc.subr + +name=kbserver +rcvar=`set_rcvar` +load_rc_config $name +kbserver_enable=${kbserver_enable-"NO"} + +command=/usr/local/sbin/kb_server +start_cmd=kbserver_start +stop_cmd=kbserver_stop + +kbserver_start() +{ + echo "Starting kb_server: " + ${command} + return 0 +} +kbserver_stop() +{ + echo "Stopping kb_server: " + killall kb_server + return 0 +} + +run_rc_command "$1" diff --git a/comms/kb/files/patch-boxes.c b/comms/kb/files/patch-boxes.c new file mode 100644 index 000000000000..2a6e8ae0b3db --- /dev/null +++ b/comms/kb/files/patch-boxes.c @@ -0,0 +1,35 @@ +--- boxes.c.orig 2007-11-24 19:46:36.000000000 -0500 ++++ boxes.c 2007-11-24 19:42:17.000000000 -0500 +@@ -749,8 +749,13 @@ + guint ikey, istate; + gchar msg[43], email_file_names[5][13], lpr_line[81]; + gint margin=9; ++#ifdef BSD ++ const gchar *lpr_cmd = ++ "lpr "; ++#else + const gchar *lpr_cmd = + "lpr -r -o page-top=36 -o page-left=18 -o page-bottom=36 "; ++#endif + const gchar *print_file_names[4] = {"PRINT.SUM", "PRINT.DUP", + "PRINT.LOG", "PRINT.MLT"}; + +@@ -778,14 +783,14 @@ + if(icall_count) + { + write_summary_file (print_file_names[obd->item], margin); +- strcpy(lpr_line, lpr_cmd); +- strcat(lpr_line, print_file_names[obd->item]); ++ snprintf(lpr_line, sizeof(lpr_line), "%s %s", lpr_cmd, ++ print_file_names[obd->item]); + icopy = system(lpr_line); + if(isel_contest==WPX) + { + write_multiplier_file (print_file_names[3], margin); +- strcpy(lpr_line, lpr_cmd); +- strcat(lpr_line, print_file_names[3]); ++ snprintf(lpr_line, sizeof(lpr_line), "%s %s", lpr_cmd, ++ print_file_names[3]); + icopy = system(lpr_line); + } + if(!icopy) diff --git a/comms/kb/files/patch-elogs.c b/comms/kb/files/patch-elogs.c new file mode 100644 index 000000000000..0cb6442775de --- /dev/null +++ b/comms/kb/files/patch-elogs.c @@ -0,0 +1,915 @@ +--- elogs.c.orig 2007-11-22 13:24:56.000000000 -0500 ++++ elogs.c 2007-11-22 14:19:17.000000000 -0500 +@@ -56,7 +56,6 @@ + gchar locus_line[4], ops_line[45]; + gint iqsos[2] = {0, 0}, idupes[2] = {0, 0}, ipoints[2] = {0, 0}; + gint mults[2] = {0, 0}, izones[2] = {0, 0}, nlw[2] = {0, 0}; +- gchar skip_line[3] = {'\r', '\n', '\0'}; + const gchar *stpr = "State/Province: "; + const gchar *category_choices[8] = {"Single Operator", + "Single Operator, Assisted", +@@ -106,9 +105,7 @@ + concat(line_out, cr_array[1].date, 4, 5, !COPY); + strcat(line_out, " "); + strcat(line_out, select_contest_items[isel_contest]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Call: "); + strcpy(station, init_screen_choices[0]); +@@ -169,9 +166,7 @@ + strcat(line_out, "Section: ___"); + break; + } +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp, "%s\n\n", line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Category: "); + for(i=0; i<8; i++) +@@ -192,16 +187,12 @@ + strcpy(ops_line, ""); + break; + } +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp, "%s\n\n", line_out); + if(strlen(ops_line)) + { + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, ops_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp, "%s\n\n", line_out); + } + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Mode: "); +@@ -211,24 +202,18 @@ + strcat(line_out, power_line); + concat(line_out, blank80, 0, 9, !COPY); + strcat(line_out, "Hours of Operation: __"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp, "%s\n\n\n", line_out); + switch (isel_contest) + { + case DX : + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " Net QSO Country Claimed"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " QSOs Points Mults Score"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp, "%s\n\n", line_out); + for(i=0; i<6; i++) + { + concat(line_out, blank80, 0, margin+2, COPY); +@@ -247,10 +232,9 @@ + int_to_comma (score_mb.mults[mode][i], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n", line_out); + } +- fputs(skip_line, fp); ++ fprintf(fp,"\n"); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "All Bands"); + concat(line_out, blank80, 0, 3, !COPY); +@@ -269,21 +253,17 @@ + int_to_comma (ipoints[mode]*mults[mode], score_line); + left_blank_pad (score_line, sizeof(score_line)); + strcat(line_out, score_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + break; + case FD : + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " Net CW Net PH"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " QSOs QSOs"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + for(i=0; i<6; i++) + { + concat(line_out, blank80, 0, margin+2, COPY); +@@ -297,10 +277,9 @@ + int_to_comma (score_mb.qsos[PH][i]-score_mb.dupes[PH][i], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } +- fputs(skip_line, fp); ++ fprintf(fp,"\n"); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "All Bands"); + concat(line_out, blank80, 0, 4, !COPY); +@@ -315,8 +294,7 @@ + int_to_comma (iqsos[CW]-idupes[CW]+iqsos[PH]-idupes[PH], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "QSO Points"); + concat(line_out, blank80, 0, 3, !COPY); +@@ -331,8 +309,7 @@ + int_to_comma (ipoints[CW]+ipoints[PH], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Power Multiplier"); + concat(line_out, blank80, 0, 21, !COPY); +@@ -345,43 +322,34 @@ + int_to_comma (pm, sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "QSO Score"); + concat(line_out, blank80, 0, 28, !COPY); + int_to_comma (pm*(ipoints[CW]+ipoints[PH]), sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Bonus Points"); + concat(line_out, blank80, 0, 24, !COPY); + concat(line_out, under_line, 0, 6, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Claimed Score"); + concat(line_out, blank80, 0, 23, !COPY); + concat(line_out, under_line, 0, 6, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + break; + case WPX : + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " Net QSO Prefix Claimed"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " QSOs Points Mults Score"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + for(i=0; i<6; i++) + { + concat(line_out, blank80, 0, margin+2, COPY); +@@ -400,10 +368,9 @@ + int_to_comma (score_mb.mults[mode][i], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } +- fputs(skip_line, fp); ++ fprintf(fp,"\n"); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "All Bands"); + concat(line_out, blank80, 0, 3, !COPY); +@@ -422,8 +389,7 @@ + int_to_comma (ipoints[mode]*mults[mode], score_line); + left_blank_pad (score_line, sizeof(score_line)); + strcat(line_out, score_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + break; + case CQP : + break; +@@ -431,14 +397,11 @@ + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " Net QSO Country Zone Claimed"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " QSOs Points Mults Mults Score"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + for(i=0; i<6; i++) + { + concat(line_out, blank80, 0, margin+2, COPY); +@@ -461,10 +424,9 @@ + int_to_comma (score_mb.zones[mode][i], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } +- fputs(skip_line, fp); ++ fprintf(fp,"\n"); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "All Bands"); + concat(line_out, blank80, 0, 2, !COPY); +@@ -487,22 +449,17 @@ + int_to_comma (ipoints[mode]*(mults[mode]+izones[mode]), score_line); + left_blank_pad (score_line, sizeof(score_line)); + strcat(line_out, score_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + break; + case SS : + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " Net QSO Section Claimed"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " QSOs Points Mults Score"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + concat(line_out, blank80, 0, 12, !COPY); + int_to_comma (iqsos[mode]-idupes[mode], sum_line); +@@ -520,21 +477,15 @@ + int_to_comma (ipoints[mode]*mults[mode], score_line); + left_blank_pad (score_line, sizeof(score_line)); + strcat(line_out, score_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " ARRL Sections Check-Off List"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " (Sections worked marked with an asterisk)"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + for(j=1; j<11; j++) + { + concat(line_out, blank80, 0, margin, COPY); +@@ -554,8 +505,7 @@ + strcat(line_out, mult_line); + strcat(line_out, locus_line); + } +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + break; + case A160 : +@@ -565,18 +515,14 @@ + int_to_comma (iqsos[CW]-idupes[CW], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "QSO Points"); + concat(line_out, blank80, 0, 9, !COPY); + int_to_comma (ipoints[CW], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "States/Prov"); + for(i=0; i<2; i++) +@@ -587,9 +533,7 @@ + int_to_comma (nlw[CW], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Countries"); + nlw[0] = 0; +@@ -602,18 +546,14 @@ + int_to_comma (nlw[CW], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Total Mults"); + concat(line_out, blank80, 0, 8, !COPY); + int_to_comma (mults[CW], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Claimed Score"); + concat(line_out, blank80, 0, 1, !COPY); +@@ -621,16 +561,13 @@ + score_line); + left_blank_pad (score_line, sizeof(score_line)); + strcat(line_out, score_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + break; + case TEN : + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + " CW Phone All"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "QSOs"); + concat(line_out, blank80, 0, 15, !COPY); +@@ -645,9 +582,7 @@ + int_to_comma (iqsos[CW]-idupes[CW]+iqsos[PH]-idupes[PH], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "QSO Points"); + concat(line_out, blank80, 0, 9, !COPY); +@@ -662,9 +597,7 @@ + int_to_comma (ipoints[CW]+ipoints[PH], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "States/Prov"); + for(i=0; i<2; i++) +@@ -683,9 +616,7 @@ + int_to_comma (nlw[CW]+nlw[PH], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Countries"); + nlw[0] = 0; +@@ -706,9 +637,7 @@ + int_to_comma (nlw[CW]+nlw[PH], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Total Mults"); + concat(line_out, blank80, 0, 8, !COPY); +@@ -723,9 +652,7 @@ + int_to_comma (mults[CW]+mults[PH], sum_line); + left_blank_pad (sum_line, sizeof(sum_line)); + strcat(line_out, sum_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Claimed Score"); + concat(line_out, blank80, 0, 30, !COPY); +@@ -733,76 +660,51 @@ + score_line); + left_blank_pad (score_line, sizeof(score_line)); + strcat(line_out, score_line); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + break; + } +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"\n\n"); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + "Club Participation? ( ) Yes ( ) No If yes, print name below."); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Name of Club: "); + concat(line_out, under_line, 0, 49, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Rigs: "); + concat(line_out, under_line, 0, 57, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + concat(line_out, under_line, 0, 63, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Antennas: "); + concat(line_out, under_line, 0, 53, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + concat(line_out, under_line, 0, 63, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Remarks: "); + concat(line_out, under_line, 0, 54, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + concat(line_out, under_line, 0, 63, !COPY); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n%s\n\n",line_out,line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + "This is to certify that in this contest I have operated my"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + "transmitter within the limitations of my license and have"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, + "observed fully the rules and regulations of the contest."); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, "Date "); + concat(line_out, under_line, 0, 9, !COPY); +@@ -810,25 +712,20 @@ + concat(line_out, under_line, 0, 22, !COPY); + strcat(line_out, ", "); + strcat(line_out, init_screen_choices[1]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, init_screen_choices[2]); + strcat(line_out, ", "); + strcat(line_out, init_screen_choices[1]); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, init_screen_choices[3]); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + if(strlen(init_screen_choices[4])) + { + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, init_screen_choices[4]); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, init_screen_choices[5]); +@@ -836,8 +733,7 @@ + strcat(line_out, init_screen_choices[6]); + strcat(line_out, " "); + strcat(line_out, init_screen_choices[7]); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + fflush(fp); + fsync(fileno(fp)); + fclose(fp); +@@ -852,7 +748,6 @@ + gchar station[14], mode_line[6], dupe_line[2]; + gchar title_line[74], header_line1[74], call_hold[14], call_fill[14]; + gint iqsos[2] = {0, 0}, max_lines=54; +- gchar skip_line[3] = {'\r', '\n', '\0'}; + gchar form_feed[2] = {'\f', '\0'}; + + fp = fopen(filnam, "w"); +@@ -924,10 +819,7 @@ + int_to_char (npages, npages_char); + left_blank_pad (npages_char, sizeof(npages_char)); + strcat(line_out, npages_char); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n\n",line_out); + } + if(margin || new_mb) + { +@@ -936,9 +828,7 @@ + strcat(line_out, header_line1); + strcat(line_out, bandw[i]); + strcat(line_out, mode_char[j]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + } + strcpy(call_hold, ""); + ic = 0; +@@ -973,8 +863,7 @@ + ic %= 4; + if(!ic) + { +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + idl++; + } + } +@@ -986,14 +875,13 @@ + } + if(ic) + { +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + if(margin) + fputs(form_feed, fp); + } + if(!margin) +- fputs(skip_line, fp); ++ fprintf(fp,"\n"); + } + fflush(fp); + fsync(fileno(fp)); +@@ -1014,7 +902,6 @@ + gchar hl2_zone[7], hl2_country[10]; + gint iqsos[2] = {0, 0}, nqsos[2] = {0, 0}; + gint nzones[2] = {0, 0}, nmults[2] = {0, 0}, npts[2] = {0, 0}; +- gchar skip_line[3] = {'\r', '\n', '\0'}; + gchar form_feed[2] = {'\f', '\0'}; + + fp = fopen(filnam, "w"); +@@ -1154,19 +1041,13 @@ + strcat(line_out, ipage_char); + strcat(line_out, " of "); + strcat(line_out, npages_char); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, header_line1); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, header_line2); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + } + for(i=(ipage-1)*50+1; i<=ipage*50; i++) + { +@@ -1361,11 +1242,10 @@ + npts[0] += atoi(cr_array[i].points); + npts[1] += atoi(cr_array[i].points); + strcat(line_out, cr_array[i].points); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + else if(margin) +- fputs(skip_line, fp); ++ fprintf(fp,"\n"); + } + if(margin) + { +@@ -1385,7 +1265,7 @@ + left_blank_pad (footer2_vars[2], sizeof(footer2_vars[2])); + int_to_char (npts[1], footer2_vars[3]); + left_blank_pad (footer2_vars[3], sizeof(footer2_vars[3])); +- fputs(skip_line, fp); ++ fprintf(fp,"\n"); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, footer_line1); + concat(line_out, blank80, 0, 9, !COPY); +@@ -1402,8 +1282,7 @@ + strcat(line_out, footer1_vars[2]); + concat(line_out, blank80, 0, 3, !COPY); + strcat(line_out, footer1_vars[3]); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, footer_line2); + concat(line_out, blank80, 0, 9, !COPY); +@@ -1420,9 +1299,7 @@ + strcat(line_out, footer2_vars[2]); + concat(line_out, blank80, 0, 3, !COPY); + strcat(line_out, footer2_vars[3]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(form_feed, fp); ++ fprintf(fp,"%s\f\n",line_out); + } + } + fflush(fp); +@@ -1439,7 +1316,6 @@ + gchar title_line[74], header_line1[74]; + gint max_lines=54; + gint iqsos[2] = {0, 0}; +- gchar skip_line[3] = {'\r', '\n', '\0'}; + gchar form_feed[2] = {'\f', '\0'}; + + fp = fopen(filnam, "w"); +@@ -1499,15 +1375,10 @@ + strcat(line_out, ipage_char); + strcat(line_out, " of "); + strcat(line_out, npages_char); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n\n",line_out); + concat(line_out, blank80, 0, margin, COPY); + strcat(line_out, header_line1); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(skip_line, fp); ++ fprintf(fp,"%s\n\n",line_out); + } + jfirst = (ipage-1)*max_lines*10+1; + jlast = ipage*max_lines*10<px_tree.npx ? +@@ -1525,14 +1396,12 @@ + ic %= 10; + if(!ic) + { +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + } + if(ic) + { +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + if(margin) + fputs(form_feed, fp); +@@ -1662,8 +1531,7 @@ + strcat(category_cab, " "); + strcat(category_cab, mode_cab); + strcpy(line_out, "START-OF-LOG: 2.0"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + if(strlen(section)>0) + { + strcpy(line_out, "ARRL-SECTION: "); +@@ -1671,80 +1539,45 @@ + } + else + strcpy(line_out, "ARRL-SECTION:"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + strcpy(line_out, "CALLSIGN: "); + strcat(line_out, init_screen_choices[0]); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + strcpy(line_out, "CATEGORY: "); + strcat(line_out, category_cab); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + if(isel_contest==WPX && !strcmp(init_screen_choices[11], "<SO-TRI/SE>")) + { + strcpy(line_out, "CATEGORY-OVERLAY: "); + strcat(line_out, "TB-WIRES"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + strcpy(line_out, "CLAIMED-SCORE: "); + strcat(line_out, score_cab); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + strcpy(line_out, "CLUB:"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + strcpy(line_out, "CONTEST: "); + strcat(line_out, contest_cab); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + strcpy(line_out, "NAME: "); + strcat(line_out, init_screen_choices[2]); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + strcpy(line_out, "ADDRESS: "); + strcat(line_out, init_screen_choices[3]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- if(strlen(init_screen_choices[4])) +- { +- strcpy(line_out, "ADDRESS: "); +- strcat(line_out, init_screen_choices[4]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- strcpy(line_out, "ADDRESS: "); +- strcat(line_out, init_screen_choices[5]); +- strcat(line_out, ", "); +- strcat(line_out, init_screen_choices[6]); +- strcat(line_out, " "); +- strcat(line_out, init_screen_choices[7]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- } +- else +- { +- strcpy(line_out, "ADDRESS: "); +- strcat(line_out, init_screen_choices[5]); +- strcat(line_out, ", "); +- strcat(line_out, init_screen_choices[6]); +- strcat(line_out, " "); +- strcat(line_out, init_screen_choices[7]); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- strcpy(line_out, "ADDRESS:"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- } +- strcpy(line_out, "OPERATORS:"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- strcpy(line_out, "SOAPBOX:"); +- add_eol_chars (line_out); +- fputs(line_out, fp); +- fputs(line_out, fp); +- fputs(line_out, fp); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); ++ if(strlen(init_screen_choices[4])!=0) ++ fprintf(fp,"ADDRESS: %s\n", ++ init_screen_choices[4]); ++ fprintf(fp,"ADDRESS: %s, %s %s\n",init_screen_choices[5], ++ init_screen_choices[6],init_screen_choices[7]); ++ ++ fprintf(fp,"OPERATORS:\n"); ++ fprintf(fp,"SOAPBOX:\n"); ++ fprintf(fp,"SOAPBOX:\n"); ++ fprintf(fp,"SOAPBOX:\n"); ++ fprintf(fp,"SOAPBOX:\n"); ++ fprintf(fp,"SOAPBOX:\n"); + switch (isel_contest) + { + case WPX : +@@ -1790,8 +1623,7 @@ + strcat(line_out, exch_rcvd_cab); + strcat(line_out, " "); + strcat(line_out, cr_array[i].tx); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + break; + case FD : +@@ -1836,8 +1668,7 @@ + strcat(line_out, exch_rcvd_cab); + strcat(line_out, " "); + strcat(line_out, cr_array[i].tx); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + break; + case CQP : +@@ -1892,8 +1723,7 @@ + strcat(line_out, ck_rcvd_cab); + strcat(line_out, " "); + strcat(line_out, rst_rcvd_cab); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + break; + case A160 : +@@ -1947,8 +1777,7 @@ + strcat(line_out, exch_rcvd_cab); + strcat(line_out, " "); + strcat(line_out, cr_array[i].tx); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + break; + default : +@@ -1995,13 +1824,10 @@ + strcat(line_out, exch_rcvd_cab); + strcat(line_out, " "); + strcat(line_out, cr_array[i].tx); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"%s\n",line_out); + } + } +- strcpy(line_out, "END-OF-LOG:"); +- add_eol_chars (line_out); +- fputs(line_out, fp); ++ fprintf(fp,"END-OF-LOG:\n"); + fflush(fp); + fsync(fileno(fp)); + fclose(fp); diff --git a/comms/kb/files/patch-fields.c b/comms/kb/files/patch-fields.c new file mode 100644 index 000000000000..cfcf3b859c03 --- /dev/null +++ b/comms/kb/files/patch-fields.c @@ -0,0 +1,15 @@ +--- fields.c.orig 2007-09-10 10:57:01.000000000 -0400 ++++ fields.c 2007-11-22 19:53:19.000000000 -0500 +@@ -1418,6 +1418,12 @@ + gint cyan_bar_color, text_color; + gchar str_hold[81]; + ++ /* If esk->ikey is nul shunt it off here. I saw it happen - db VA3DB */ ++ if (esd->ikey == '\0') ++ { ++ play_bells (BELL_SOUND); ++ return; ++ } + beep = 1; + ccol = *esd->cursor_colp-esd->field_col; + lflp = strlen(esd->field_linep); diff --git a/comms/kb/files/patch-globs.h b/comms/kb/files/patch-globs.h new file mode 100644 index 000000000000..df7aaf0da8b2 --- /dev/null +++ b/comms/kb/files/patch-globs.h @@ -0,0 +1,27 @@ +--- globs.h.orig 2007-07-20 10:26:01.000000000 -0400 ++++ globs.h 2007-11-23 09:38:53.000000000 -0500 +@@ -169,8 +169,15 @@ + "<18.0>", "<19.2>", "<20.6>", "<22.2>", "<24.0>", + "<26.2>", "<28.8>", "<32.0>", "<36.0>", "<41.1>", + "<48.0>", "<57.6>", "<72.0>"}; ++/* These device names are really specific to FreeBSD -db */ ++#ifdef BSD ++static const gchar *port_bracket[6] = {"<OFF>", "<ttyd0>", "<ttyd1>", ++ "<ttyU0>", "<ttyU1>", "<TELNET>"}; ++#else + static const gchar *port_bracket[6] = {"<OFF>", "<ttyS0>", "<ttyS1>", + "<ttyUSB0>", "<ttyUSB1>", "<TELNET>"}; ++#endif ++ + static const gchar *yn_bracket[2] = {"<YES>", "<NO>"}; + static const gchar *dupe_bracket[2] = {"<ASK>", "<ALWAYS>"}; + static const gchar *partial_bracket[3] = {"<NO>", "<2>", "<3>"}; +@@ -178,7 +185,7 @@ + " Station Call Sign", "Operator Call Sign", + " Operator Name", " Address", + " Address", " City", +- " State", " Zip Code", ++ " State/Province", " Zip/Postal Code", + " Latitude", " Longitude", + " Offset to UTC", " Entry Category", + " Power", " Contest Type", diff --git a/comms/kb/files/patch-init.c b/comms/kb/files/patch-init.c new file mode 100644 index 000000000000..4081df6845f9 --- /dev/null +++ b/comms/kb/files/patch-init.c @@ -0,0 +1,150 @@ +--- init.c.orig 2007-09-10 10:34:21.000000000 -0400 ++++ init.c 2007-11-24 16:43:45.000000000 -0500 +@@ -30,6 +30,7 @@ + static gint set_error_check(gpointer data); + static gint check_precedence(void); + static gint butt_kick(gpointer widget); ++static void set_fixed_font(GtkWidget *); + struct init_vars + { + gint row1; +@@ -108,33 +109,13 @@ + (col1+9)*wcol, + (row1+9)*hrow+hrow/2, + layout); +- pfd = pango_font_description_from_string ("misc fixed 16"); +- pc = gtk_widget_get_pango_context (widget); +- pl = pango_context_get_language (pc); +- pfm = pango_context_get_metrics (pc, pfd, pl); +- ipfmgadw = pango_font_metrics_get_approximate_digit_width (pfm); +- cursor_offset = 8-pango_font_metrics_get_descent (pfm)/PANGO_SCALE; +- pango_font_metrics_unref (pfm); +- if(ipfmgadw==10240) +- { +- pango_layout_set_font_description (layout, pfd); +- pango_font_description_free (pfd); +- } +- else +- { +- pango_font_description_free (pfd); +- pfd = pango_font_description_from_string ("luxi mono 12"); +- pango_layout_set_font_description (layout, pfd); +- pango_font_description_free (pfd); +- printf("%s\n", missing_font); +- printf("For a more readable KB screen "); +- printf("add the Misc Fixed font to your system.\n"); +- printf("%s\n", missing_font); +- write_line (row1+23, col1+20, missing_font, HI_RED, SAVEPIX); +- write_line (row1+24, col1+6, +- "Now Using Alternate Font. KB Screens May Exhibit Display Problems.", +- HI_RED, SAVEPIX); +- } ++ /* Original code would only work on a 1024 wide screen. ++ * This works for other sized screens, including mine which is 1280 wide. ++ * ++ * - Diane VA3DB db@db.net ++ */ ++ set_fixed_font(widget); ++ + concat(comp_mon, __DATE__, 0, 2, COPY); + concat(comp_yr, __DATE__, 7, 10, COPY); + while(strcmp(comp_mon, month_array[icm]) && icm<11) +@@ -404,6 +385,7 @@ + mode = CW; + else + mode = PH; ++ shift_fkeys = 0; + if(!sccfn && strcmp(init_screen_choices[16], port_bracket[0])) + { + idisplay_type = IDT_KEYER; +@@ -1139,8 +1121,13 @@ + beep = 0; + break; + case 7 : +- if(isdigit_ui(ikey) || ikey=='-') +- beep = 0; ++ /* Canadian postal codes will be ANA[space]NAN ++ * I will cheat and allow any combination of alpha, numeric and space. ++ * - Diane VA3DB <db@db.net> ++ */ ++ ikey = toupper_ui(ikey); ++ if(isalpha_ui(ikey) || isdigit_ui(ikey) || ikey==' ' || ikey=='-') ++ beep = 0; + break; + case 8 : + ikey = toupper_ui(ikey); +@@ -1163,7 +1150,7 @@ + edit_line (&esd); + } + else +- play_bells (BAD_KEY_SOUND); ++ play_bells (BAD_KEY_SOUND); + } + return TRUE; + } +@@ -1791,6 +1778,7 @@ + } + write_ini_file (); + insert_mode = 0; ++ shift_fkeys = 0; + shift_fkeys = (strcmp(set_screen_choices[11], yn_bracket[1])); + ssd->done = TRUE; + break; +@@ -2381,3 +2369,57 @@ + update_rect.height); + return TRUE; + } ++ ++/* ++ * set_fixed_font ++ * ++ * Author - Diane Bruce <db@db.net> VA3DB ++ * Inputs - None ++ * Output - None ++ * Side effects - Try to find a font that fits the screen ++ * giving 80 columns across ++ * KB relies upon the width of a monospace font being equal ++ * in width to one of 80 (NUMBER_OF_COLUMNS) columns. ++ * Bugs - I am sure there must be better ways of doing this. ++ * There is probably a mapping function between ++ * font size and pixel width. I'll look for that next. ++ */ ++#define SBUFSIZE 64 ++static void ++set_fixed_font(GtkWidget *widget) ++{ ++ int width_col; ++ char font_desc[SBUFSIZE]; ++ int width_font; ++ int font_size; ++ gint ipfmgadw; ++ PangoFontDescription *pfd; ++ PangoContext *pc; ++ PangoLanguage *pl; ++ PangoFontMetrics *pfm; ++ ++ width_col = widget->allocation.width/NUMBER_OF_COLUMNS; ++ ++ pc = gtk_widget_get_pango_context (widget); ++ pl = pango_context_get_language (pc); ++ ++ for (font_size = 10; font_size < 24; font_size++) ++ { ++ snprintf(font_desc, sizeof(font_desc)-1, "monospace %d", font_size); ++ ++ pfd = pango_font_description_from_string (font_desc); ++ pfm = pango_context_get_metrics (pc, pfd, pl); ++ ipfmgadw = pango_font_metrics_get_approximate_digit_width (pfm); ++ if (ipfmgadw/PANGO_SCALE == width_col) ++ { ++ printf("Found a good font [%s]\n", font_desc); ++ pango_font_metrics_unref (pfm); ++ break; ++ } ++ pango_font_metrics_unref (pfm); ++ } ++ ++ cursor_offset = 8-pango_font_metrics_get_descent (pfm)/PANGO_SCALE; ++ pango_layout_set_font_description (layout, pfd); ++ pango_font_description_free (pfd); ++} diff --git a/comms/kb/files/patch-io.c b/comms/kb/files/patch-io.c new file mode 100644 index 000000000000..041ea0655cb5 --- /dev/null +++ b/comms/kb/files/patch-io.c @@ -0,0 +1,533 @@ +--- io.c.orig 2007-07-01 15:19:57.000000000 -0400 ++++ io.c 2007-11-24 18:14:00.000000000 -0500 +@@ -17,6 +17,7 @@ + static void rewrite_contest_file(void); + static void write_call_library_file(void); + static gint process_tmp_file(const gchar *filnam); ++static char* chomp(char *s); + + static void fill_iend_array(void) + { +@@ -99,24 +100,22 @@ + strcat(contest_line, cr_array[qnum].tx); + strcpy(field_hold, cr_array[qnum].prefix); + right_blank_pad(field_hold, sizeof(cr_array[qnum].prefix)); +- strcat(contest_line, field_hold); +- add_eol_chars (contest_line); ++ sprintf(contest_line,"%s%s\n",contest_line,field_hold); + } + + static void read_ini_file(void) + { + FILE *fp; + gchar filnam[13], msg[49], contest_ini_line[76]; +- gint i, icolon, lcil, socil; ++ gint i, socil; ++ char *token; + guint answer; + +- strcpy(filnam, contest_file_base); +- strcat(filnam, ".INI"); ++ snprintf(filnam,sizeof(filnam), "%s.INI", contest_file_base); + fp = fopen(filnam, "r"); + if(fp==NULL) + { +- strcpy(msg, filnam); +- strcat(msg, " does not exist. Use default? (Y/N)"); ++ snprintf(msg,sizeof(msg),"%s does not exist. Use default? (Y/N)"); + play_bells (DUPE_SOUND); + answer = boxed_message (msg, 0, LT_GRAY); + if(toupper_ui(answer)=='Y') fp = fopen("DEFAULT.INI","r"); +@@ -125,53 +124,41 @@ + socil = sizeof(contest_ini_line); + for(i=0; i<MAX_INIT_ITEMS; i++) + { +- fgets(contest_ini_line, socil, fp); +- if(feof(fp)) break; +- icolon = kb_index (contest_ini_line, ":"); +- if(icolon>-1) +- { +- lcil = strlen(contest_ini_line); +- if(contest_ini_line[lcil-1]=='\n') contest_ini_line[lcil-1] = '\0'; +- if(contest_ini_line[lcil-2]=='\r') contest_ini_line[lcil-2] = '\0'; +- lcil = strlen(contest_ini_line); +- if(lcil>icolon+1) +- concat(init_screen_choices[i], contest_ini_line, +- icolon+1, lcil-1, COPY); +- } ++ if(fgets(contest_ini_line, socil, fp) == NULL) ++ break; ++ token = strtok(contest_ini_line, ":\r\n"); ++ if (token != NULL) ++ { ++ token = strtok(NULL,":\r\n"); ++ if (token != NULL) ++ strcpy(init_screen_choices[i], token); ++ } + } + for(i=0; i<MAX_SET_ITEMS; i++) + { +- fgets(contest_ini_line, socil, fp); +- if(feof(fp)) break; +- icolon = kb_index (contest_ini_line, ":"); +- if(icolon>-1) +- { +- lcil = strlen(contest_ini_line); +- if(contest_ini_line[lcil-1]=='\n') contest_ini_line[lcil-1] = '\0'; +- if(contest_ini_line[lcil-2]=='\r') contest_ini_line[lcil-2] = '\0'; +- lcil = strlen(contest_ini_line); +- if(lcil>icolon+1) +- concat(set_screen_choices[i], contest_ini_line, +- icolon+1, lcil-1, COPY); +- } ++ if(fgets(contest_ini_line, socil, fp) == NULL) ++ break; ++ token = strtok(contest_ini_line, ":\r\n"); ++ if (token != NULL) ++ { ++ token = strtok(NULL,":\r\n"); ++ if (token != NULL) ++ strcpy(set_screen_choices[i], token); ++ } + } + if(!strcmp(set_screen_choices[1], "<NEVER>")) + strcpy(set_screen_choices[1], dupe_bracket[0]); + for(i=0; i<MAX_KEYER_ITEMS; i++) + { +- fgets(contest_ini_line, socil, fp); +- if(feof(fp)) break; +- icolon = kb_index (contest_ini_line, ":"); +- if(icolon>-1) +- { +- lcil = strlen(contest_ini_line); +- if(contest_ini_line[lcil-1]=='\n') contest_ini_line[lcil-1] = '\0'; +- if(contest_ini_line[lcil-2]=='\r') contest_ini_line[lcil-2] = '\0'; +- lcil = strlen(contest_ini_line); +- if(lcil>icolon+1) +- concat(keyer_screen_choices[i], contest_ini_line, +- icolon+1, lcil-1, COPY); +- } ++ if(fgets(contest_ini_line, socil, fp) == NULL) ++ break; ++ token = strtok(contest_ini_line, ":\r\n"); ++ if(token != NULL) ++ { ++ token = strtok(NULL,":\r\n"); ++ if (token != NULL) ++ strcpy(keyer_screen_choices[i], token); ++ } + } + fclose(fp); + } +@@ -187,17 +174,14 @@ + fp = fopen(filnam, "r"); + if(fp==NULL) + { +- strcpy(msg, "Error reading "); +- strcat(msg, filnam); ++ snprintf(msg, sizeof(msg), "Error reading %s", filnam); + rw_error_box (main_drawing_area, msg); + return; + } + icall_count = 0; + socl = sizeof(contest_line); +- for( ; ; ) ++ while(fgets(contest_line, socl, fp) != NULL) + { +- fgets(contest_line, socl, fp); +- if(feof(fp)) break; + icall_count++; + fill_cr_array_all (contest_line, icall_count); + } +@@ -257,16 +241,13 @@ + gchar filnam[13], contest_line[76]; + + ded_num = 0; +- strcpy(filnam, contest_file_base); +- strcat(filnam, ".DED"); ++ sprintf(filnam,"%s.DED", filnam); + fp = fopen(filnam, "r"); + if(fp==NULL) + return; + socl = sizeof(contest_line); +- for( ; ; ) ++ while(fgets(contest_line, socl, fp) != NULL) + { +- fgets(contest_line, socl, fp); +- if(feof(fp)) break; + ded_num++; + strcpy(ded_array[ded_num], contest_line); + } +@@ -276,7 +257,7 @@ + static void read_locus_file(void) + { + FILE *fp; +- gint i, j, lcil, icn, soli; ++ gint i, j, icn, soli; + gchar filnam[13], msg[49], clat[5], clong[6]; + gchar line_in[80]; + gint n=0; +@@ -320,20 +301,14 @@ + fp = fopen(filnam, "r"); + if(fp==NULL) + { +- strcpy(msg, "Error reading "); +- strcat(msg, filnam); ++ snprintf(msg,sizeof(msg),"Error reading %s",filnam); + rw_error_box (main_drawing_area, msg); + return; + } + soli = sizeof(line_in); +- for( ; ; ) ++ while(fgets(line_in, soli, fp) != NULL) + { +- fgets(line_in, soli, fp); +- if(feof(fp)) break; +- lcil = strlen(line_in); +- if(line_in[lcil-1]=='\n') line_in[lcil-1] = '\0'; +- if(line_in[lcil-2]=='\r') line_in[lcil-2] = '\0'; +- lcil = strlen(line_in); ++ chomp(line_in); + n++; + concat(loci.locus_name[n], line_in, + col_num[icn][0], col_num[icn][1], COPY); +@@ -376,8 +351,7 @@ + fp = fopen(filnam, "r"); + if(fp==NULL) + { +- strcpy(msg, "Error reading "); +- strcat(msg, filnam); ++ snprintf(msg, sizeof(msg), "Error reading %s",filnam); + rw_error_box (main_drawing_area, msg); + return; + } +@@ -385,12 +359,12 @@ + contest_nc[i][0] = '\0'; + for(i=0; i<MAX_COUNTRIES; i++) + { +- countries.country_name[i][0] = '\0';
+- countries.country_abv[i][0] = '\0';
+- countries.country_syn[i][0] = '\0';
+- countries.continent_abv[i][0] = '\0';
+- countries.zones_in_country[i][0] = '\0';
+- countries.country_lat[i] = 0.;
++ countries.country_name[i][0] = '\0'; ++ countries.country_abv[i][0] = '\0'; ++ countries.country_syn[i][0] = '\0'; ++ countries.continent_abv[i][0] = '\0'; ++ countries.zones_in_country[i][0] = '\0'; ++ countries.country_lat[i] = 0.; + countries.country_long[i] = 0.; + } + for(i=0; i<6; i++) +@@ -401,13 +375,9 @@ + countries.izone_worked[i][j] = 0; + } + soli = sizeof(line_in); +- for( ; ; ) ++ while(fgets(line_in, soli, fp) != NULL) + { +- fgets(line_in, soli, fp); +- if(feof(fp)) break; +- lcil = strlen(line_in); +- if(line_in[lcil-1]=='\n') line_in[lcil-1] = '\0'; +- if(line_in[lcil-2]=='\r') line_in[lcil-2] = '\0'; ++ chomp(line_in); + lcil = strlen(line_in); + if(line_in[0]=='-') + { +@@ -456,11 +426,11 @@ + countries.country_lat[0] = -89.; + for(i=0; i<=n; i++) + { +- right_blank_unpad (countries.country_name[i]);
+- right_blank_unpad (countries.country_abv[i]);
+- right_blank_unpad (countries.country_syn[i]);
+- right_blank_unpad (countries.continent_abv[i]);
+- right_blank_unpad (countries.zones_in_country[i]);
++ right_blank_unpad (countries.country_name[i]); ++ right_blank_unpad (countries.country_abv[i]); ++ right_blank_unpad (countries.country_syn[i]); ++ right_blank_unpad (countries.continent_abv[i]); ++ right_blank_unpad (countries.zones_in_country[i]); + } + for(i=0; i<=notc; i++) + { +@@ -491,16 +461,16 @@ + for(k=j; k<=n; k++) + { + strcpy(countries.country_name[k], +- countries.country_name[k+1]);
++ countries.country_name[k+1]); + strcpy(countries.country_abv[k], +- countries.country_abv[k+1]);
++ countries.country_abv[k+1]); + strcpy(countries.country_syn[k], +- countries.country_syn[k+1]);
++ countries.country_syn[k+1]); + strcpy(countries.continent_abv[k], +- countries.continent_abv[k+1]);
++ countries.continent_abv[k+1]); + strcpy(countries.zones_in_country[k], +- countries.zones_in_country[k+1]);
+- countries.country_lat[k] = countries.country_lat[k+1];
++ countries.zones_in_country[k+1]); ++ countries.country_lat[k] = countries.country_lat[k+1]; + countries.country_long[k] = countries.country_long[k+1]; + } + n--; +@@ -557,19 +527,14 @@ + fp = fopen(clib.filnam, "r"); + if(fp==NULL) + { +- strcpy(msg, "Error reading "); +- strcat(msg, clib.filnam); ++ snprintf(msg, sizeof(msg), "Error reading %s", clib.filnam); + rw_error_box (main_drawing_area, msg); + return; + } + soli = sizeof(line_in); +- for( ; ; ) ++ while(fgets(line_in, soli, fp) != NULL) + { +- fgets(line_in, soli, fp); +- if(feof(fp)) break; +- lcil = strlen(line_in); +- if(line_in[lcil-1]=='\n') line_in[lcil-1] = '\0'; +- if(line_in[lcil-2]=='\r') line_in[lcil-2] = '\0'; ++ chomp(line_in); + right_blank_pad (line_in, soli); + lcil = strlen(line_in); + n++; +@@ -595,9 +560,9 @@ + fclose(fp); + for(i=0; i<=n; i++) + { +- right_blank_unpad (clib.call[i]);
+- right_blank_unpad (clib.country[i]);
+- right_blank_unpad (clib.section[i]);
++ right_blank_unpad (clib.call[i]); ++ right_blank_unpad (clib.country[i]); ++ right_blank_unpad (clib.section[i]); + right_blank_unpad (clib.county[i]); + } + clib.number_of_calls = n+1; +@@ -606,7 +571,6 @@ + static void read_help_file(void) + { + FILE *fp; +- gint lcil, soli; + gchar filnam[13], msg[49]; + gchar line_in[80]; + gint n=-1; +@@ -622,19 +586,13 @@ + fp = fopen(filnam, "r"); + if(fp==NULL) + { +- strcpy(msg, "Error reading "); +- strcat(msg, filnam); ++ snprintf(msg,sizeof(msg), "Error reading %s",filnam); + rw_error_box (main_drawing_area, msg); + return; + } +- soli = sizeof(line_in); +- for( ; ; ) ++ while(fgets(line_in, sizeof(line_in), fp) != NULL) + { +- fgets(line_in, soli, fp); +- if(feof(fp)) break; +- lcil = strlen(line_in); +- if(line_in[lcil-1]=='\n') line_in[lcil-1] = '\0'; +- if(line_in[lcil-2]=='\r') line_in[lcil-2] = '\0'; ++ chomp(line_in); + n++; + strcpy(helpbv.help_lines[n], line_in); + } +@@ -652,13 +610,10 @@ + fp = fopen(filnam, "w"); + if(fp==NULL) + { +- strcpy(msg, "Error writing "); +- strcat(msg, filnam); ++ snprintf(msg,sizeof(msg),"Error writing %s",filnam); + rw_error_box (main_drawing_area, msg); + return; + } +-// fflush(fp); +-// fsync(fileno(fp)); + fclose(fp); + } + +@@ -672,11 +627,7 @@ + concat(filnam_hold, filnam, 0, idot-1, COPY); + else + strcpy(filnam_hold, filnam); +- strcpy(msg, "cp "); +- strcat(msg, filnam); +- strcat(msg, " "); +- strcat(msg, filnam_hold); +- strcat(msg, ".BAK"); ++ snprintf(msg, sizeof(msg), "cp %s %s.BAK",filnam,filnam_hold); + icopy = system(msg); + return icopy; + } +@@ -687,13 +638,11 @@ + gchar filnam[13], msg[49], contest_ini_line[76]; + gint i; + +- strcpy(filnam, contest_file_base); +- strcat(filnam, ".INI"); ++ snprintf(filnam, sizeof(filnam), "%s.INIT", contest_file_base); + fp = fopen(filnam, "w"); + if(fp==NULL) + { +- strcpy(msg, "Error writing "); +- strcat(msg, filnam); ++ snprintf(msg, sizeof(msg), "Error writing %s", filnam); + rw_error_box (main_drawing_area, msg); + return; + } +@@ -703,8 +652,7 @@ + left_blank_unpad(contest_ini_line); + strcat(contest_ini_line, ":"); + strcat(contest_ini_line, init_screen_choices[i]); +- add_eol_chars (contest_ini_line); +- fputs(contest_ini_line, fp); ++ fprintf(fp,"%s\n",contest_ini_line); + } + for(i=0; i<MAX_SET_ITEMS; i++) + { +@@ -712,8 +660,7 @@ + left_blank_unpad(contest_ini_line); + strcat(contest_ini_line, ":"); + strcat(contest_ini_line, set_screen_choices[i]); +- add_eol_chars (contest_ini_line); +- fputs(contest_ini_line, fp); ++ fprintf(fp,"%s\n",contest_ini_line); + } + for(i=0; i<MAX_KEYER_ITEMS; i++) + { +@@ -721,8 +668,7 @@ + left_blank_unpad(contest_ini_line); + strcat(contest_ini_line, ":"); + strcat(contest_ini_line, keyer_screen_choices[i]); +- add_eol_chars (contest_ini_line); +- fputs(contest_ini_line, fp); ++ fprintf(fp,"%s\n",contest_ini_line); + } + fflush(fp); + fsync(fileno(fp)); +@@ -738,8 +684,7 @@ + fp = fopen(filnam, "a"); + if(fp==NULL) + { +- strcpy(msg, "Error writing "); +- strcat(msg, filnam); ++ snprintf(msg, sizeof(msg), "Error writing %s", filnam); + rw_error_box (main_drawing_area, msg); + return; + } +@@ -757,21 +702,18 @@ + FILE *fp; + gchar filnam[13], msg[49], contest_line[76]; + +- strcpy(filnam, contest_file_base); +- strcat(filnam, ".DED"); ++ snprintf(filnam, sizeof(filnam), "%s.DED", contest_file_base); + fp = fopen(filnam, "a"); + if(fp==NULL) + { +- strcpy(msg, "Error writing "); +- strcat(msg, filnam); ++ snprintf(msg, sizeof(msg), "Error writing %s",filnam); + rw_error_box (main_drawing_area, msg); + return; + } + strcpy(contest_line, cmd); +- add_eol_chars (contest_line); +- fputs(contest_line, fp); ++ fprintf(fp,"%s\n",contest_line); + make_contest_line (contest_line, qnum); +- fputs(contest_line, fp); ++ fprintf(fp, "%s\n", contest_line); + fflush(fp); + fsync(fileno(fp)); + fclose(fp); +@@ -789,8 +731,7 @@ + fp = fopen(filnam, "w"); + if(fp==NULL) + { +- strcpy(msg, "Error writing "); +- strcat(msg, filnam); ++ snprintf(msg, sizeof(msg), "Error writing %s", filnam); + rw_error_box (main_drawing_area, msg); + return; + } +@@ -813,8 +754,7 @@ + fp = fopen(clib.filnam, "w"); + if(fp==NULL) + { +- strcpy(msg, "Error writing "); +- strcat(msg, clib.filnam); ++ snprintf(msg, sizeof(msg),"Error writing %s",clib.filnam); + rw_error_box (main_drawing_area, msg); + return; + } +@@ -856,8 +796,7 @@ + strcat(library_line, " "); + strcat(library_line, clib.check[9999]); + right_blank_unpad(library_line); +- add_eol_chars (library_line); +- fputs(library_line, fp); ++ fprintf(fp,"%s\n",library_line); + } + fflush(fp); + fsync(fileno(fp)); +@@ -867,24 +806,35 @@ + static gint process_tmp_file(const gchar *filnam) + { + FILE *fp; ++ FILE *pfp; + gchar filnam_hold[14], psc_line[81], system_line[41]; + gint ami_running=-1; + +- strcpy(filnam_hold, filnam); +- strcat(filnam_hold, ".tmp"); +- strcpy(system_line, "ps -C "); +- strcat(system_line, filnam); +- strcat(system_line, " | sort > "); +- strcat(system_line, filnam_hold); +- system(system_line); +- fp = fopen(filnam_hold, "r"); +- if(fp!=NULL) ++ snprintf(system_line, sizeof(system_line) - 1, "ps|grep %s|grep -v grep", ++ filnam); ++ pfp = popen(system_line, "r"); ++ if(pfp!=NULL) + { +- fgets(psc_line, sizeof(psc_line), fp); ++ fgets(psc_line, sizeof(psc_line), pfp); + if(kb_index (psc_line, filnam)>-1) + ami_running = 0; +- fclose(fp); +- remove(filnam_hold); ++ fclose(pfp); + } + return ami_running; + } ++ ++static char* ++chomp(char *s) ++{ ++ char *p; ++ ++ p = strchr(s, '\n'); ++ if (p != NULL) ++ { ++ *p = '\0'; ++ p--; ++ if (*p == '\r') ++ *p = '\0'; ++ } ++} ++ diff --git a/comms/kb/files/patch-kb.c b/comms/kb/files/patch-kb.c new file mode 100644 index 000000000000..b1554aeef8b6 --- /dev/null +++ b/comms/kb/files/patch-kb.c @@ -0,0 +1,32 @@ +--- kb.c.orig 2007-09-10 14:58:04.000000000 -0400 ++++ kb.c 2007-11-24 14:46:35.000000000 -0500 +@@ -1,7 +1,12 @@ + #include <stdio.h> + #include <fcntl.h> + #include <sys/ioctl.h> ++#if (defined(__unix__) || defined(unix)) && !defined(USG) ++#include <sys/param.h> ++#endif ++#ifndef BSD + #include <sys/io.h> ++#endif + #include <stdlib.h> + #include <time.h> + #include <string.h> +@@ -3090,10 +3095,14 @@ + + gtk_key_snooper_install (kp_snooper, drawing_area); + ++#ifdef __FreeBSD__ ++ fd_bells = open("/dev/speaker", O_RDWR); ++#else + fd_bells = open("/dev/kb_bells", O_RDWR); ++#endif + g_thread_init (NULL); + gtk_main (); +- close(fd_bells); +- ++ if(fd_bells > 0) ++ close(fd_bells); + return 0; + } diff --git a/comms/kb/files/patch-support.c b/comms/kb/files/patch-support.c new file mode 100644 index 000000000000..6e28e8e1a5ce --- /dev/null +++ b/comms/kb/files/patch-support.c @@ -0,0 +1,86 @@ +--- support.c.orig 2007-07-18 14:21:10.000000000 -0400 ++++ support.c 2007-12-20 18:48:00.000000000 -0500 +@@ -1,3 +1,6 @@ ++#ifdef BSDSOUND ++#include BSDSOUND ++#endif + #include <termios.h> + #include <libgnome/libgnome.h> + #include <sys/utsname.h> +@@ -20,7 +23,6 @@ + static void concat(gchar *s1, const gchar *s2, gint is2, gint js2, + gint nullout_s1); + static gint kb_index(const gchar *s1, const gchar *s2); +-static void add_eol_chars(gchar *line_out); + static void left_zero_pad(gchar *s1, gint ss1); + static void left_blank_pad(gchar *s1, gint ss1); + static void left_blank_unpad(gchar *s1); +@@ -144,10 +146,22 @@ + layout); + } + ++#ifdef BSDSOUND ++#include "bsd_bells.c" ++#endif + static void play_bells(int isound) + { +- if(!strcmp(set_screen_choices[3], "<YES>")) +- ioctl(fd_bells, _IO(KB_BELLS_IOCTL_BASE, isound)); ++ if(fd_bells<0) ++ return; ++ if(strcmp(set_screen_choices[3], "<YES>") !=0) ++ return; ++#ifdef BSD ++#ifdef BSDSOUND ++ bsd_play_bells(isound); ++#endif ++#else ++ ioctl(fd_bells, _IO(KB_BELLS_IOCTL_BASE, isound)); ++#endif + } + + static void get_kb_time(void) +@@ -189,25 +203,8 @@ + + static void fill_kb_dt(void) + { +- gchar *t1; +- +- t1 = asctime(&kb_time); +- kb_dt.date[0] = month_num[2*kb_time.tm_mon]; +- kb_dt.date[1] = month_num[2*kb_time.tm_mon+1]; +- kb_dt.date[2] = *(t1+8); +- if(kb_dt.date[2]==' ') +- kb_dt.date[2] = '0'; +- kb_dt.date[3] = *(t1+9); +- kb_dt.date[4] = *(t1+22); +- kb_dt.date[5] = *(t1+23); +- kb_dt.date[6] = '\0'; +- kb_dt.time[0] = *(t1+11); +- kb_dt.time[1] = *(t1+12); +- kb_dt.time[2] = *(t1+14); +- kb_dt.time[3] = *(t1+15); +- kb_dt.time[4] = *(t1+17); +- kb_dt.time[5] = *(t1+18); +- kb_dt.time[6] = '\0'; ++ strftime(kb_dt.date, sizeof(kb_dt.date), "%m%d%g", &kb_time); ++ strftime(kb_dt.time, sizeof(kb_dt.time), "%H%M%S", &kb_time); + } + + static gint idelta_time(const gchar *day1, const gchar *day2, +@@ -284,15 +281,6 @@ + return -1;
+ }
+ +-static void add_eol_chars(gchar *line_out) +-{ +- gint lcil; +- +- lcil = strlen(line_out); +- line_out[lcil] = '\r'; +- line_out[lcil+1] = '\n'; +- line_out[lcil+2] = '\0'; +-} + + static void left_zero_pad(gchar *s1, gint ss1)
+ {
diff --git a/comms/kb/files/pkg_message b/comms/kb/files/pkg_message new file mode 100644 index 000000000000..1b1b70002057 --- /dev/null +++ b/comms/kb/files/pkg_message @@ -0,0 +1,8 @@ +kb is now installed. +If you want the speaker bell to work, make sure you add +speaker_load="YES" to /boot/loader.conf if your kernel +does not have speaker support. You will also need to modify +/etc/devfs.conf to add permission for users to use the speaker. +... +perm speaker 0660 +... diff --git a/comms/kb/pkg-descr b/comms/kb/pkg-descr new file mode 100644 index 000000000000..ad9111bd3a58 --- /dev/null +++ b/comms/kb/pkg-descr @@ -0,0 +1,14 @@ +The KB contest logging computer program runs on the Linux operating system +with the Gnome desktop. The program is under development, and currently +supports the CQ WW, CQ WPX, and ARRL DX contests, plus Field Day. +Features include on-the-fly dupe checking, CW and voice message keying, +super check partial, packet (Telnet and rf nodes), networking, and +radio control (currently for the FT-1000 only). The program is designed +to be used by U.S. stations, with some support for Canadian stations. +New features and contests are being added regularly, and I will consider +adding support for DX stations if there is sufficient demand. + +(The port version has bug fixes and some modifications for Canadian stations. +- db) + +WWW: http://www.k2ct.net/kbsoftware/kbsoftware.htm diff --git a/comms/kb/pkg-plist b/comms/kb/pkg-plist new file mode 100644 index 000000000000..e6ad72b3a5dc --- /dev/null +++ b/comms/kb/pkg-plist @@ -0,0 +1,15 @@ +bin/kb +bin/kb_bin +sbin/kb_server +etc/rc.d/kbserver +%%DATADIR%%/CALL_FD.LST +%%DATADIR%%/CALL_LIB.LST +%%DATADIR%%/CALL_SS.LST +%%DATADIR%%/COUNTY.CQP +%%DATADIR%%/COUNTRY.LST +%%DATADIR%%/DEFAULT.INI +%%DATADIR%%/HELP.LST +%%DATADIR%%/HELPFD.LST +%%DATADIR%%/SECTION.LST +%%DATADIR%%/STATE.LST +@dirrm %%DATADIR%% |