Skip to content
Snippets Groups Projects
execmsg.cpp 8.65 KiB
Newer Older
/* Synchronet message-related command shell/module routines */

/****************************************************************************
 * @format.tab-size 4		(Plain Text/Source Code File Header)			*
 * @format.use-tabs true	(see http://www.synchro.net/ptsc_hdr.html)		*
 *																			*
 * Copyright Rob Swindell - http://www.synchro.net/copyright.html			*
 *																			*
 * This program is free software; you can redistribute it and/or			*
 * modify it under the terms of the GNU General Public License				*
 * as published by the Free Software Foundation; either version 2			*
 * of the License, or (at your option) any later version.					*
 * See the GNU General Public License for more details: gpl.txt or			*
 * http://www.fsf.org/copyleft/gpl.html										*
 *																			*
 * For Synchronet coding style and modification guidelines, see				*
 * http://www.synchro.net/source.html										*
 *																			*
 * Note: If this box doesn't appear square, then you need to fix your tabs.	*
 ****************************************************************************/

#include "sbbs.h"
#include "cmdshell.h"

int sbbs_t::exec_msg(csi_t *csi)
	char str[256], ch;
	int  i, j;

	switch (*(csi->ip++)) {

		case CS_MSG_SELECT_AREA:
			csi->logic = LOGIC_FALSE;
			if (!usrgrps)
				return 0;
			while (online) {
				j = 0;
				if (usrgrps > 1) {
					if (!menu("grps", P_NOERROR)) {
						bputs(text[CfgGrpLstHdr]);
						for (i = 0; i < usrgrps && !msgabort(); i++) {
							if (i == curgrp)
								outchar('*');
							else
								outchar(' ');
							if (i < 9)
								outchar(' ');
							if (i < 99)
								outchar(' ');
							add_hotspot(i + 1);
							bprintf(text[CfgGrpLstFmt]
							        , i + 1, cfg.grp[usrgrp[i]]->lname);
						}
					snprintf(str, sizeof str, text[JoinWhichGrp], curgrp + 1);
					mnemonics(str);
					j = getnum(usrgrps);
rswindell's avatar
rswindell committed
						j--;
				snprintf(str, sizeof str, "subs%u", usrgrp[j] + 1);
				if (!menu(str, P_NOERROR)) {
					CLS;
					bprintf(text[SubLstHdr], cfg.grp[usrgrp[j]]->lname);
					for (i = 0; i < usrsubs[j] && !msgabort(); i++) {
						if (i == cursub[j])
							outchar('*');
						else
							outchar(' ');
						snprintf(str, sizeof str, text[SubLstFmt], i + 1
						         , cfg.sub[usrsub[j][i]]->lname, nulstr
						         , getposts(&cfg, usrsub[j][i]));
						if (i < 9)
							outchar(' ');
						if (i < 99)
							outchar(' ');
						add_hotspot(i + 1);
						bputs(str);
					}
				snprintf(str, sizeof str, text[JoinWhichSub], cursub[j] + 1);
				mnemonics(str);
				i = getnum(usrsubs[j]);
				if ((int)i == -1) {
					if (usrgrps == 1)
				if (!i)
					i = cursub[j];
				curgrp = j;
				cursub[curgrp] = i;
				csi->logic = LOGIC_TRUE;

		case CS_MSG_GET_SUB_NUM:

			if (useron.misc & COLDKEYS) {
				i = atoi(csi->str);
				if (i && usrgrps && i <= usrsubs[curgrp])
					cursub[curgrp] = i - 1;
			ch = getkey(K_UPPER);
			if (usrgrps && (ch & 0xf) * 10 <= usrsubs[curgrp] && (ch & 0xf)) {
				i = (ch & 0xf) * 10;
				ch = getkey(K_UPPER);
				if (!IS_DIGIT(ch) && ch != CR) {
					cursub[curgrp] = (i / 10) - 1;
				if (ch == CR) {
					cursub[curgrp] = (i / 10) - 1;
				logch(ch, 0);
				i += ch & 0xf;
				if (i * 10 <= usrsubs[curgrp]) {     /* 100+ subs */
					i *= 10;
					ch = getkey(K_UPPER);
					if (!IS_DIGIT(ch) && ch != CR) {
						cursub[curgrp] = (i / 10) - 1;
					if (ch == CR) {
						cursub[curgrp] = (i / 10) - 1;
					logch(ch, 0);
					i += ch & 0xf;
				if (i <= usrsubs[curgrp])
					cursub[curgrp] = i - 1;
				if (keybuf_level() && (ch = getkey(K_UPPER)) != '\r')
					ungetkey(ch, /* insert: */ true);
			if ((ch & 0xf) <= usrsubs[curgrp] && (ch & 0xf) && usrgrps)
				cursub[curgrp] = (ch & 0xf) - 1;

		case CS_MSG_GET_GRP_NUM:

			if (useron.misc & COLDKEYS) {
				i = atoi(csi->str);
				if (i && i <= usrgrps)
					curgrp = i - 1;
			ch = getkey(K_UPPER);
			if ((ch & 0xf) * 10 <= usrgrps && (ch & 0xf)) {
				i = (ch & 0xf) * 10;
				ch = getkey(K_UPPER);
				if (!IS_DIGIT(ch) && ch != CR) {
					curgrp = (i / 10) - 1;
				if (ch == CR) {
					curgrp = (i / 10) - 1;
				logch(ch, 0);
				i += ch & 0xf;
				if (i <= usrgrps)
					curgrp = i - 1;
				if (keybuf_level() && (ch = getkey(K_UPPER)) != '\r')
					ungetkey(ch, /* insert: */ true);
			if ((ch & 0xf) <= usrgrps && (ch & 0xf))
				curgrp = (ch & 0xf) - 1;
			if (keybuf_level() && (ch = getkey(K_UPPER)) != '\r')
				ungetkey(ch, /* insert: */ true);

		case CS_MSG_SET_GROUP:
			csi->logic = LOGIC_TRUE;
			for (i = 0; i < usrgrps; i++)
				if (!stricmp(cfg.grp[usrgrp[i]]->sname, csi->str))
			if (i < usrgrps)
				curgrp = i;
				csi->logic = LOGIC_FALSE;

		case CS_MSG_SHOW_GROUPS:
			if (!usrgrps)
				return 0;
			if (menu("grps", P_NOERROR)) {
			bputs(text[GrpLstHdr]);
			for (i = 0; i < usrgrps && !msgabort(); i++) {
				if (i == curgrp)
				else
					outchar(' ');
				if (i < 9)
					outchar(' ');
				add_hotspot(i + 1);
				bprintf(text[GrpLstFmt], i + 1
				        , cfg.grp[usrgrp[i]]->lname, nulstr, usrsubs[i]);

		case CS_MSG_SHOW_SUBBOARDS:
			if (!usrgrps)
				return 0;
			snprintf(str, sizeof str, "subs%u", usrgrp[curgrp] + 1);
			if (menu(str, P_NOERROR)) {
			bprintf(text[SubLstHdr], cfg.grp[usrgrp[curgrp]]->lname);
			for (i = 0; i < usrsubs[curgrp] && !msgabort(); i++) {
				if (i == cursub[curgrp])
					outchar('*');
				else
					outchar(' ');
				snprintf(str, sizeof str, text[SubLstFmt], i + 1
				         , cfg.sub[usrsub[curgrp][i]]->lname, nulstr
				         , getposts(&cfg, usrsub[curgrp][i]));
				if (i < 9)
					outchar(' ');
				if (i < 99)
					outchar(' ');
				add_hotspot(i + 1);
				bputs(str);

		case CS_MSG_GROUP_UP:
			curgrp++;
			if (curgrp >= usrgrps)
				curgrp = 0;
		case CS_MSG_GROUP_DOWN:
			if (!curgrp)
				curgrp = usrgrps - 1;
		case CS_MSG_SUBBOARD_UP:
			if (!usrgrps)
				return 0;
			cursub[curgrp]++;
			if (cursub[curgrp] >= usrsubs[curgrp])
				cursub[curgrp] = 0;
		case CS_MSG_SUBBOARD_DOWN:
			if (!usrgrps)
				return 0;
			if (!cursub[curgrp])
				cursub[curgrp] = usrsubs[curgrp] - 1;
			else
				cursub[curgrp]--;
		case CS_MSG_SET_AREA:
			csi->logic = LOGIC_TRUE;
			for (i = 0; i < usrgrps; i++)
				for (j = 0; j < usrsubs[i]; j++)
					if (!stricmp(csi->str, cfg.sub[usrsub[i][j]]->code)) {
						curgrp = i;
						cursub[i] = j;
			csi->logic = LOGIC_FALSE;
		case CS_MSG_READ:
			if (!usrgrps)
				return 0;
			csi->logic = scanposts(usrsub[curgrp][cursub[curgrp]], 0, nulstr);
		case CS_MSG_POST:
			if (!usrgrps)
				return 0;
			csi->logic = !postmsg(usrsub[curgrp][cursub[curgrp]], 0, 0);
		case CS_MSG_QWK:
			qwk_sec();
		case CS_MSG_PTRS_CFG:
			new_scan_ptr_cfg();
		case CS_MSG_PTRS_REINIT:
			bputs(text[MsgPtrsInitialized]);
		case CS_MSG_NEW_SCAN_CFG:
			new_scan_cfg(SUB_CFG_NSCAN);
		case CS_MSG_NEW_SCAN:
			scansubs(SCAN_NEW);
		case CS_MSG_NEW_SCAN_SUB:
			csi->logic = scanposts(usrsub[curgrp][cursub[curgrp]], SCAN_NEW, nulstr);
		case CS_MSG_NEW_SCAN_ALL:
			scanallsubs(SCAN_NEW);
		case CS_MSG_CONT_SCAN:
			scansubs(SCAN_NEW | SCAN_CONT);
		case CS_MSG_CONT_SCAN_ALL:
			scanallsubs(SCAN_NEW | SCAN_CONT);
		case CS_MSG_BROWSE_SCAN:
			scansubs(SCAN_NEW | SCAN_BACK);
		case CS_MSG_BROWSE_SCAN_ALL:
			scanallsubs(SCAN_BACK | SCAN_NEW);
		case CS_MSG_FIND_TEXT:
			scansubs(SCAN_FIND);
		case CS_MSG_FIND_TEXT_ALL:
			scanallsubs(SCAN_FIND);
		case CS_MSG_YOUR_SCAN_CFG:
			new_scan_cfg(SUB_CFG_SSCAN);
		case CS_MSG_YOUR_SCAN:
			scansubs(SCAN_TOYOU);
		case CS_MSG_YOUR_SCAN_ALL:
			scanallsubs(SCAN_TOYOU);
			listsub(usrsub[curgrp][cursub[curgrp]], SCAN_INDEX, /* start: */ 0, /* search: */ NULL);
	errormsg(WHERE, ERR_CHK, "shell function", *(csi->ip - 1));