diff options
-rw-r--r-- | drv.c | 61 | ||||
-rw-r--r-- | drv.h | 15 | ||||
-rw-r--r-- | drv_BeckmannEgle.c | 8 | ||||
-rw-r--r-- | drv_Crystalfontz.c | 8 | ||||
-rw-r--r-- | drv_Curses.c | 8 | ||||
-rw-r--r-- | drv_Cwlinux.c | 8 | ||||
-rw-r--r-- | drv_HD44780.c | 50 | ||||
-rw-r--r-- | drv_Image.c | 8 | ||||
-rw-r--r-- | drv_M50530.c | 8 | ||||
-rw-r--r-- | drv_MatrixOrbital.c | 8 | ||||
-rw-r--r-- | drv_MilfordInstruments.c | 8 | ||||
-rw-r--r-- | drv_NULL.c | 8 | ||||
-rw-r--r-- | drv_T6963.c | 8 | ||||
-rw-r--r-- | drv_USBLCD.c | 8 | ||||
-rw-r--r-- | drv_X11.c | 8 | ||||
-rw-r--r-- | layout.c | 8 | ||||
-rw-r--r-- | lcd4linux.c | 87 | ||||
-rw-r--r-- | lcd4linux.conf.sample | 8 |
18 files changed, 211 insertions, 114 deletions
@@ -1,4 +1,4 @@ -/* $Id: drv.c,v 1.15 2004/05/31 16:39:06 reinelt Exp $ +/* $Id: drv.c,v 1.16 2004/06/02 09:41:19 reinelt Exp $ * * new framework for display drivers * @@ -23,6 +23,10 @@ * * * $Log: drv.c,v $ + * Revision 1.16 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.15 2004/05/31 16:39:06 reinelt * * added NULL display driver (for debugging/profiling purposes) @@ -203,13 +207,52 @@ DRIVER *Driver[] = { static DRIVER *Drv = NULL; +// Fixme +char* drv_hello (int line, int cols) +{ + int i; + static char *line1[] = { "* LCD4Linux " VERSION " *", + "LCD4Linux " VERSION, + "* LCD4Linux *", + "LCD4Linux", + "L4Linux", + NULL }; + + static char *line2[] = { "http://lcd4linux.sourceforge.net", + "lcd4linux.sourceforge.net", + "http://lcd4linux.sf.net", + "lcd4linux.sf.net", + NULL }; + + + switch (line) { + case 1: + for (i = 0; line1[i]; i++) { + if (strlen(line1[i]) <= cols) { + return line1[i]; + } + } + break; + case 2: + for (i = 0; line2[i]; i++) { + if (strlen(line2[i]) <= cols) { + return line2[i]; + } + } + break; + } + + return NULL; +} + + int drv_list (void) { int i; printf ("available display drivers:"); - for (i=0; Driver[i]; i++) { + for (i = 0; Driver[i]; i++) { printf ("\n %-20s: ", Driver[i]->name); if (Driver[i]->list) Driver[i]->list(); } @@ -218,14 +261,14 @@ int drv_list (void) } -int drv_init (char *section, char *driver) +int drv_init (char *section, char *driver, int quiet) { int i; - for (i=0; Driver[i]; i++) { - if (strcmp (Driver[i]->name, driver)==0) { - Drv=Driver[i]; - if (Drv->init==NULL) return 0; - return Drv->init(section); + for (i = 0; Driver[i]; i++) { + if (strcmp (Driver[i]->name, driver) == 0) { + Drv = Driver[i]; + if (Drv->init == NULL) return 0; + return Drv->init(section, quiet); } } error ("drv_init(%s) failed: no such driver", driver); @@ -235,6 +278,6 @@ int drv_init (char *section, char *driver) int drv_quit (void) { - if (Drv->quit==NULL) return 0; + if (Drv->quit == NULL) return 0; return Drv->quit(); } @@ -1,4 +1,4 @@ -/* $Id: drv.h,v 1.3 2004/01/20 15:32:49 reinelt Exp $ +/* $Id: drv.h,v 1.4 2004/06/02 09:41:19 reinelt Exp $ * * new framework for display drivers * @@ -23,6 +23,10 @@ * * * $Log: drv.h,v $ + * Revision 1.4 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.3 2004/01/20 15:32:49 reinelt * first version of Next Generation HD44780 (untested! but it compiles...) * some cleanup in the other drivers @@ -48,7 +52,8 @@ typedef struct DRIVER { char *name; int (*list) (void); - int (*init) (char *section); + int (*init) (char *section, int quiet); + int (*greet) (int start_stop); int (*quit) (void); } DRIVER; @@ -58,8 +63,8 @@ typedef struct DRIVER { // even if the raster driver is not included! extern char *output; -int drv_list (void); -int drv_init (char *section, char *driver); -int drv_quit (void); +int drv_list (void); +int drv_init (char *section, char *driver, int quiet); +int drv_quit (void); #endif diff --git a/drv_BeckmannEgle.c b/drv_BeckmannEgle.c index b6a6e40..11ac10e 100644 --- a/drv_BeckmannEgle.c +++ b/drv_BeckmannEgle.c @@ -1,4 +1,4 @@ -/* $Id: drv_BeckmannEgle.c,v 1.3 2004/06/02 05:14:16 reinelt Exp $ +/* $Id: drv_BeckmannEgle.c,v 1.4 2004/06/02 09:41:19 reinelt Exp $ * * driver for Beckmann+Egle mini terminals * Copyright 2000 Michael Reinelt <reinelt@eunet.at> @@ -22,6 +22,10 @@ * * * $Log: drv_BeckmannEgle.c,v $ + * Revision 1.4 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.3 2004/06/02 05:14:16 reinelt * * fixed models listing for Beckmann+Egle driver @@ -206,7 +210,7 @@ int drv_BE_list (void) // initialize driver & display -int drv_BE_init (char *section) +int drv_BE_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_Crystalfontz.c b/drv_Crystalfontz.c index 00d5397..0ab226c 100644 --- a/drv_Crystalfontz.c +++ b/drv_Crystalfontz.c @@ -1,4 +1,4 @@ -/* $Id: drv_Crystalfontz.c,v 1.22 2004/06/02 05:56:25 reinelt Exp $ +/* $Id: drv_Crystalfontz.c,v 1.23 2004/06/02 09:41:19 reinelt Exp $ * * new style driver for Crystalfontz display modules * @@ -23,6 +23,10 @@ * * * $Log: drv_Crystalfontz.c,v $ + * Revision 1.23 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.22 2004/06/02 05:56:25 reinelt * * extended contrast range for Crystalfontz @@ -904,7 +908,7 @@ int drv_CF_list (void) // initialize driver & display -int drv_CF_init (char *section) +int drv_CF_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_Curses.c b/drv_Curses.c index 8c94668..13e53e9 100644 --- a/drv_Curses.c +++ b/drv_Curses.c @@ -1,4 +1,4 @@ -/* $Id: drv_Curses.c,v 1.1 2004/05/26 11:37:36 reinelt Exp $ +/* $Id: drv_Curses.c,v 1.2 2004/06/02 09:41:19 reinelt Exp $ * * pure ncurses based text driver * @@ -26,6 +26,10 @@ * * * $Log: drv_Curses.c,v $ + * Revision 1.2 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.1 2004/05/26 11:37:36 reinelt * * Curses driver ported. @@ -214,7 +218,7 @@ int drv_Curs_list (void) // initialize driver & display -int drv_Curs_init (char *section) +int drv_Curs_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_Cwlinux.c b/drv_Cwlinux.c index 54e340a..fb1915e 100644 --- a/drv_Cwlinux.c +++ b/drv_Cwlinux.c @@ -1,4 +1,4 @@ -/* $Id: drv_Cwlinux.c,v 1.11 2004/06/01 06:45:29 reinelt Exp $ +/* $Id: drv_Cwlinux.c,v 1.12 2004/06/02 09:41:19 reinelt Exp $ * * new style driver for Cwlinux display modules * @@ -23,6 +23,10 @@ * * * $Log: drv_Cwlinux.c,v $ + * Revision 1.12 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.11 2004/06/01 06:45:29 reinelt * * some Fixme's processed @@ -341,7 +345,7 @@ int drv_CW_list (void) // initialize driver & display -int drv_CW_init (char *section) +int drv_CW_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_HD44780.c b/drv_HD44780.c index 026160a..6833dd9 100644 --- a/drv_HD44780.c +++ b/drv_HD44780.c @@ -1,4 +1,4 @@ -/* $Id: drv_HD44780.c,v 1.24 2004/06/01 06:45:29 reinelt Exp $ +/* $Id: drv_HD44780.c,v 1.25 2004/06/02 09:41:19 reinelt Exp $ * * new style driver for HD44780-based displays * @@ -29,6 +29,10 @@ * * * $Log: drv_HD44780.c,v $ + * Revision 1.25 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.24 2004/06/01 06:45:29 reinelt * * some Fixme's processed @@ -162,6 +166,7 @@ #include "debug.h" #include "cfg.h" #include "udelay.h" +#include "qprintf.h" #include "plugin.h" #include "widget.h" #include "widget_text.h" @@ -770,7 +775,7 @@ int drv_HD_list (void) // initialize driver & display -int drv_HD_init (char *section) +int drv_HD_init (char *section, int quiet) { WIDGET_CLASS wc; int asc255bug; @@ -836,6 +841,47 @@ int drv_HD_init (char *section) } +// say hello to the user +static int drv_HD_greet (int start_stop) +{ + int flag = 0; + char buffer[40]; + char *msg; + + drv_HD_command (allControllers, 0x01, T_CLEAR); // clear *both* displays + + msg = drv_hello (1, DCOLS); + if (msg != NULL) { + drv_HD_write (0, (DCOLS-strlen(msg))/2, msg, strlen(msg)); + flag = 1; + } + + if (DROWS >= 2) { + msg = drv_hello (2, DCOLS); + if (msg != NULL) { + drv_HD_write (1, (DCOLS-strlen(msg))/2, msg, strlen(msg)); + flag = 1; + } + } + + if (DROWS >= 3) { + qprintf(buffer, sizeof(buffer), "HD44780 %dx%d", DCOLS, DROWS); + msg = buffer; + if (strlen(msg) <= DCOLS) { + drv_HD_write (2, (DCOLS-strlen(msg))/2, msg, strlen(msg)); + flag = 1; + } + } + + if (flag && start_stop) { + sleep (3); + drv_HD_command (allControllers, 0x01, T_CLEAR); // clear *both* displays + } + + return 0; +} + + // close driver & display int drv_HD_quit (void) { diff --git a/drv_Image.c b/drv_Image.c index 82f4e9a..ab9a83b 100644 --- a/drv_Image.c +++ b/drv_Image.c @@ -1,4 +1,4 @@ -/* $Id: drv_Image.c,v 1.3 2004/05/31 06:24:42 reinelt Exp $ +/* $Id: drv_Image.c,v 1.4 2004/06/02 09:41:19 reinelt Exp $ * * new style Image (PPM/PNG) Driver for LCD4Linux * @@ -23,6 +23,10 @@ * * * $Log: drv_Image.c,v $ + * Revision 1.4 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.3 2004/05/31 06:24:42 reinelt * * fixed symlink security issue with the image driver @@ -472,7 +476,7 @@ int drv_IMG_list (void) // initialize driver & display -int drv_IMG_init (char *section) +int drv_IMG_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_M50530.c b/drv_M50530.c index 4d903c1..018862c 100644 --- a/drv_M50530.c +++ b/drv_M50530.c @@ -1,4 +1,4 @@ -/* $Id: drv_M50530.c,v 1.7 2004/06/01 06:45:29 reinelt Exp $ +/* $Id: drv_M50530.c,v 1.8 2004/06/02 09:41:19 reinelt Exp $ * * new style driver for M50530-based displays * @@ -23,6 +23,10 @@ * * * $Log: drv_M50530.c,v $ + * Revision 1.8 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.7 2004/06/01 06:45:29 reinelt * * some Fixme's processed @@ -296,7 +300,7 @@ int drv_M5_list (void) // initialize driver & display -int drv_M5_init (char *section) +int drv_M5_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_MatrixOrbital.c b/drv_MatrixOrbital.c index ee09de0..26ef3a6 100644 --- a/drv_MatrixOrbital.c +++ b/drv_MatrixOrbital.c @@ -1,4 +1,4 @@ -/* $Id: drv_MatrixOrbital.c,v 1.28 2004/06/01 06:45:29 reinelt Exp $ +/* $Id: drv_MatrixOrbital.c,v 1.29 2004/06/02 09:41:19 reinelt Exp $ * * new style driver for Matrix Orbital serial display modules * @@ -23,6 +23,10 @@ * * * $Log: drv_MatrixOrbital.c,v $ + * Revision 1.29 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.28 2004/06/01 06:45:29 reinelt * * some Fixme's processed @@ -614,7 +618,7 @@ int drv_MO_list (void) // initialize driver & display -int drv_MO_init (char *section) +int drv_MO_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_MilfordInstruments.c b/drv_MilfordInstruments.c index d68f3eb..32b29ab 100644 --- a/drv_MilfordInstruments.c +++ b/drv_MilfordInstruments.c @@ -1,4 +1,4 @@ -/* $Id: drv_MilfordInstruments.c,v 1.5 2004/05/31 05:38:02 reinelt Exp $ +/* $Id: drv_MilfordInstruments.c,v 1.6 2004/06/02 09:41:19 reinelt Exp $ * * driver for Milford Instruments 'BPK' piggy-back serial interface board * for standard Hitachi 44780 compatible lcd modules. @@ -27,6 +27,10 @@ * * * $Log: drv_MilfordInstruments.c,v $ + * Revision 1.6 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.5 2004/05/31 05:38:02 reinelt * * fixed possible bugs with user-defined chars (clear high bits) @@ -196,7 +200,7 @@ int drv_MI_list (void) // initialize driver & display -int drv_MI_init (char *section) +int drv_MI_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; @@ -1,4 +1,4 @@ -/* $Id: drv_NULL.c,v 1.1 2004/05/31 16:39:06 reinelt Exp $ +/* $Id: drv_NULL.c,v 1.2 2004/06/02 09:41:19 reinelt Exp $ * * NULL driver (for testing) * @@ -23,6 +23,10 @@ * * * $Log: drv_NULL.c,v $ + * Revision 1.2 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.1 2004/05/31 16:39:06 reinelt * * added NULL display driver (for debugging/profiling purposes) @@ -124,7 +128,7 @@ int drv_NULL_list (void) // initialize driver & display -int drv_NULL_init (char *section) +int drv_NULL_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_T6963.c b/drv_T6963.c index 151cfe9..fc74475 100644 --- a/drv_T6963.c +++ b/drv_T6963.c @@ -1,4 +1,4 @@ -/* $Id: drv_T6963.c,v 1.5 2004/06/01 06:45:30 reinelt Exp $ +/* $Id: drv_T6963.c,v 1.6 2004/06/02 09:41:19 reinelt Exp $ * * new style driver for T6963-based displays * @@ -23,6 +23,10 @@ * * * $Log: drv_T6963.c,v $ + * Revision 1.6 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.5 2004/06/01 06:45:30 reinelt * * some Fixme's processed @@ -512,7 +516,7 @@ int drv_T6_list (void) // initialize driver & display -int drv_T6_init (char *section) +int drv_T6_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; diff --git a/drv_USBLCD.c b/drv_USBLCD.c index 17c2cd2..a185e13 100644 --- a/drv_USBLCD.c +++ b/drv_USBLCD.c @@ -1,4 +1,4 @@ -/* $Id: drv_USBLCD.c,v 1.5 2004/05/31 05:38:02 reinelt Exp $ +/* $Id: drv_USBLCD.c,v 1.6 2004/06/02 09:41:19 reinelt Exp $ * * new style driver for USBLCD displays * @@ -26,6 +26,10 @@ * * * $Log: drv_USBLCD.c,v $ + * Revision 1.6 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.5 2004/05/31 05:38:02 reinelt * * fixed possible bugs with user-defined chars (clear high bits) @@ -289,7 +293,7 @@ int drv_UL_list (void) // initialize driver & display -int drv_UL_init (char *section) +int drv_UL_init (char *section, int quiet) { WIDGET_CLASS wc; int asc255bug; @@ -1,4 +1,4 @@ -/* $Id: drv_X11.c,v 1.2 2004/05/25 14:26:29 reinelt Exp $ +/* $Id: drv_X11.c,v 1.3 2004/06/02 09:41:19 reinelt Exp $ * * new style X11 Driver for LCD4Linux * @@ -26,6 +26,10 @@ * * * $Log: drv_X11.c,v $ + * Revision 1.3 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.2 2004/05/25 14:26:29 reinelt * * added "Image" driver (was: Raster.c) for PPM and PNG creation @@ -337,7 +341,7 @@ int drv_X11_list (void) // initialize driver & display -int drv_X11_init (char *section) +int drv_X11_init (char *section, int quiet) { WIDGET_CLASS wc; int ret; @@ -1,4 +1,4 @@ -/* $Id: layout.c,v 1.10 2004/03/03 03:47:04 reinelt Exp $ +/* $Id: layout.c,v 1.11 2004/06/02 09:41:19 reinelt Exp $ * * new layouter framework * @@ -23,6 +23,10 @@ * * * $Log: layout.c,v $ + * Revision 1.11 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.10 2004/03/03 03:47:04 reinelt * big patch from Martin Hejl: * - use qprintf() where appropriate @@ -134,7 +138,7 @@ int layout_init (char *layout) if (widget!=NULL && *widget!='\0') { layout_addItem (widget, row, col); } - free(widget); + free(widget); } // next field l=p?p+1:NULL; diff --git a/lcd4linux.c b/lcd4linux.c index 20c6ed7..857100e 100644 --- a/lcd4linux.c +++ b/lcd4linux.c @@ -1,4 +1,4 @@ -/* $Id: lcd4linux.c,v 1.70 2004/06/02 05:14:16 reinelt Exp $ +/* $Id: lcd4linux.c,v 1.71 2004/06/02 09:41:19 reinelt Exp $ * * LCD4Linux * @@ -23,6 +23,10 @@ * * * $Log: lcd4linux.c,v $ + * Revision 1.71 2004/06/02 09:41:19 reinelt + * + * prepared support for startup splash screen + * * Revision 1.70 2004/06/02 05:14:16 reinelt * * fixed models listing for Beckmann+Egle driver @@ -383,46 +387,6 @@ static void usage(void) printf (" lcd4linux [-c key=value] [-F] [-f config-file] [-o output-file] [-q] [-v]\n"); } -#if 0 -// Fixme: how to hello() with new layout? -int hello (void) -{ - int i, x, y, flag; - char *line1[] = { "* LCD4Linux " VERSION " *", - "LCD4Linux " VERSION, - "LCD4Linux", - "L4Linux", - NULL }; - - char *line2[] = { "(c) 2003 M.Reinelt", - "(c) M.Reinelt", - NULL }; - - lcd_query (&y, &x, NULL, NULL, NULL, NULL, NULL); - - flag=0; - for (i=0; line1[i]; i++) { - if (strlen(line1[i])<=x) { - lcd_put (1, (x-strlen(line1[i]))/2+1, line1[i]); - flag=1; - break; - } - } - - for (i=0; line2[i]; i++) { - if (strlen(line2[i])<=x) { - lcd_put (2, (x-strlen(line2[i]))/2+1, line2[i]); - flag=1; - break; - } - } - - if (flag) lcd_flush(); - return flag; -} -#endif - - static void interactive_mode (void) { char line[1024]; @@ -596,7 +560,7 @@ int main (int argc, char *argv[]) // create PID file if ((pid = pid_init(PIDFILE)) != 0) { - error ("lcd4linux already running as process %d", pid) + error ("lcd4linux already running as process %d", pid); exit (1); } @@ -612,23 +576,18 @@ int main (int argc, char *argv[]) exit (0); } + // check the conf to see if quiet startup is wanted + if (!quiet) { + cfg_number(NULL, "Quiet", 0, 0, 1, &quiet); + } + debug ("initializing driver %s", driver); - if (drv_init(section, driver)==-1) { + if (drv_init(section, driver, quiet)==-1) { pid_exit(PIDFILE); exit (1); } free(driver); - // check for new-style layout - layout=cfg_get(NULL, "Layout", NULL); - if (layout==NULL || *layout=='\0') { - error ("missing 'Layout' entry in %s!", cfg_source()); - exit (1); - } - - layout_init(layout); - free(layout); - // go into interactive mode (display has been initialized) if (interactive >= 1) { interactive_mode(); @@ -638,18 +597,15 @@ int main (int argc, char *argv[]) exit (0); } - // check the conf to see if quiet startup is wanted - if (!quiet) { - cfg_number(NULL, "Quiet", 0, 0, 1, &quiet); + // check for new-style layout + layout=cfg_get(NULL, "Layout", NULL); + if (layout==NULL || *layout=='\0') { + error ("missing 'Layout' entry in %s!", cfg_source()); + exit (1); } -#if 0 - // Fixme: how to hello() with new layout? - if (!quiet && hello()) { - sleep (3); - lcd_clear(1); - } -#endif + layout_init(layout); + free(layout); debug ("starting main loop"); @@ -667,11 +623,6 @@ int main (int argc, char *argv[]) debug ("leaving main loop"); -#if 0 - // Fixme: how to hello() with new layout? - lcd_clear(1); - if (!quiet) hello(); -#endif drv_quit(); pid_exit(PIDFILE); cfg_exit(); diff --git a/lcd4linux.conf.sample b/lcd4linux.conf.sample index c8ef7ed..1892354 100644 --- a/lcd4linux.conf.sample +++ b/lcd4linux.conf.sample @@ -544,7 +544,7 @@ Layout testMySQL { #Display 'LK204' #Display 'MI240' #Display 'CW12232' -#Display 'HD44780-20x4' +Display 'HD44780-20x4' #Display 'M50530-24x8' #Display 'CF631' #Display 'CF632' @@ -553,11 +553,11 @@ Layout testMySQL { #Display 'USBLCD' #Display 'T6963-240x64' #Display 'XWindow' -Display 'Image' +#Display 'Image' -#Layout 'Default' +Layout 'Default' #Layout 'L16x2' -Layout 'L20x2' +#Layout 'L20x2' #Layout 'Test' |