[lcd4linux @ 2004-06-02 09:41:19 by reinelt]

prepared support for startup splash screen

git-svn-id: https://ssl.bulix.org/svn/lcd4linux/trunk@461 3ae390bd-cb1e-0410-b409-cd5a39f66f1f
This commit is contained in:
reinelt
2004-06-02 09:41:19 +00:00
parent b07a5205b1
commit 246b8539fe
18 changed files with 211 additions and 114 deletions

61
drv.c
View File

@@ -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();
}

15
drv.h
View File

@@ -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

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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) {

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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;

View File

@@ -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();

View File

@@ -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'