more work on utf-8

This commit is contained in:
Andrew Pamment 2017-04-23 12:14:14 +10:00
parent bc588e8636
commit 6027021d4f
14 changed files with 81 additions and 22 deletions

View File

@ -34,7 +34,7 @@ OBJ = inih/ini.o bbs.o main.o users.o main_menu.o mail_menu.o doors.o bbs_list.
$(CC) -c -o $@ $< $(CFLAGS) $(CC) -c -o $@ $< $(CFLAGS)
magicka: $(OBJ) ${LUA} ${JAMLIB} ${ZMODEM} ${JSMN} magicka: $(OBJ) ${LUA} ${JAMLIB} ${ZMODEM} ${JSMN}
$(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh $(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh -liconv
magimail: $(JAMLIB) magimail: $(JAMLIB)
cd utils/magimail && $(MAKE) freebsd cd utils/magimail && $(MAKE) freebsd

View File

@ -39,7 +39,7 @@ OBJ = deps/aha/aha.o inih/ini.o bbs.o main.o users.o main_menu.o mail_menu.o do
$(CC) -c -o $@ $< $(CFLAGS) $(CC) -c -o $@ $< $(CFLAGS)
magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${B64} ${JSMN} magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${B64} ${JSMN}
$(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh $(MICROHTTPD) $(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh -liconv $(MICROHTTPD)
magimail: $(JAMLIB) magimail: $(JAMLIB)
cd utils/magimail && $(MAKE) freebsd cd utils/magimail && $(MAKE) freebsd

View File

@ -35,7 +35,7 @@ OBJ = inih/ini.o bbs.o main.o users.o main_menu.o mail_menu.o doors.o bbs_list.o
$(CC) -c -o $@ $< $(CFLAGS) $(CC) -c -o $@ $< $(CFLAGS)
magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${JSMN} magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${JSMN}
$(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -ldl -lssl -lcrypto -lssh $(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -ldl -lssl -lcrypto -lssh -liconv
magimail: $(JAMLIB) magimail: $(JAMLIB)
cd utils/magimail && $(MAKE) linux cd utils/magimail && $(MAKE) linux

View File

@ -39,7 +39,7 @@ OBJ = deps/aha/aha.o inih/ini.o bbs.o main.o users.o main_menu.o mail_menu.o do
$(CC) -c -o $@ $< $(CFLAGS) $(CC) -c -o $@ $< $(CFLAGS)
magicka: $(OBJ) ${LUA} ${JAMLIB} ${ZMODEM} ${B64} ${JSMN} magicka: $(OBJ) ${LUA} ${JAMLIB} ${ZMODEM} ${B64} ${JSMN}
$(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -ldl -lssl -lcrypto -lssh $(MICROHTTPD) $(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/local/lib -lsqlite3 -lutil -lm -ldl -lssl -lcrypto -lssh -liconv $(MICROHTTPD)
magimail: $(JAMLIB) magimail: $(JAMLIB)
cd utils/magimail && $(MAKE) linux cd utils/magimail && $(MAKE) linux

View File

@ -34,7 +34,7 @@ OBJ = inih/ini.o bbs.o main.o users.o main_menu.o mail_menu.o doors.o bbs_list.o
$(CC) -c -o $@ $< $(CFLAGS) $(CC) -c -o $@ $< $(CFLAGS)
magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${JSMN} magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${JSMN}
$(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/pkg/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh $(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/pkg/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh -liconv
magiedit: $(ODOORS) magiedit: $(ODOORS)
cd utils/magiedit && $(MAKE) cd utils/magiedit && $(MAKE)

View File

@ -39,7 +39,7 @@ OBJ = deps/aha/aha.o inih/ini.o bbs.o main.o users.o main_menu.o mail_menu.o do
$(CC) -c -o $@ $< $(CFLAGS) $(CC) -c -o $@ $< $(CFLAGS)
magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${B64} ${JSMN} magicka: $(OBJ) ${LUA} ${ZMODEM} ${JAMLIB} ${B64} ${JSMN}
$(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/pkg/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh $(MICROHTTPD) $(CC) -o magicka -o $@ $^ $(CFLAGS) -L/usr/pkg/lib -lsqlite3 -lutil -lm -lssl -lcrypto -lssh -liconv $(MICROHTTPD)
magiedit: $(ODOORS) magiedit: $(ODOORS)
cd utils/magiedit && $(MAKE) cd utils/magiedit && $(MAKE)

6
bbs.h
View File

@ -45,6 +45,7 @@ struct door_config {
char *name; char *name;
char *command; char *command;
int stdio; int stdio;
char *codepage;
}; };
struct mail_area { struct mail_area {
@ -144,6 +145,7 @@ struct bbs_config {
char *menu_path; char *menu_path;
char *external_editor_cmd; char *external_editor_cmd;
int external_editor_stdio; int external_editor_stdio;
char *external_editor_codepage;
int fork; int fork;
int nodes; int nodes;
@ -273,8 +275,8 @@ extern void next_mail_area(struct user_record *user);
extern void prev_mail_area(struct user_record *user); extern void prev_mail_area(struct user_record *user);
extern void post_message(struct user_record *user); extern void post_message(struct user_record *user);
extern void rundoor(struct user_record *user, char *cmd, int stdio); extern void rundoor(struct user_record *user, char *cmd, int stdio, char *codepage);
extern void runexternal(struct user_record *user, char *cmd, int stdio, char **argv, char *cwd, int raw); extern void runexternal(struct user_record *user, char *cmd, int stdio, char **argv, char *cwd, int raw, char *codepage);
extern void bbs_list(struct user_record *user); extern void bbs_list(struct user_record *user);

View File

@ -1,5 +1,5 @@
[main] [main]
Codepage = cp437 Codepage = CP437
Telnet Port = 2023 Telnet Port = 2023
BBS Name = Magicka BBS BBS Name = Magicka BBS
Sysop Name = sysop Sysop Name = sysop
@ -11,6 +11,7 @@ MagiChat BBSTag = Magicka
Default Tagline = Brought to you by Another Magicka BBS! Default Tagline = Brought to you by Another Magicka BBS!
External Editor cmd = /home/andrew/MagickaBBS/utils/magiedit/magiedit.sh External Editor cmd = /home/andrew/MagickaBBS/utils/magiedit/magiedit.sh
External Editor stdio = true External Editor stdio = true
External Editor Codepage = CP437
Automessage Write Level = 10 Automessage Write Level = 10
Fork = false Fork = false
Enable WWW = false Enable WWW = false

59
doors.c
View File

@ -9,6 +9,7 @@
#include <sys/wait.h> #include <sys/wait.h>
#include <sys/ioctl.h> #include <sys/ioctl.h>
#include <fcntl.h> #include <fcntl.h>
#include <iconv.h>
#if defined(linux) #if defined(linux)
# include <pty.h> # include <pty.h>
#elif defined(__OpenBSD__) || defined(__NetBSD__) || defined(__APPLE__) #elif defined(__OpenBSD__) || defined(__NetBSD__) || defined(__APPLE__)
@ -130,7 +131,7 @@ int write_door32sys(struct user_record *user) {
void rundoor(struct user_record *user, char *cmd, int stdio) { void rundoor(struct user_record *user, char *cmd, int stdio, char *codepage) {
char *arguments[4]; char *arguments[4];
int door_out; int door_out;
char buffer[10]; char buffer[10];
@ -147,14 +148,14 @@ void rundoor(struct user_record *user, char *cmd, int stdio) {
arguments[2] = strdup(buffer); arguments[2] = strdup(buffer);
arguments[3] = NULL; arguments[3] = NULL;
runexternal(user, cmd, stdio, arguments, NULL, 0); runexternal(user, cmd, stdio, arguments, NULL, 0, codepage);
free(arguments[0]); free(arguments[0]);
free(arguments[1]); free(arguments[1]);
free(arguments[2]); free(arguments[2]);
} }
void runexternal(struct user_record *user, char *cmd, int stdio, char *argv[], char *cwd, int raw) { void runexternal(struct user_record *user, char *cmd, int stdio, char *argv[], char *cwd, int raw, char *codepage) {
char buffer[1024]; char buffer[1024];
int pid; int pid;
@ -172,7 +173,8 @@ void runexternal(struct user_record *user, char *cmd, int stdio, char *argv[], c
int i; int i;
int gotiac; int gotiac;
int flush; int flush;
iconv_t ic;
struct timeval thetimeout; struct timeval thetimeout;
struct termios oldit; struct termios oldit;
struct termios oldot; struct termios oldot;
@ -182,6 +184,11 @@ void runexternal(struct user_record *user, char *cmd, int stdio, char *argv[], c
char outbuf[512]; char outbuf[512];
int h; int h;
int g; int g;
char *ptr1;
char *ptr2;
size_t ouc;
size_t inc;
timeoutpaused = 1; timeoutpaused = 1;
if (write_door32sys(user) != 0) { if (write_door32sys(user) != 0) {
@ -302,7 +309,27 @@ void runexternal(struct user_record *user, char *cmd, int stdio, char *argv[], c
} }
} }
} }
write(master, outbuf, g); if (codepage == NULL || (strcmp(codepage, "CP437") == 0 && conf.codepage == 0) || (strcmp(codepage, "UTF-8") == 0 && conf.codepage == 1)) {
write(master, outbuf, g);
} else {
if (conf.codepage == 0) {
ic = iconv_open("CP437", codepage);
} else {
ic = iconv_open("UTF-8", codepage);
}
ptr1 = outbuf;
ptr2 = (char *)malloc((g + 1) * 2);
memset(ptr2, 0, (g + 1) * 2);
inc = g;
ouc = g * 2;
iconv(ic, &ptr1, &inc, &ptr2, &ouc);
ptr2 = ptr2 - (g * 2 - ouc);
write(master, ptr2, strlen(ptr2));
free(ptr2);
iconv_close(ic);
}
} else if (FD_ISSET(master, &fdset)) { } else if (FD_ISSET(master, &fdset)) {
len = read(master, inbuf, 256); len = read(master, inbuf, 256);
if (len == 0) { if (len == 0) {
@ -317,7 +344,27 @@ void runexternal(struct user_record *user, char *cmd, int stdio, char *argv[], c
} }
outbuf[g++] = c; outbuf[g++] = c;
} }
write(door_out, outbuf, g); if (codepage == NULL || (strcmp(codepage, "CP437") == 0 && conf.codepage == 0) || (strcmp(codepage, "UTF-8") == 0 && conf.codepage == 1)) {
write(door_out, outbuf, g);
} else {
if (conf.codepage == 0) {
ic = iconv_open(codepage, "CP437");
} else {
ic = iconv_open(codepage, "UTF-8");
}
ptr1 = outbuf;
ptr2 = (char *)malloc((g + 1) * 2);
memset(ptr2, 0, (g + 1) * 2);
inc = g;
ouc = g * 2;
iconv(ic, &ptr1, &inc, &ptr2, &ouc);
ptr2 = ptr2 - (g * 2 - ouc);
write(door_out, ptr2, strlen(ptr2));
free(ptr2);
iconv_close(ic);
}
} }
} else { } else {
if (!running_door) { if (!running_door) {

View File

@ -439,7 +439,7 @@ int do_download(struct user_record *user, char *file) {
arguments[0] = download_command; arguments[0] = download_command;
runexternal(user, download_command, conf.protocols[user->defprotocol - 1]->stdio, arguments, conf.bbs_path, 1); runexternal(user, download_command, conf.protocols[user->defprotocol - 1]->stdio, arguments, conf.bbs_path, 1, NULL);
free(arguments); free(arguments);
} }
@ -540,7 +540,7 @@ int do_upload(struct user_record *user, char *final_path) {
mkdir(upload_path, 0755); mkdir(upload_path, 0755);
runexternal(user, upload_command, conf.protocols[user->defprotocol - 1]->stdio, arguments, upload_path, 1); runexternal(user, upload_command, conf.protocols[user->defprotocol - 1]->stdio, arguments, upload_path, 1, NULL);
free(arguments); free(arguments);

View File

@ -100,8 +100,8 @@ int l_bbsMailScan(lua_State *L) {
int l_bbsRunDoor(lua_State *L) { int l_bbsRunDoor(lua_State *L) {
char *cmd = (char *)lua_tostring(L, 1); char *cmd = (char *)lua_tostring(L, 1);
int stdio = lua_toboolean(L, 2); int stdio = lua_toboolean(L, 2);
char *codepage = (char *)lua_tostring(L, 3);
rundoor(gUser, cmd, stdio); rundoor(gUser, cmd, stdio, codepage);
return 0; return 0;
} }

View File

@ -423,7 +423,7 @@ char *external_editor(struct user_record *user, char *to, char *from, char *quot
} }
fclose(fptr); fclose(fptr);
rundoor(user, conf.external_editor_cmd, conf.external_editor_stdio); rundoor(user, conf.external_editor_cmd, conf.external_editor_stdio, conf.external_editor_codepage);
// readin msgtmp // readin msgtmp
sprintf(buffer, "%s/node%d/MSGTMP", conf.bbs_path, mynode); sprintf(buffer, "%s/node%d/MSGTMP", conf.bbs_path, mynode);

10
main.c
View File

@ -210,6 +210,8 @@ static int door_config_handler(void* user, const char* section, const char* name
} else { } else {
conf->doors[i]->stdio = 0; conf->doors[i]->stdio = 0;
} }
} else if (strcasecmp(name, "codepage") == 0) {
conf->doors[i]->codepage = strdup(value);
} }
return 1; return 1;
} }
@ -224,6 +226,7 @@ static int door_config_handler(void* user, const char* section, const char* name
conf->doors[conf->door_count] = (struct door_config *)malloc(sizeof(struct door_config)); conf->doors[conf->door_count] = (struct door_config *)malloc(sizeof(struct door_config));
conf->doors[conf->door_count]->name = strdup(section); conf->doors[conf->door_count]->name = strdup(section);
conf->doors[conf->door_count]->codepage = NULL;
if (strcasecmp(name, "command") == 0) { if (strcasecmp(name, "command") == 0) {
conf->doors[conf->door_count]->command = strdup(value); conf->doors[conf->door_count]->command = strdup(value);
@ -233,6 +236,8 @@ static int door_config_handler(void* user, const char* section, const char* name
} else { } else {
conf->doors[conf->door_count]->stdio = 0; conf->doors[conf->door_count]->stdio = 0;
} }
} else if (strcasecmp(name, "codepage") == 0) {
conf->doors[conf->door_count]->codepage = strdup(value);
} }
conf->door_count++; conf->door_count++;
@ -434,6 +439,8 @@ static int handler(void* user, const char* section, const char* name,
conf->default_tagline = strdup(value); conf->default_tagline = strdup(value);
} else if (strcasecmp(name, "external editor cmd") == 0) { } else if (strcasecmp(name, "external editor cmd") == 0) {
conf->external_editor_cmd = strdup(value); conf->external_editor_cmd = strdup(value);
} else if (strcasecmp(name, "external editor codepage") == 0) {
conf->external_editor_codepage = strdup(value);
} else if (strcasecmp(name, "external editor stdio") == 0) { } else if (strcasecmp(name, "external editor stdio") == 0) {
if (strcasecmp(value, "true") == 0) { if (strcasecmp(value, "true") == 0) {
conf->external_editor_stdio = 1; conf->external_editor_stdio = 1;
@ -482,7 +489,7 @@ static int handler(void* user, const char* section, const char* name,
} else if (strcasecmp(name, "codepage") == 0) { } else if (strcasecmp(name, "codepage") == 0) {
if (strcasecmp(value, "cp437") == 0) { if (strcasecmp(value, "cp437") == 0) {
conf->codepage = 0; conf->codepage = 0;
} else if (strcasecmp(value, "utf8") == 0) { } else if (strcasecmp(value, "utf-8") == 0) {
conf->codepage = 1; conf->codepage = 1;
} }
} }
@ -1143,6 +1150,7 @@ int main(int argc, char **argv) {
conf.mgchat_bbstag = NULL; conf.mgchat_bbstag = NULL;
conf.text_file_count = 0; conf.text_file_count = 0;
conf.external_editor_cmd = NULL; conf.external_editor_cmd = NULL;
conf.external_editor_codepage = NULL;
conf.log_path = NULL; conf.log_path = NULL;
conf.script_path = NULL; conf.script_path = NULL;
conf.automsgwritelvl = 10; conf.automsgwritelvl = 10;

View File

@ -2,6 +2,7 @@
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h>
#include "bbs.h" #include "bbs.h"
#include "lua/lua.h" #include "lua/lua.h"
#include "lua/lualib.h" #include "lua/lualib.h"
@ -370,7 +371,7 @@ int menu_system(char *menufile) {
for (j=0;j<conf.door_count;j++) { for (j=0;j<conf.door_count;j++) {
if (strcasecmp(menu[i]->data, conf.doors[j]->name) == 0) { if (strcasecmp(menu[i]->data, conf.doors[j]->name) == 0) {
dolog("%s launched door %s, on node %d", gUser->loginname, conf.doors[j]->name, mynode); dolog("%s launched door %s, on node %d", gUser->loginname, conf.doors[j]->name, mynode);
rundoor(gUser, conf.doors[j]->command, conf.doors[j]->stdio); rundoor(gUser, conf.doors[j]->command, conf.doors[j]->stdio, conf.doors[j]->codepage);
dolog("%s returned from door %s, on node %d", gUser->loginname, conf.doors[j]->name, mynode); dolog("%s returned from door %s, on node %d", gUser->loginname, conf.doors[j]->name, mynode);
break; break;
} }