Adjusted telnet server to the new shell logic.

This commit is contained in:
oliverschmidt 2008-02-09 17:15:58 +00:00
parent 081d50b878
commit b1c748c137
4 changed files with 45 additions and 28 deletions

View File

@ -1,3 +1,5 @@
telnetd_src = telnetd.c memb.c shell.c telnetd_src = telnetd.c memb.c \
shell.c shell-file.c shell-ps.c shell-run.c \
shell-text.c shell-time.c list.c random.c
telnetd_dsc = telnetd-dsc.c telnetd_dsc = telnetd-dsc.c
APPDIRS += $(CONTIKI)/apps/shell APPDIRS += $(CONTIKI)/apps/shell

View File

@ -28,7 +28,7 @@
* *
* This file is part of the Contiki desktop OS. * This file is part of the Contiki desktop OS.
* *
* $Id: telnetd-gui.c,v 1.2 2007/04/13 22:02:28 oliverschmidt Exp $ * $Id: telnetd-gui.c,v 1.3 2008/02/09 17:15:58 oliverschmidt Exp $
* *
*/ */
@ -54,20 +54,20 @@ static struct ctk_label loglabel =
/*-----------------------------------------------------------------------------------*/ /*-----------------------------------------------------------------------------------*/
void void
telnetd_gui_output(char *str1, char *str2) telnetd_gui_output(const char *str1, int len1, const char *str2, int len2)
{ {
static unsigned int len, i; static unsigned int i;
for(i = 1; i < YSIZE; ++i) { for(i = 1; i < YSIZE; ++i) {
memcpy(&log[(i - 1) * XSIZE], &log[i * XSIZE], XSIZE); memcpy(&log[(i - 1) * XSIZE], &log[i * XSIZE], XSIZE);
} }
memset(&log[(YSIZE - 1) * XSIZE], 0, XSIZE);
len = (unsigned int)strlen(str1);
strncpy(&log[(YSIZE - 1) * XSIZE], str1, XSIZE); strncpy(&log[(YSIZE - 1) * XSIZE], str1, XSIZE);
if(len < XSIZE) { if(len1 < XSIZE) {
strncpy(&log[(YSIZE - 1) * XSIZE] + len, str2, XSIZE - len); strncpy(&log[(YSIZE - 1) * XSIZE] + len1, str2, XSIZE - len1);
if(len1 + len2 < XSIZE) {
log[(YSIZE - 1) * XSIZE + len1 + len2] = 0;
}
} }
CTK_WIDGET_REDRAW(&loglabel); CTK_WIDGET_REDRAW(&loglabel);

View File

@ -28,20 +28,19 @@
* *
* This file is part of the Contiki desktop OS. * This file is part of the Contiki desktop OS.
* *
* $Id: telnetd.c,v 1.7 2007/11/17 20:13:54 oliverschmidt Exp $ * $Id: telnetd.c,v 1.8 2008/02/09 17:15:58 oliverschmidt Exp $
* *
*/ */
#include <string.h>
#include "contiki-lib.h"
#include "contiki-net.h" #include "contiki-net.h"
#include "lib/petsciiconv.h" #include "lib/petsciiconv.h"
#include "contiki-lib.h"
#include "shell.h" #include "shell.h"
#include "telnetd.h" #include "telnetd.h"
#include <string.h>
#define ISO_nl 0x0a #define ISO_nl 0x0a
#define ISO_cr 0x0d #define ISO_cr 0x0d
@ -50,6 +49,8 @@
PROCESS(telnetd_process, "Shell server"); PROCESS(telnetd_process, "Shell server");
AUTOSTART_PROCESSES(&telnetd_process);
#ifndef TELNETD_CONF_LINELEN #ifndef TELNETD_CONF_LINELEN
#define TELNETD_CONF_LINELEN 40 #define TELNETD_CONF_LINELEN 40
#endif #endif
@ -58,13 +59,13 @@ PROCESS(telnetd_process, "Shell server");
#endif #endif
struct telnetd_line { struct telnetd_line {
char line[TELNETD_CONF_LINELEN]; char line[TELNETD_CONF_LINELEN + 1];
}; };
MEMB(linemem, struct telnetd_line, TELNETD_CONF_NUMLINES); MEMB(linemem, struct telnetd_line, TELNETD_CONF_NUMLINES);
struct telnetd_state { struct telnetd_state {
char *lines[TELNETD_CONF_NUMLINES]; char *lines[TELNETD_CONF_NUMLINES];
char buf[TELNETD_CONF_LINELEN]; char buf[TELNETD_CONF_LINELEN + 1];
char bufptr; char bufptr;
u8_t numsent; u8_t numsent;
u8_t state; u8_t state;
@ -142,20 +143,30 @@ shell_prompt(char *str)
} }
/*-----------------------------------------------------------------------------------*/ /*-----------------------------------------------------------------------------------*/
void void
shell_output(char *str1, char *str2) shell_default_output(const char *str1, int len1, const char *str2, int len2)
{ {
static unsigned len; static unsigned len;
char *line; char *line;
if(str1[len1 - 1] == '\n') {
--len1;
}
if(str2[len2 - 1] == '\n') {
--len2;
}
#if TELNETD_CONF_GUI #if TELNETD_CONF_GUI
telnetd_gui_output(str1, str2); telnetd_gui_output(str1, len1, str2, len2);
#endif /* TELNETD_CONF_GUI */ #endif /* TELNETD_CONF_GUI */
line = alloc_line(); line = alloc_line();
if(line != NULL) { if(line != NULL) {
len = (unsigned int)strlen(str1); line[TELNETD_CONF_LINELEN] = 0;
strncpy(line, str1, TELNETD_CONF_LINELEN); strncpy(line, str1, TELNETD_CONF_LINELEN);
if(len < TELNETD_CONF_LINELEN) { if(len1 < TELNETD_CONF_LINELEN) {
strncpy(line + len, str2, TELNETD_CONF_LINELEN - len); strncpy(line + len1, str2, TELNETD_CONF_LINELEN - len1);
if(len1 + len2 < TELNETD_CONF_LINELEN) {
line[len1 + len2] = 0;
}
} }
len = (unsigned int)strlen(line); len = (unsigned int)strlen(line);
if(len < TELNETD_CONF_LINELEN - 2) { if(len < TELNETD_CONF_LINELEN - 2) {
@ -174,7 +185,14 @@ PROCESS_THREAD(telnetd_process, ev, data)
tcp_listen(HTONS(23)); tcp_listen(HTONS(23));
memb_init(&linemem); memb_init(&linemem);
shell_init(); shell_init();
shell_file_init();
shell_ps_init();
shell_run_init();
shell_text_init();
shell_time_init();
#if TELNETD_CONF_GUI #if TELNETD_CONF_GUI
telnetd_gui_init(); telnetd_gui_init();
#endif /* TELNETD_CONF_GUI */ #endif /* TELNETD_CONF_GUI */
@ -186,7 +204,6 @@ PROCESS_THREAD(telnetd_process, ev, data)
} else if(ev == PROCESS_EVENT_EXIT) { } else if(ev == PROCESS_EVENT_EXIT) {
telnetd_quit(); telnetd_quit();
} else { } else {
shell_eventhandler(ev, data);
#if TELNETD_CONF_GUI #if TELNETD_CONF_GUI
telnetd_gui_eventhandler(ev, data); telnetd_gui_eventhandler(ev, data);
#endif /* TELNETD_CONF_GUI */ #endif /* TELNETD_CONF_GUI */
@ -263,7 +280,7 @@ get_char(u8_t c)
s.buf[(int)s.bufptr] = 0; s.buf[(int)s.bufptr] = 0;
petsciiconv_topetscii(s.buf, TELNETD_CONF_LINELEN); petsciiconv_topetscii(s.buf, TELNETD_CONF_LINELEN);
} }
shell_input(s.buf); shell_input(s.buf, s.bufptr);
s.bufptr = 0; s.bufptr = 0;
} else { } else {
++s.bufptr; ++s.bufptr;
@ -364,8 +381,6 @@ telnetd_appcall(void *ts)
} }
s.bufptr = 0; s.bufptr = 0;
s.state = STATE_NORMAL; s.state = STATE_NORMAL;
shell_start();
} }
if(s.state == STATE_CLOSE) { if(s.state == STATE_CLOSE) {

View File

@ -29,7 +29,7 @@
* *
* This file is part of the Contiki desktop environment * This file is part of the Contiki desktop environment
* *
* $Id: telnetd.h,v 1.3 2007/11/30 11:15:41 oliverschmidt Exp $ * $Id: telnetd.h,v 1.4 2008/02/09 17:15:58 oliverschmidt Exp $
* *
*/ */
#ifndef __TELNETD_H__ #ifndef __TELNETD_H__
@ -42,7 +42,7 @@ PROCESS_NAME(telnetd_process);
void telnetd_gui_eventhandler(process_event_t ev, process_data_t data); void telnetd_gui_eventhandler(process_event_t ev, process_data_t data);
void telnetd_appcall(void *data); void telnetd_appcall(void *data);
void telnetd_gui_init(void); void telnetd_gui_init(void);
void telnetd_gui_output(char *str1, char *str2); void telnetd_gui_output(const char *str1, int len1, const char *str2, int len2);
void telnetd_gui_quit(void); void telnetd_gui_quit(void);
void telnetd_quit(void); void telnetd_quit(void);