diff options
author | Jeremy Katz <katzj@redhat.com> | 2003-02-11 05:25:25 +0000 |
---|---|---|
committer | Jeremy Katz <katzj@redhat.com> | 2003-02-11 05:25:25 +0000 |
commit | 4c1e84038ff95cd5b4fef0d8928a525e3822106d (patch) | |
tree | ae9bf398c51398598067bed864d5c06e491dad18 /isys/lang.c | |
parent | 39b46a6cbf9e3f5152e88f22c61e1e38dd2c4016 (diff) | |
download | anaconda-4c1e84038ff95cd5b4fef0d8928a525e3822106d.tar.gz anaconda-4c1e84038ff95cd5b4fef0d8928a525e3822106d.tar.xz anaconda-4c1e84038ff95cd5b4fef0d8928a525e3822106d.zip |
put start bterm in lang.c, bind from python
Diffstat (limited to 'isys/lang.c')
-rw-r--r-- | isys/lang.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/isys/lang.c b/isys/lang.c index 7b00d6dde..74e09a53c 100644 --- a/isys/lang.c +++ b/isys/lang.c @@ -5,6 +5,7 @@ #include <stdlib.h> #include <string.h> #include <sys/ioctl.h> +#include <sys/stat.h> #include <unistd.h> #include <linux/keyboard.h> @@ -161,3 +162,30 @@ int isysLoadKeymap(char * keymap) { return rc; } + +/* returns 0 on success, 1 on failure */ +extern int bterm_main(int argc, char **argv); + +int isysStartBterm(void) { + char * btermargs[4] = { "bterm", "-s", "-f", NULL }; + int rc; + struct stat sb; + + /* assume that if we're already on a pty we can handle unicode */ + fstat(0, &sb); + if (major(sb.st_rdev) == 3 || major(sb.st_rdev) == 136) + return 0; + + if (!access("/etc/font.bgf.gz", R_OK)) + btermargs[3] = "/etc/font.bgf.gz"; + else if (!access("/usr/lib/bogl/font.bgf.gz", R_OK)) + btermargs[3] = "/usr/lib/bogl/font.bgf.gz"; + else if (!access("font.bgf.gz", R_OK)) + btermargs[3] = "font.bgf.gz"; + else + return 0; + + rc = bterm_main(4, btermargs); + + return rc; +} |