1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

UTF-8: Change type of constants to struct screen_driver_opt.

We don't need a full struct screen_driver here.
This commit is contained in:
Kalle Olavi Niemitalo 2007-05-19 09:24:08 +03:00 committed by Witold Filipczyk
parent 3786dd9265
commit 5261cd17d1

View File

@ -143,10 +143,7 @@ struct screen_driver {
unsigned char name[1]; /* XXX: Keep last! */ unsigned char name[1]; /* XXX: Keep last! */
}; };
static const struct screen_driver dumb_screen_driver = { static const struct screen_driver_opt dumb_screen_driver_opt = {
NULL_LIST_HEAD,
/* type: */ TERM_DUMB,
{
#ifndef CONFIG_UTF8 #ifndef CONFIG_UTF8
/* charsets: */ { -1, -1 }, /* No UTF8 I/O */ /* charsets: */ { -1, -1 }, /* No UTF8 I/O */
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
@ -158,13 +155,9 @@ static const struct screen_driver dumb_screen_driver = {
#ifdef CONFIG_UTF8 #ifdef CONFIG_UTF8
/* utf-8: */ 0, /* utf-8: */ 0,
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
}
}; };
static const struct screen_driver vt100_screen_driver = { static const struct screen_driver_opt vt100_screen_driver_opt = {
NULL_LIST_HEAD,
/* type: */ TERM_VT100,
{
#ifndef CONFIG_UTF8 #ifndef CONFIG_UTF8
/* charsets: */ { -1, -1 }, /* No UTF8 I/O */ /* charsets: */ { -1, -1 }, /* No UTF8 I/O */
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
@ -176,13 +169,9 @@ static const struct screen_driver vt100_screen_driver = {
#ifdef CONFIG_UTF8 #ifdef CONFIG_UTF8
/* utf-8: */ 0, /* utf-8: */ 0,
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
}
}; };
static const struct screen_driver linux_screen_driver = { static const struct screen_driver_opt linux_screen_driver_opt = {
NULL_LIST_HEAD,
/* type: */ TERM_LINUX,
{
#ifndef CONFIG_UTF8 #ifndef CONFIG_UTF8
/* charsets: */ { -1, -1 }, /* No UTF8 I/O */ /* charsets: */ { -1, -1 }, /* No UTF8 I/O */
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
@ -194,13 +183,9 @@ static const struct screen_driver linux_screen_driver = {
#ifdef CONFIG_UTF8 #ifdef CONFIG_UTF8
/* utf-8: */ 0, /* utf-8: */ 0,
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
}
}; };
static const struct screen_driver koi8_screen_driver = { static const struct screen_driver_opt koi8_screen_driver_opt = {
NULL_LIST_HEAD,
/* type: */ TERM_KOI8,
{
#ifndef CONFIG_UTF8 #ifndef CONFIG_UTF8
/* charsets: */ { -1, -1 }, /* No UTF8 I/O */ /* charsets: */ { -1, -1 }, /* No UTF8 I/O */
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
@ -212,13 +197,9 @@ static const struct screen_driver koi8_screen_driver = {
#ifdef CONFIG_UTF8 #ifdef CONFIG_UTF8
/* utf-8: */ 0, /* utf-8: */ 0,
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
}
}; };
static const struct screen_driver freebsd_screen_driver = { static const struct screen_driver_opt freebsd_screen_driver_opt = {
NULL_LIST_HEAD,
/* type: */ TERM_FREEBSD,
{
#ifndef CONFIG_UTF8 #ifndef CONFIG_UTF8
/* charsets: */ { -1, -1 }, /* No UTF8 I/O */ /* charsets: */ { -1, -1 }, /* No UTF8 I/O */
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
@ -230,16 +211,15 @@ static const struct screen_driver freebsd_screen_driver = {
#ifdef CONFIG_UTF8 #ifdef CONFIG_UTF8
/* utf-8: */ 0, /* utf-8: */ 0,
#endif /* CONFIG_UTF8 */ #endif /* CONFIG_UTF8 */
}
}; };
/* XXX: Keep in sync with enum term_mode_type. */ /* XXX: Keep in sync with enum term_mode_type. */
static const struct screen_driver *const screen_drivers[] = { static const struct screen_driver_opt *const screen_driver_opts[] = {
/* TERM_DUMB: */ &dumb_screen_driver, /* TERM_DUMB: */ &dumb_screen_driver_opt,
/* TERM_VT100: */ &vt100_screen_driver, /* TERM_VT100: */ &vt100_screen_driver_opt,
/* TERM_LINUX: */ &linux_screen_driver, /* TERM_LINUX: */ &linux_screen_driver_opt,
/* TERM_KOI8: */ &koi8_screen_driver, /* TERM_KOI8: */ &koi8_screen_driver_opt,
/* TERM_FREEBSD: */ &freebsd_screen_driver, /* TERM_FREEBSD: */ &freebsd_screen_driver_opt,
}; };
#ifdef CONFIG_UTF8 #ifdef CONFIG_UTF8
@ -260,7 +240,7 @@ set_screen_driver_opt(struct screen_driver *driver, struct option *term_spec)
/* Copy all the original options from constants, so that this /* Copy all the original options from constants, so that this
* function need not carefully restore options one by one. */ * function need not carefully restore options one by one. */
copy_struct(&driver->opt, &screen_drivers[driver->type]->opt); copy_struct(&driver->opt, screen_driver_opts[driver->type]);
#ifdef CONFIG_UTF8 #ifdef CONFIG_UTF8
/* Force UTF-8 I/O if the UTF-8 charset is selected. Various /* Force UTF-8 I/O if the UTF-8 charset is selected. Various