curses 1.4.5 → 1.4.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (249) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/push_gem.yml +48 -0
  3. data/History.md +3 -0
  4. data/curses.gemspec +1 -1
  5. metadata +8 -247
  6. data/vendor/PDCurses/.gitignore +0 -47
  7. data/vendor/PDCurses/.travis.yml +0 -49
  8. data/vendor/PDCurses/CMakeLists.txt +0 -68
  9. data/vendor/PDCurses/HISTORY.md +0 -2036
  10. data/vendor/PDCurses/IMPLEMNT.md +0 -327
  11. data/vendor/PDCurses/Makefile +0 -27
  12. data/vendor/PDCurses/README.md +0 -77
  13. data/vendor/PDCurses/acs_defs.h +0 -265
  14. data/vendor/PDCurses/appveyor.yml +0 -218
  15. data/vendor/PDCurses/cmake/README.md +0 -71
  16. data/vendor/PDCurses/cmake/build_dependencies.cmake +0 -178
  17. data/vendor/PDCurses/cmake/build_options.cmake +0 -25
  18. data/vendor/PDCurses/cmake/dll_version.cmake +0 -26
  19. data/vendor/PDCurses/cmake/gen_config_header.cmake +0 -43
  20. data/vendor/PDCurses/cmake/get_version.cmake +0 -17
  21. data/vendor/PDCurses/cmake/make_uninstall.cmake +0 -19
  22. data/vendor/PDCurses/cmake/project_common.cmake +0 -121
  23. data/vendor/PDCurses/cmake/resource.in.cmake +0 -52
  24. data/vendor/PDCurses/cmake/sdl2_ttf/CMakeLists.txt +0 -83
  25. data/vendor/PDCurses/cmake/target_arch.cmake +0 -36
  26. data/vendor/PDCurses/cmake/version.in.cmake +0 -73
  27. data/vendor/PDCurses/cmake/watcom_open_dos16_toolchain.cmake +0 -96
  28. data/vendor/PDCurses/cmake/watcom_open_dos32_toolchain.cmake +0 -106
  29. data/vendor/PDCurses/cmake/watcom_open_os2v2_toolchain.cmake +0 -105
  30. data/vendor/PDCurses/curses.h +0 -1846
  31. data/vendor/PDCurses/curspriv.h +0 -134
  32. data/vendor/PDCurses/demos/README.md +0 -25
  33. data/vendor/PDCurses/demos/firework.c +0 -144
  34. data/vendor/PDCurses/demos/newtest.c +0 -581
  35. data/vendor/PDCurses/demos/ozdemo.c +0 -447
  36. data/vendor/PDCurses/demos/ptest.c +0 -283
  37. data/vendor/PDCurses/demos/rain.c +0 -157
  38. data/vendor/PDCurses/demos/testcurs.c +0 -1607
  39. data/vendor/PDCurses/demos/tui.c +0 -1048
  40. data/vendor/PDCurses/demos/tui.h +0 -65
  41. data/vendor/PDCurses/demos/tuidemo.c +0 -233
  42. data/vendor/PDCurses/demos/version.c +0 -61
  43. data/vendor/PDCurses/demos/worm.c +0 -432
  44. data/vendor/PDCurses/demos/xmas.c +0 -955
  45. data/vendor/PDCurses/dos/CMakeLists.txt +0 -47
  46. data/vendor/PDCurses/dos/Makefile +0 -105
  47. data/vendor/PDCurses/dos/Makefile.bcc +0 -83
  48. data/vendor/PDCurses/dos/Makefile.dmc +0 -257
  49. data/vendor/PDCurses/dos/Makefile.msc +0 -113
  50. data/vendor/PDCurses/dos/Makefile.wcc +0 -107
  51. data/vendor/PDCurses/dos/README.md +0 -51
  52. data/vendor/PDCurses/dos/bccdos.lrf +0 -9
  53. data/vendor/PDCurses/dos/mscdos.lrf +0 -50
  54. data/vendor/PDCurses/dos/pdcclip.c +0 -132
  55. data/vendor/PDCurses/dos/pdcdisp.c +0 -135
  56. data/vendor/PDCurses/dos/pdcdos.h +0 -194
  57. data/vendor/PDCurses/dos/pdcgetsc.c +0 -98
  58. data/vendor/PDCurses/dos/pdckbd.c +0 -513
  59. data/vendor/PDCurses/dos/pdcscrn.c +0 -785
  60. data/vendor/PDCurses/dos/pdcsetsc.c +0 -101
  61. data/vendor/PDCurses/dos/pdcutil.c +0 -212
  62. data/vendor/PDCurses/libobjs.mif +0 -26
  63. data/vendor/PDCurses/makedist.mif +0 -20
  64. data/vendor/PDCurses/man/Makefile +0 -37
  65. data/vendor/PDCurses/man/README.md +0 -21
  66. data/vendor/PDCurses/man/intro.md +0 -361
  67. data/vendor/PDCurses/man/manext.c +0 -119
  68. data/vendor/PDCurses/man/sdl.md +0 -152
  69. data/vendor/PDCurses/man/sdl2.md +0 -58
  70. data/vendor/PDCurses/man/x11.md +0 -407
  71. data/vendor/PDCurses/ncurses/CMakeLists.txt +0 -66
  72. data/vendor/PDCurses/ncurses/README.md +0 -26
  73. data/vendor/PDCurses/ncurses/makefile +0 -29
  74. data/vendor/PDCurses/os2/CMakeLists.txt +0 -41
  75. data/vendor/PDCurses/os2/Makefile +0 -132
  76. data/vendor/PDCurses/os2/Makefile.bcc +0 -90
  77. data/vendor/PDCurses/os2/Makefile.wcc +0 -43
  78. data/vendor/PDCurses/os2/README.md +0 -43
  79. data/vendor/PDCurses/os2/iccos2.lrf +0 -50
  80. data/vendor/PDCurses/os2/iccos2.mak +0 -256
  81. data/vendor/PDCurses/os2/pdcclip.c +0 -188
  82. data/vendor/PDCurses/os2/pdcdisp.c +0 -93
  83. data/vendor/PDCurses/os2/pdcgetsc.c +0 -89
  84. data/vendor/PDCurses/os2/pdckbd.c +0 -521
  85. data/vendor/PDCurses/os2/pdcos2.h +0 -55
  86. data/vendor/PDCurses/os2/pdcscrn.c +0 -449
  87. data/vendor/PDCurses/os2/pdcsetsc.c +0 -112
  88. data/vendor/PDCurses/os2/pdcutil.c +0 -52
  89. data/vendor/PDCurses/panel.h +0 -56
  90. data/vendor/PDCurses/pdcurses/README.md +0 -25
  91. data/vendor/PDCurses/pdcurses/addch.c +0 -693
  92. data/vendor/PDCurses/pdcurses/addchstr.c +0 -245
  93. data/vendor/PDCurses/pdcurses/addstr.c +0 -240
  94. data/vendor/PDCurses/pdcurses/attr.c +0 -359
  95. data/vendor/PDCurses/pdcurses/beep.c +0 -68
  96. data/vendor/PDCurses/pdcurses/bkgd.c +0 -223
  97. data/vendor/PDCurses/pdcurses/border.c +0 -411
  98. data/vendor/PDCurses/pdcurses/clear.c +0 -159
  99. data/vendor/PDCurses/pdcurses/color.c +0 -298
  100. data/vendor/PDCurses/pdcurses/debug.c +0 -109
  101. data/vendor/PDCurses/pdcurses/delch.c +0 -96
  102. data/vendor/PDCurses/pdcurses/deleteln.c +0 -211
  103. data/vendor/PDCurses/pdcurses/deprec.c +0 -27
  104. data/vendor/PDCurses/pdcurses/getch.c +0 -417
  105. data/vendor/PDCurses/pdcurses/getstr.c +0 -474
  106. data/vendor/PDCurses/pdcurses/getyx.c +0 -139
  107. data/vendor/PDCurses/pdcurses/inch.c +0 -127
  108. data/vendor/PDCurses/pdcurses/inchstr.c +0 -214
  109. data/vendor/PDCurses/pdcurses/initscr.c +0 -367
  110. data/vendor/PDCurses/pdcurses/inopts.c +0 -324
  111. data/vendor/PDCurses/pdcurses/insch.c +0 -271
  112. data/vendor/PDCurses/pdcurses/insstr.c +0 -264
  113. data/vendor/PDCurses/pdcurses/instr.c +0 -246
  114. data/vendor/PDCurses/pdcurses/kernel.c +0 -259
  115. data/vendor/PDCurses/pdcurses/keyname.c +0 -157
  116. data/vendor/PDCurses/pdcurses/mouse.c +0 -438
  117. data/vendor/PDCurses/pdcurses/move.c +0 -57
  118. data/vendor/PDCurses/pdcurses/outopts.c +0 -159
  119. data/vendor/PDCurses/pdcurses/overlay.c +0 -214
  120. data/vendor/PDCurses/pdcurses/pad.c +0 -260
  121. data/vendor/PDCurses/pdcurses/panel.c +0 -633
  122. data/vendor/PDCurses/pdcurses/printw.c +0 -126
  123. data/vendor/PDCurses/pdcurses/refresh.c +0 -279
  124. data/vendor/PDCurses/pdcurses/scanw.c +0 -578
  125. data/vendor/PDCurses/pdcurses/scr_dump.c +0 -213
  126. data/vendor/PDCurses/pdcurses/scroll.c +0 -101
  127. data/vendor/PDCurses/pdcurses/slk.c +0 -591
  128. data/vendor/PDCurses/pdcurses/termattr.c +0 -182
  129. data/vendor/PDCurses/pdcurses/terminfo.c +0 -217
  130. data/vendor/PDCurses/pdcurses/touch.c +0 -163
  131. data/vendor/PDCurses/pdcurses/util.c +0 -312
  132. data/vendor/PDCurses/pdcurses/window.c +0 -569
  133. data/vendor/PDCurses/sdl1/Makefile +0 -129
  134. data/vendor/PDCurses/sdl1/Makefile.mng +0 -110
  135. data/vendor/PDCurses/sdl1/README.md +0 -31
  136. data/vendor/PDCurses/sdl1/deffont.h +0 -385
  137. data/vendor/PDCurses/sdl1/deficon.h +0 -23
  138. data/vendor/PDCurses/sdl1/pdcclip.c +0 -131
  139. data/vendor/PDCurses/sdl1/pdcdisp.c +0 -373
  140. data/vendor/PDCurses/sdl1/pdcgetsc.c +0 -30
  141. data/vendor/PDCurses/sdl1/pdckbd.c +0 -405
  142. data/vendor/PDCurses/sdl1/pdcscrn.c +0 -414
  143. data/vendor/PDCurses/sdl1/pdcsdl.h +0 -31
  144. data/vendor/PDCurses/sdl1/pdcsetsc.c +0 -64
  145. data/vendor/PDCurses/sdl1/pdcutil.c +0 -40
  146. data/vendor/PDCurses/sdl1/sdltest.c +0 -79
  147. data/vendor/PDCurses/sdl2/CMakeLists.txt +0 -76
  148. data/vendor/PDCurses/sdl2/Makefile +0 -135
  149. data/vendor/PDCurses/sdl2/Makefile.vc +0 -164
  150. data/vendor/PDCurses/sdl2/README.md +0 -34
  151. data/vendor/PDCurses/sdl2/deffont.h +0 -385
  152. data/vendor/PDCurses/sdl2/deficon.h +0 -23
  153. data/vendor/PDCurses/sdl2/pdcclip.c +0 -93
  154. data/vendor/PDCurses/sdl2/pdcdisp.c +0 -534
  155. data/vendor/PDCurses/sdl2/pdcgetsc.c +0 -30
  156. data/vendor/PDCurses/sdl2/pdckbd.c +0 -480
  157. data/vendor/PDCurses/sdl2/pdcscrn.c +0 -443
  158. data/vendor/PDCurses/sdl2/pdcsdl.h +0 -33
  159. data/vendor/PDCurses/sdl2/pdcsetsc.c +0 -67
  160. data/vendor/PDCurses/sdl2/pdcutil.c +0 -39
  161. data/vendor/PDCurses/sdl2/sdltest.c +0 -81
  162. data/vendor/PDCurses/term.h +0 -48
  163. data/vendor/PDCurses/version.mif +0 -7
  164. data/vendor/PDCurses/vt/CMakeLists.txt +0 -28
  165. data/vendor/PDCurses/vt/Makefile +0 -135
  166. data/vendor/PDCurses/vt/Makefile.bcc +0 -111
  167. data/vendor/PDCurses/vt/Makefile.dmc +0 -258
  168. data/vendor/PDCurses/vt/Makefile.vc +0 -144
  169. data/vendor/PDCurses/vt/Makefile.wcc +0 -107
  170. data/vendor/PDCurses/vt/README.md +0 -64
  171. data/vendor/PDCurses/vt/pdcclip.c +0 -20
  172. data/vendor/PDCurses/vt/pdcdisp.c +0 -284
  173. data/vendor/PDCurses/vt/pdcgetsc.c +0 -27
  174. data/vendor/PDCurses/vt/pdckbd.c +0 -394
  175. data/vendor/PDCurses/vt/pdcscrn.c +0 -434
  176. data/vendor/PDCurses/vt/pdcsetsc.c +0 -45
  177. data/vendor/PDCurses/vt/pdcutil.c +0 -43
  178. data/vendor/PDCurses/vt/pdcvt.h +0 -16
  179. data/vendor/PDCurses/watcom.mif +0 -68
  180. data/vendor/PDCurses/wincon/CMakeLists.txt +0 -27
  181. data/vendor/PDCurses/wincon/Makefile.bcc +0 -88
  182. data/vendor/PDCurses/wincon/Makefile.dmc +0 -256
  183. data/vendor/PDCurses/wincon/Makefile.lcc +0 -273
  184. data/vendor/PDCurses/wincon/Makefile.mng +0 -176
  185. data/vendor/PDCurses/wincon/Makefile.vc +0 -144
  186. data/vendor/PDCurses/wincon/Makefile.wcc +0 -51
  187. data/vendor/PDCurses/wincon/README.md +0 -85
  188. data/vendor/PDCurses/wincon/pdcclip.c +0 -174
  189. data/vendor/PDCurses/wincon/pdcdisp.c +0 -143
  190. data/vendor/PDCurses/wincon/pdcgetsc.c +0 -55
  191. data/vendor/PDCurses/wincon/pdckbd.c +0 -786
  192. data/vendor/PDCurses/wincon/pdcscrn.c +0 -717
  193. data/vendor/PDCurses/wincon/pdcsetsc.c +0 -91
  194. data/vendor/PDCurses/wincon/pdcurses.ico +0 -0
  195. data/vendor/PDCurses/wincon/pdcurses.rc +0 -28
  196. data/vendor/PDCurses/wincon/pdcutil.c +0 -41
  197. data/vendor/PDCurses/wincon/pdcwin.h +0 -31
  198. data/vendor/PDCurses/wingui/CMakeLists.txt +0 -27
  199. data/vendor/PDCurses/wingui/Makefile.bcc +0 -85
  200. data/vendor/PDCurses/wingui/Makefile.dmc +0 -259
  201. data/vendor/PDCurses/wingui/Makefile.lcc +0 -273
  202. data/vendor/PDCurses/wingui/Makefile.mng +0 -171
  203. data/vendor/PDCurses/wingui/Makefile.vc +0 -144
  204. data/vendor/PDCurses/wingui/Makefile.wcc +0 -51
  205. data/vendor/PDCurses/wingui/README.md +0 -93
  206. data/vendor/PDCurses/wingui/pdcclip.c +0 -174
  207. data/vendor/PDCurses/wingui/pdcdisp.c +0 -718
  208. data/vendor/PDCurses/wingui/pdcgetsc.c +0 -30
  209. data/vendor/PDCurses/wingui/pdckbd.c +0 -143
  210. data/vendor/PDCurses/wingui/pdcscrn.c +0 -2797
  211. data/vendor/PDCurses/wingui/pdcsetsc.c +0 -89
  212. data/vendor/PDCurses/wingui/pdcurses.ico +0 -0
  213. data/vendor/PDCurses/wingui/pdcurses.rc +0 -28
  214. data/vendor/PDCurses/wingui/pdcutil.c +0 -61
  215. data/vendor/PDCurses/wingui/pdcwin.h +0 -122
  216. data/vendor/PDCurses/x11/Makefile.in +0 -754
  217. data/vendor/PDCurses/x11/PDCurses.spec +0 -82
  218. data/vendor/PDCurses/x11/README.md +0 -62
  219. data/vendor/PDCurses/x11/ScrollBox.c +0 -319
  220. data/vendor/PDCurses/x11/ScrollBox.h +0 -51
  221. data/vendor/PDCurses/x11/ScrollBoxP.h +0 -70
  222. data/vendor/PDCurses/x11/aclocal.m4 +0 -994
  223. data/vendor/PDCurses/x11/big_icon.xbm +0 -46
  224. data/vendor/PDCurses/x11/compose.h +0 -201
  225. data/vendor/PDCurses/x11/config.guess +0 -1500
  226. data/vendor/PDCurses/x11/config.h.in +0 -100
  227. data/vendor/PDCurses/x11/config.sub +0 -1616
  228. data/vendor/PDCurses/x11/configure +0 -6700
  229. data/vendor/PDCurses/x11/configure.ac +0 -295
  230. data/vendor/PDCurses/x11/debian/changelog +0 -6
  231. data/vendor/PDCurses/x11/debian/compat +0 -1
  232. data/vendor/PDCurses/x11/debian/control +0 -11
  233. data/vendor/PDCurses/x11/debian/copyright +0 -27
  234. data/vendor/PDCurses/x11/debian/rules +0 -98
  235. data/vendor/PDCurses/x11/install-sh +0 -253
  236. data/vendor/PDCurses/x11/little_icon.xbm +0 -14
  237. data/vendor/PDCurses/x11/ncurses_cfg.h +0 -45
  238. data/vendor/PDCurses/x11/pdcclip.c +0 -173
  239. data/vendor/PDCurses/x11/pdcdisp.c +0 -85
  240. data/vendor/PDCurses/x11/pdcgetsc.c +0 -28
  241. data/vendor/PDCurses/x11/pdckbd.c +0 -104
  242. data/vendor/PDCurses/x11/pdcscrn.c +0 -258
  243. data/vendor/PDCurses/x11/pdcsetsc.c +0 -95
  244. data/vendor/PDCurses/x11/pdcutil.c +0 -52
  245. data/vendor/PDCurses/x11/pdcx11.c +0 -316
  246. data/vendor/PDCurses/x11/pdcx11.h +0 -191
  247. data/vendor/PDCurses/x11/sb.c +0 -155
  248. data/vendor/PDCurses/x11/x11.c +0 -3686
  249. data/vendor/PDCurses/x11/xcurses-config.in +0 -81
@@ -1,785 +0,0 @@
1
- /* Public Domain Curses */
2
-
3
- #include "pdcdos.h"
4
-
5
- #include <stdlib.h>
6
-
7
- #ifdef CHTYPE_LONG
8
- # define PDC_OFFSET 32
9
- #else
10
- # define PDC_OFFSET 8
11
- #endif
12
-
13
- /* COLOR_PAIR to attribute encoding table. */
14
-
15
- unsigned char *pdc_atrtab = (unsigned char *)NULL;
16
-
17
- int pdc_adapter; /* screen type */
18
- int pdc_scrnmode; /* default screen mode */
19
- int pdc_font; /* default font size */
20
- bool pdc_direct_video; /* allow direct screen memory writes */
21
- bool pdc_bogus_adapter; /* TRUE if adapter has insane values */
22
- unsigned pdc_video_seg; /* video base segment */
23
- unsigned pdc_video_ofs; /* video base offset */
24
-
25
- static short curstoreal[16], realtocurs[16] =
26
- {
27
- COLOR_BLACK, COLOR_BLUE, COLOR_GREEN, COLOR_CYAN, COLOR_RED,
28
- COLOR_MAGENTA, COLOR_YELLOW, COLOR_WHITE, COLOR_BLACK + 8,
29
- COLOR_BLUE + 8, COLOR_GREEN + 8, COLOR_CYAN + 8, COLOR_RED + 8,
30
- COLOR_MAGENTA + 8, COLOR_YELLOW + 8, COLOR_WHITE + 8
31
- };
32
-
33
- static bool sizeable = FALSE; /* TRUE if adapter is resizeable */
34
-
35
- static unsigned short *saved_screen = NULL;
36
- static int saved_lines = 0;
37
- static int saved_cols = 0;
38
-
39
- static int saved_scrnmode[3];
40
- static int saved_font[3];
41
-
42
- /* special purpose function keys */
43
- static int PDC_shutdown_key[PDC_MAX_FUNCTION_KEYS] = { 0, 0, 0, 0, 0 };
44
-
45
- /* Thanks to Jeff Duntemann, K16RA for providing the impetus
46
- (through the Dr. Dobbs Journal, March 1989 issue) for getting
47
- the routines below merged into Bjorn Larsson's PDCurses 1.3...
48
- -- frotz@dri.com 900730 */
49
-
50
- /* _get_font() - Get the current font size */
51
-
52
- static int _get_font(void)
53
- {
54
- int retval;
55
-
56
- retval = getdosmemword(0x485);
57
-
58
- /* Assume the MDS Genius is in 66 line mode. */
59
-
60
- if ((retval == 0) && (pdc_adapter == _MDS_GENIUS))
61
- retval = _FONT15;
62
-
63
- switch (pdc_adapter)
64
- {
65
- case _MDA:
66
- retval = 10; /* POINTS is not certain on MDA/Hercules */
67
- break;
68
-
69
- case _EGACOLOR:
70
- case _EGAMONO:
71
- switch (retval)
72
- {
73
- case _FONT8:
74
- case _FONT14:
75
- break;
76
- default:
77
- retval = _FONT14;
78
- }
79
- break;
80
-
81
- case _CGA:
82
- retval = _FONT8;
83
- }
84
-
85
- return retval;
86
- }
87
-
88
- /* _set_font() - Sets the current font size, if the adapter allows such a
89
- change. It is an error to attempt to change the font size on a
90
- "bogus" adapter. The reason for this is that we have a known video
91
- adapter identity problem. e.g. Two adapters report the same identifying
92
- characteristics. */
93
-
94
- static void _set_font(int size)
95
- {
96
- PDCREGS regs;
97
-
98
- if (pdc_bogus_adapter)
99
- return;
100
-
101
- switch (pdc_adapter)
102
- {
103
- case _CGA:
104
- case _MDA:
105
- case _MCGACOLOR:
106
- case _MCGAMONO:
107
- case _MDS_GENIUS:
108
- break;
109
-
110
- case _EGACOLOR:
111
- case _EGAMONO:
112
- if (sizeable && (pdc_font != size))
113
- {
114
- switch (size)
115
- {
116
- case _FONT8:
117
- regs.W.ax = 0x1112;
118
- regs.h.bl = 0x00;
119
- PDCINT(0x10, regs);
120
- break;
121
- case _FONT14:
122
- regs.W.ax = 0x1111;
123
- regs.h.bl = 0x00;
124
- PDCINT(0x10, regs);
125
- }
126
- }
127
- break;
128
-
129
- case _VGACOLOR:
130
- case _VGAMONO:
131
- if (sizeable && (pdc_font != size))
132
- {
133
- switch (size)
134
- {
135
- case _FONT8:
136
- regs.W.ax = 0x1112;
137
- regs.h.bl = 0x00;
138
- PDCINT(0x10, regs);
139
- break;
140
- case _FONT14:
141
- regs.W.ax = 0x1111;
142
- regs.h.bl = 0x00;
143
- PDCINT(0x10, regs);
144
- break;
145
- case _FONT16:
146
- regs.W.ax = 0x1114;
147
- regs.h.bl = 0x00;
148
- PDCINT(0x10, regs);
149
- }
150
- }
151
- }
152
-
153
- curs_set(SP->visibility);
154
-
155
- pdc_font = _get_font();
156
- }
157
-
158
- /* _set_80x25() - force a known screen state: 80x25 text mode. Forces the
159
- appropriate 80x25 alpha mode given the display adapter. */
160
-
161
- static void _set_80x25(void)
162
- {
163
- PDCREGS regs;
164
-
165
- switch (pdc_adapter)
166
- {
167
- case _CGA:
168
- case _EGACOLOR:
169
- case _EGAMONO:
170
- case _VGACOLOR:
171
- case _VGAMONO:
172
- case _MCGACOLOR:
173
- case _MCGAMONO:
174
- regs.h.ah = 0x00;
175
- regs.h.al = 0x03;
176
- PDCINT(0x10, regs);
177
- break;
178
- case _MDA:
179
- regs.h.ah = 0x00;
180
- regs.h.al = 0x07;
181
- PDCINT(0x10, regs);
182
- }
183
- }
184
-
185
- /* _get_scrn_mode() - Return the current BIOS video mode */
186
-
187
- static int _get_scrn_mode(void)
188
- {
189
- PDCREGS regs;
190
-
191
- regs.h.ah = 0x0f;
192
- PDCINT(0x10, regs);
193
-
194
- return (int)regs.h.al;
195
- }
196
-
197
- /* _set_scrn_mode() - Sets the BIOS Video Mode Number only if it is
198
- different from the current video mode. */
199
-
200
- static void _set_scrn_mode(int new_mode)
201
- {
202
- PDCREGS regs;
203
-
204
- if (_get_scrn_mode() != new_mode)
205
- {
206
- regs.h.ah = 0;
207
- regs.h.al = (unsigned char) new_mode;
208
- PDCINT(0x10, regs);
209
- }
210
-
211
- pdc_font = _get_font();
212
- pdc_scrnmode = new_mode;
213
- LINES = PDC_get_rows();
214
- COLS = PDC_get_columns();
215
- }
216
-
217
- /* _sanity_check() - A video adapter identification sanity check. This
218
- routine will force sane values for various control flags. */
219
-
220
- static int _sanity_check(int adapter)
221
- {
222
- int fontsize = _get_font();
223
- int rows = PDC_get_rows();
224
-
225
- PDC_LOG(("_sanity_check() - called: Adapter %d\n", adapter));
226
-
227
- switch (adapter)
228
- {
229
- case _EGACOLOR:
230
- case _EGAMONO:
231
- switch (rows)
232
- {
233
- case 25:
234
- case 43:
235
- break;
236
- default:
237
- pdc_bogus_adapter = TRUE;
238
- }
239
-
240
- switch (fontsize)
241
- {
242
- case _FONT8:
243
- case _FONT14:
244
- break;
245
- default:
246
- pdc_bogus_adapter = TRUE;
247
- }
248
- break;
249
-
250
- case _VGACOLOR:
251
- case _VGAMONO:
252
- break;
253
-
254
- case _CGA:
255
- case _MDA:
256
- case _MCGACOLOR:
257
- case _MCGAMONO:
258
- switch (rows)
259
- {
260
- case 25:
261
- break;
262
- default:
263
- pdc_bogus_adapter = TRUE;
264
- }
265
- break;
266
-
267
- default:
268
- pdc_bogus_adapter = TRUE;
269
- }
270
-
271
- if (pdc_bogus_adapter)
272
- {
273
- sizeable = FALSE;
274
- pdc_direct_video = FALSE;
275
- }
276
-
277
- return adapter;
278
- }
279
-
280
- /* _query_adapter_type() - Determine PC video adapter type. */
281
-
282
- static int _query_adapter_type(void)
283
- {
284
- PDCREGS regs;
285
- int retval = _NONE;
286
-
287
- /* thanks to paganini@ax.apc.org for the GO32 fix */
288
-
289
- #if !defined(__DJGPP__) && !defined(__WATCOMC__)
290
- struct SREGS segs;
291
- #endif
292
- short video_base = getdosmemword(0x463);
293
-
294
- PDC_LOG(("_query_adapter_type() - called\n"));
295
-
296
- /* attempt to call VGA Identify Adapter Function */
297
-
298
- regs.W.ax = 0x1a00;
299
- PDCINT(0x10, regs);
300
-
301
- if ((regs.h.al == 0x1a) && (retval == _NONE))
302
- {
303
- /* We know that the PS/2 video BIOS is alive and well. */
304
-
305
- switch (regs.h.al)
306
- {
307
- case 0:
308
- retval = _NONE;
309
- break;
310
- case 1:
311
- retval = _MDA;
312
- break;
313
- case 2:
314
- retval = _CGA;
315
- break;
316
- case 4:
317
- retval = _EGACOLOR;
318
- sizeable = TRUE;
319
- break;
320
- case 5:
321
- retval = _EGAMONO;
322
- break;
323
- case 26: /* ...alt. VGA BIOS... */
324
- case 7:
325
- retval = _VGACOLOR;
326
- sizeable = TRUE;
327
- break;
328
- case 8:
329
- retval = _VGAMONO;
330
- break;
331
- case 10:
332
- case 13:
333
- retval = _MCGACOLOR;
334
- break;
335
- case 12:
336
- retval = _MCGAMONO;
337
- break;
338
- default:
339
- retval = _CGA;
340
- }
341
- }
342
- else
343
- {
344
- /* No VGA BIOS, check for an EGA BIOS by selecting an
345
- Alternate Function Service...
346
-
347
- bx == 0x0010 --> return EGA information */
348
-
349
- regs.h.ah = 0x12;
350
- regs.W.bx = 0x10;
351
- PDCINT(0x10, regs);
352
-
353
- if ((regs.h.bl != 0x10) && (retval == _NONE))
354
- {
355
- /* An EGA BIOS exists */
356
-
357
- regs.h.ah = 0x12;
358
- regs.h.bl = 0x10;
359
- PDCINT(0x10, regs);
360
-
361
- if (regs.h.bh == 0)
362
- retval = _EGACOLOR;
363
- else
364
- retval = _EGAMONO;
365
- }
366
- else if (retval == _NONE)
367
- {
368
- /* Now we know we only have CGA or MDA */
369
-
370
- PDCINT(0x11, regs);
371
-
372
- switch (regs.h.al & 0x30)
373
- {
374
- case 0x10:
375
- case 0x20:
376
- retval = _CGA;
377
- break;
378
- case 0x30:
379
- retval = _MDA;
380
- break;
381
- default:
382
- retval = _NONE;
383
- }
384
- }
385
- }
386
-
387
- if (video_base == 0x3d4)
388
- {
389
- pdc_video_seg = 0xb800;
390
- switch (retval)
391
- {
392
- case _EGAMONO:
393
- retval = _EGACOLOR;
394
- break;
395
- case _VGAMONO:
396
- retval = _VGACOLOR;
397
- }
398
- }
399
-
400
- if (video_base == 0x3b4)
401
- {
402
- pdc_video_seg = 0xb000;
403
- switch (retval)
404
- {
405
- case _EGACOLOR:
406
- retval = _EGAMONO;
407
- break;
408
- case _VGACOLOR:
409
- retval = _VGAMONO;
410
- }
411
- }
412
-
413
- if ((retval == _NONE)
414
- #ifndef CGA_DIRECT
415
- || (retval == _CGA)
416
- #endif
417
- )
418
- pdc_direct_video = FALSE;
419
-
420
- if ((unsigned)pdc_video_seg == 0xb000)
421
- SP->mono = TRUE;
422
- else
423
- SP->mono = FALSE;
424
-
425
- /* Check for DESQview shadow buffer
426
- thanks to paganini@ax.apc.org for the GO32 fix */
427
-
428
- #ifndef __WATCOMC__
429
- regs.h.ah = 0xfe;
430
- regs.h.al = 0;
431
- regs.x.di = pdc_video_ofs;
432
- # ifdef __DJGPP__
433
- regs.x.es = pdc_video_seg;
434
- __dpmi_int(0x10, &regs);
435
- pdc_video_seg = regs.x.es;
436
- # else
437
- segs.es = pdc_video_seg;
438
- int86x(0x10, &regs, &regs, &segs);
439
- pdc_video_seg = segs.es;
440
- # endif
441
- pdc_video_ofs = regs.x.di;
442
- #endif
443
- if (!pdc_adapter)
444
- pdc_adapter = retval;
445
-
446
- return _sanity_check(retval);
447
- }
448
-
449
- /* close the physical screen -- may restore the screen to its state
450
- before PDC_scr_open(); miscellaneous cleanup */
451
-
452
- void PDC_scr_close(void)
453
- {
454
- #if SMALL || MEDIUM
455
- # ifndef __PACIFIC__
456
- struct SREGS segregs;
457
- # endif
458
- int ds;
459
- #endif
460
- PDC_LOG(("PDC_scr_close() - called\n"));
461
-
462
- if (getenv("PDC_RESTORE_SCREEN") && saved_screen)
463
- {
464
- #ifdef __DJGPP__
465
- dosmemput(saved_screen, saved_lines * saved_cols * 2,
466
- (unsigned long)_FAR_POINTER(pdc_video_seg,
467
- pdc_video_ofs));
468
- #else
469
- # if (SMALL || MEDIUM)
470
- # ifdef __PACIFIC__
471
- ds = FP_SEG((void far *)saved_screen);
472
- # else
473
- segread(&segregs);
474
- ds = segregs.ds;
475
- # endif
476
- movedata(ds, (int)saved_screen, pdc_video_seg, pdc_video_ofs,
477
- (saved_lines * saved_cols * 2));
478
- # else
479
- memcpy((void *)_FAR_POINTER(pdc_video_seg, pdc_video_ofs),
480
- (void *)saved_screen, (saved_lines * saved_cols * 2));
481
- # endif
482
- #endif
483
- free(saved_screen);
484
- saved_screen = NULL;
485
- }
486
-
487
- reset_shell_mode();
488
-
489
- if (SP->visibility != 1)
490
- curs_set(1);
491
-
492
- /* Position cursor to the bottom left of the screen. */
493
-
494
- PDC_gotoyx(PDC_get_rows() - 2, 0);
495
- }
496
-
497
- void PDC_scr_free(void)
498
- {
499
- if (SP)
500
- free(SP);
501
- if (pdc_atrtab)
502
- free(pdc_atrtab);
503
-
504
- pdc_atrtab = (unsigned char *)NULL;
505
- }
506
-
507
- /* open the physical screen -- allocate SP, miscellaneous intialization,
508
- and may save the existing screen for later restoration */
509
-
510
- int PDC_scr_open(int argc, char **argv)
511
- {
512
- #if SMALL || MEDIUM
513
- # ifndef __PACIFIC__
514
- struct SREGS segregs;
515
- # endif
516
- int ds;
517
- #endif
518
- int i;
519
-
520
- PDC_LOG(("PDC_scr_open() - called\n"));
521
-
522
- SP = calloc(1, sizeof(SCREEN));
523
- pdc_atrtab = calloc(PDC_COLOR_PAIRS * PDC_OFFSET, 1);
524
-
525
- if (!SP || !pdc_atrtab)
526
- return ERR;
527
-
528
- for (i = 0; i < 16; i++)
529
- curstoreal[realtocurs[i]] = i;
530
-
531
- SP->orig_attr = FALSE;
532
-
533
- pdc_direct_video = TRUE; /* Assume that we can */
534
- pdc_video_seg = 0xb000; /* Base screen segment addr */
535
- pdc_video_ofs = 0x0; /* Base screen segment ofs */
536
-
537
- pdc_adapter = _query_adapter_type();
538
- pdc_scrnmode = _get_scrn_mode();
539
- pdc_font = _get_font();
540
-
541
- SP->lines = PDC_get_rows();
542
- SP->cols = PDC_get_columns();
543
-
544
- SP->mouse_wait = PDC_CLICK_PERIOD;
545
- SP->audible = TRUE;
546
-
547
- /* If the environment variable PDCURSES_BIOS is set, the DOS int10()
548
- BIOS calls are used in place of direct video memory access. */
549
-
550
- if (getenv("PDCURSES_BIOS"))
551
- pdc_direct_video = FALSE;
552
-
553
- /* This code for preserving the current screen. */
554
-
555
- if (getenv("PDC_RESTORE_SCREEN"))
556
- {
557
- saved_lines = SP->lines;
558
- saved_cols = SP->cols;
559
-
560
- saved_screen = malloc(saved_lines * saved_cols * 2);
561
-
562
- if (!saved_screen)
563
- {
564
- SP->_preserve = FALSE;
565
- return OK;
566
- }
567
- #ifdef __DJGPP__
568
- dosmemget((unsigned long)_FAR_POINTER(pdc_video_seg, pdc_video_ofs),
569
- saved_lines * saved_cols * 2, saved_screen);
570
- #else
571
- # if SMALL || MEDIUM
572
- # ifdef __PACIFIC__
573
- ds = FP_SEG((void far *) saved_screen);
574
- # else
575
- segread(&segregs);
576
- ds = segregs.ds;
577
- # endif
578
- movedata(pdc_video_seg, pdc_video_ofs, ds, (int)saved_screen,
579
- (saved_lines * saved_cols * 2));
580
- # else
581
- memcpy((void *)saved_screen,
582
- (void *)_FAR_POINTER(pdc_video_seg, pdc_video_ofs),
583
- (saved_lines * saved_cols * 2));
584
- # endif
585
- #endif
586
- }
587
-
588
- SP->_preserve = (getenv("PDC_PRESERVE_SCREEN") != NULL);
589
-
590
- return OK;
591
- }
592
-
593
- /* the core of resize_term() */
594
-
595
- int PDC_resize_screen(int nlines, int ncols)
596
- {
597
- PDC_LOG(("PDC_resize_screen() - called. Lines: %d Cols: %d\n",
598
- nlines, ncols));
599
-
600
- if( !stdscr) /* window hasn't been created yet; we're */
601
- { /* specifying its size before doing so */
602
- return OK; /* ...which doesn't work in DOS */
603
- }
604
-
605
- /* Trash the stored value of orig_cursor -- it's only good if the
606
- video mode doesn't change */
607
-
608
- SP->orig_cursor = 0x0607;
609
-
610
- switch (pdc_adapter)
611
- {
612
- case _EGACOLOR:
613
- if (nlines >= 43)
614
- _set_font(_FONT8);
615
- else
616
- _set_80x25();
617
- break;
618
-
619
- case _VGACOLOR:
620
- if (nlines > 28)
621
- _set_font(_FONT8);
622
- else
623
- if (nlines > 25)
624
- _set_font(_FONT14);
625
- else
626
- _set_80x25();
627
- }
628
-
629
- PDC_set_blink(COLORS == 8);
630
-
631
- return OK;
632
- }
633
-
634
- void PDC_reset_prog_mode(void)
635
- {
636
- PDC_LOG(("PDC_reset_prog_mode() - called.\n"));
637
- }
638
-
639
- void PDC_reset_shell_mode(void)
640
- {
641
- PDC_LOG(("PDC_reset_shell_mode() - called.\n"));
642
- }
643
-
644
- void PDC_restore_screen_mode(int i)
645
- {
646
- if (i >= 0 && i <= 2)
647
- {
648
- pdc_font = _get_font();
649
- _set_font(saved_font[i]);
650
-
651
- if (_get_scrn_mode() != saved_scrnmode[i])
652
- _set_scrn_mode(saved_scrnmode[i]);
653
- }
654
- }
655
-
656
- void PDC_save_screen_mode(int i)
657
- {
658
- if (i >= 0 && i <= 2)
659
- {
660
- saved_font[i] = pdc_font;
661
- saved_scrnmode[i] = pdc_scrnmode;
662
- }
663
- }
664
-
665
- void PDC_init_pair(short pair, short fg, short bg)
666
- {
667
- unsigned char att, temp_bg;
668
- chtype i;
669
-
670
- fg = curstoreal[fg];
671
- bg = curstoreal[bg];
672
-
673
- for (i = 0; i < PDC_OFFSET; i++)
674
- {
675
- att = fg | (bg << 4);
676
-
677
- if (i & (A_REVERSE >> PDC_ATTR_SHIFT))
678
- att = bg | (fg << 4);
679
- if (i & (A_UNDERLINE >> PDC_ATTR_SHIFT))
680
- att = 1;
681
- if (i & (A_INVIS >> PDC_ATTR_SHIFT))
682
- {
683
- temp_bg = att >> 4;
684
- att = temp_bg << 4 | temp_bg;
685
- }
686
- if (i & (A_BOLD >> PDC_ATTR_SHIFT))
687
- att |= 8;
688
- if (i & (A_BLINK >> PDC_ATTR_SHIFT))
689
- att |= 128;
690
-
691
- pdc_atrtab[pair * PDC_OFFSET + i] = att;
692
- }
693
- }
694
-
695
- int PDC_pair_content(short pair, short *fg, short *bg)
696
- {
697
- *fg = realtocurs[pdc_atrtab[pair * PDC_OFFSET] & 0x0F];
698
- *bg = realtocurs[(pdc_atrtab[pair * PDC_OFFSET] & 0xF0) >> 4];
699
-
700
- return OK;
701
- }
702
-
703
- /* _egapal() - Find the EGA palette value (0-63) for the color (0-15).
704
- On VGA, this is an index into the DAC. */
705
-
706
- static short _egapal(short color)
707
- {
708
- PDCREGS regs;
709
-
710
- regs.W.ax = 0x1007;
711
- regs.h.bl = curstoreal[color];
712
-
713
- PDCINT(0x10, regs);
714
-
715
- return regs.h.bh;
716
- }
717
-
718
- bool PDC_can_change_color(void)
719
- {
720
- return (pdc_adapter == _VGACOLOR);
721
- }
722
-
723
- /* These are only valid when pdc_adapter == _VGACOLOR */
724
-
725
- int PDC_color_content(short color, short *red, short *green, short *blue)
726
- {
727
- PDCREGS regs;
728
-
729
- /* Read single DAC register */
730
-
731
- regs.W.ax = 0x1015;
732
- regs.h.bl = _egapal(color);
733
-
734
- PDCINT(0x10, regs);
735
-
736
- /* Scale and store */
737
-
738
- *red = DIVROUND((unsigned)(regs.h.dh) * 1000, 63);
739
- *green = DIVROUND((unsigned)(regs.h.ch) * 1000, 63);
740
- *blue = DIVROUND((unsigned)(regs.h.cl) * 1000, 63);
741
-
742
- return OK;
743
- }
744
-
745
- int PDC_init_color(short color, short red, short green, short blue)
746
- {
747
- PDCREGS regs;
748
-
749
- /* Scale */
750
-
751
- regs.h.dh = DIVROUND((unsigned)red * 63, 1000);
752
- regs.h.ch = DIVROUND((unsigned)green * 63, 1000);
753
- regs.h.cl = DIVROUND((unsigned)blue * 63, 1000);
754
-
755
- /* Set single DAC register */
756
-
757
- regs.W.ax = 0x1010;
758
- regs.W.bx = _egapal(color);
759
-
760
- PDCINT(0x10, regs);
761
-
762
- return OK;
763
- }
764
-
765
- /* Does nothing in the DOS (or OS/2 or Win32 console) flavors of PDCurses,
766
- which lack user resizing. See X11 or Win32a versions of this function for
767
- details of what it does on platforms that do support user resizing. */
768
-
769
- void PDC_set_resize_limits( const int new_min_lines, const int new_max_lines,
770
- const int new_min_cols, const int new_max_cols)
771
- {
772
- }
773
-
774
- /* PDC_set_function_key() does nothing on this platform */
775
- int PDC_set_function_key( const unsigned function, const int new_key)
776
- {
777
- int old_key = -1;
778
-
779
- if( function < PDC_MAX_FUNCTION_KEYS)
780
- {
781
- old_key = PDC_shutdown_key[function];
782
- PDC_shutdown_key[function] = new_key;
783
- }
784
- return( old_key);
785
- }