curses 1.2.7 → 1.4.1
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.
- checksums.yaml +4 -4
- data/.github/workflows/macos.yml +19 -0
- data/.github/workflows/ubuntu.yml +26 -0
- data/.github/workflows/windows.yml +25 -0
- data/.gitmodules +1 -1
- data/History.md +41 -0
- data/README.md +14 -46
- data/Rakefile +0 -83
- data/curses.gemspec +2 -3
- data/ext/curses/curses.c +1314 -176
- data/ext/curses/extconf.rb +140 -17
- data/lib/curses.rb +5 -12
- data/sample/form.rb +52 -0
- data/sample/menu.rb +1 -1
- data/vendor/PDCurses/.gitignore +47 -0
- data/vendor/PDCurses/.travis.yml +49 -0
- data/vendor/PDCurses/CMakeLists.txt +68 -0
- data/vendor/PDCurses/HISTORY.md +2036 -0
- data/vendor/PDCurses/IMPLEMNT.md +327 -0
- data/vendor/PDCurses/README.md +77 -0
- data/vendor/PDCurses/acs_defs.h +265 -0
- data/vendor/PDCurses/appveyor.yml +218 -0
- data/vendor/PDCurses/cmake/README.md +71 -0
- data/vendor/PDCurses/cmake/build_dependencies.cmake +178 -0
- data/vendor/PDCurses/cmake/build_options.cmake +25 -0
- data/vendor/PDCurses/cmake/dll_version.cmake +26 -0
- data/vendor/PDCurses/cmake/gen_config_header.cmake +43 -0
- data/vendor/PDCurses/cmake/get_version.cmake +17 -0
- data/vendor/PDCurses/cmake/make_uninstall.cmake +19 -0
- data/vendor/PDCurses/cmake/project_common.cmake +121 -0
- data/vendor/PDCurses/cmake/resource.in.cmake +52 -0
- data/vendor/PDCurses/cmake/sdl2_ttf/CMakeLists.txt +83 -0
- data/vendor/PDCurses/cmake/target_arch.cmake +36 -0
- data/vendor/PDCurses/cmake/version.in.cmake +73 -0
- data/vendor/PDCurses/cmake/watcom_open_dos16_toolchain.cmake +96 -0
- data/vendor/PDCurses/cmake/watcom_open_dos32_toolchain.cmake +106 -0
- data/vendor/PDCurses/cmake/watcom_open_os2v2_toolchain.cmake +105 -0
- data/vendor/PDCurses/curses.h +1846 -0
- data/vendor/PDCurses/curspriv.h +134 -0
- data/vendor/PDCurses/demos/README.md +25 -0
- data/vendor/PDCurses/demos/firework.c +144 -0
- data/vendor/PDCurses/demos/newtest.c +581 -0
- data/vendor/PDCurses/demos/ozdemo.c +447 -0
- data/vendor/PDCurses/demos/ptest.c +283 -0
- data/vendor/PDCurses/demos/rain.c +157 -0
- data/vendor/PDCurses/demos/testcurs.c +1607 -0
- data/vendor/PDCurses/demos/tui.c +1048 -0
- data/vendor/PDCurses/demos/tui.h +65 -0
- data/vendor/PDCurses/demos/tuidemo.c +233 -0
- data/vendor/PDCurses/demos/version.c +61 -0
- data/vendor/PDCurses/demos/worm.c +432 -0
- data/vendor/PDCurses/demos/xmas.c +955 -0
- data/vendor/PDCurses/dos/CMakeLists.txt +47 -0
- data/vendor/PDCurses/dos/Makefile.bcc +83 -0
- data/vendor/PDCurses/dos/Makefile.dmc +257 -0
- data/vendor/PDCurses/dos/Makefile.msc +113 -0
- data/vendor/PDCurses/dos/Makefile.wcc +107 -0
- data/vendor/PDCurses/dos/README.md +51 -0
- data/vendor/PDCurses/dos/bccdos.lrf +9 -0
- data/vendor/PDCurses/dos/mscdos.lrf +50 -0
- data/vendor/PDCurses/dos/pdcclip.c +132 -0
- data/vendor/PDCurses/dos/pdcdisp.c +135 -0
- data/vendor/PDCurses/dos/pdcdos.h +194 -0
- data/vendor/PDCurses/dos/pdcgetsc.c +98 -0
- data/vendor/PDCurses/dos/pdckbd.c +513 -0
- data/vendor/PDCurses/dos/pdcscrn.c +785 -0
- data/vendor/PDCurses/dos/pdcsetsc.c +101 -0
- data/vendor/PDCurses/dos/pdcutil.c +212 -0
- data/vendor/PDCurses/libobjs.mif +26 -0
- data/vendor/PDCurses/makedist.mif +20 -0
- data/vendor/PDCurses/man/README.md +21 -0
- data/vendor/PDCurses/man/intro.md +361 -0
- data/vendor/PDCurses/man/manext.c +119 -0
- data/vendor/PDCurses/man/sdl.md +152 -0
- data/vendor/PDCurses/man/sdl2.md +58 -0
- data/vendor/PDCurses/man/x11.md +407 -0
- data/vendor/PDCurses/ncurses/CMakeLists.txt +66 -0
- data/vendor/PDCurses/ncurses/README.md +26 -0
- data/vendor/PDCurses/ncurses/makefile +29 -0
- data/vendor/PDCurses/os2/CMakeLists.txt +41 -0
- data/vendor/PDCurses/os2/Makefile.bcc +90 -0
- data/vendor/PDCurses/os2/Makefile.wcc +43 -0
- data/vendor/PDCurses/os2/README.md +43 -0
- data/vendor/PDCurses/os2/iccos2.lrf +50 -0
- data/vendor/PDCurses/os2/iccos2.mak +256 -0
- data/vendor/PDCurses/os2/pdcclip.c +188 -0
- data/vendor/PDCurses/os2/pdcdisp.c +93 -0
- data/vendor/PDCurses/os2/pdcgetsc.c +89 -0
- data/vendor/PDCurses/os2/pdckbd.c +521 -0
- data/vendor/PDCurses/os2/pdcos2.h +55 -0
- data/vendor/PDCurses/os2/pdcscrn.c +449 -0
- data/vendor/PDCurses/os2/pdcsetsc.c +112 -0
- data/vendor/PDCurses/os2/pdcutil.c +52 -0
- data/vendor/PDCurses/panel.h +56 -0
- data/vendor/PDCurses/pdcurses/README.md +25 -0
- data/vendor/PDCurses/pdcurses/addch.c +693 -0
- data/vendor/PDCurses/pdcurses/addchstr.c +245 -0
- data/vendor/PDCurses/pdcurses/addstr.c +240 -0
- data/vendor/PDCurses/pdcurses/attr.c +359 -0
- data/vendor/PDCurses/pdcurses/beep.c +68 -0
- data/vendor/PDCurses/pdcurses/bkgd.c +223 -0
- data/vendor/PDCurses/pdcurses/border.c +411 -0
- data/vendor/PDCurses/pdcurses/clear.c +159 -0
- data/vendor/PDCurses/pdcurses/color.c +298 -0
- data/vendor/PDCurses/pdcurses/debug.c +109 -0
- data/vendor/PDCurses/pdcurses/delch.c +96 -0
- data/vendor/PDCurses/pdcurses/deleteln.c +211 -0
- data/vendor/PDCurses/pdcurses/deprec.c +27 -0
- data/vendor/PDCurses/pdcurses/getch.c +417 -0
- data/vendor/PDCurses/pdcurses/getstr.c +474 -0
- data/vendor/PDCurses/pdcurses/getyx.c +139 -0
- data/vendor/PDCurses/pdcurses/inch.c +127 -0
- data/vendor/PDCurses/pdcurses/inchstr.c +214 -0
- data/vendor/PDCurses/pdcurses/initscr.c +367 -0
- data/vendor/PDCurses/pdcurses/inopts.c +324 -0
- data/vendor/PDCurses/pdcurses/insch.c +271 -0
- data/vendor/PDCurses/pdcurses/insstr.c +264 -0
- data/vendor/PDCurses/pdcurses/instr.c +246 -0
- data/vendor/PDCurses/pdcurses/kernel.c +259 -0
- data/vendor/PDCurses/pdcurses/keyname.c +157 -0
- data/vendor/PDCurses/pdcurses/mouse.c +438 -0
- data/vendor/PDCurses/pdcurses/move.c +57 -0
- data/vendor/PDCurses/pdcurses/outopts.c +159 -0
- data/vendor/PDCurses/pdcurses/overlay.c +214 -0
- data/vendor/PDCurses/pdcurses/pad.c +260 -0
- data/vendor/PDCurses/pdcurses/panel.c +633 -0
- data/vendor/PDCurses/pdcurses/printw.c +126 -0
- data/vendor/PDCurses/pdcurses/refresh.c +279 -0
- data/vendor/PDCurses/pdcurses/scanw.c +578 -0
- data/vendor/PDCurses/pdcurses/scr_dump.c +213 -0
- data/vendor/PDCurses/pdcurses/scroll.c +101 -0
- data/vendor/PDCurses/pdcurses/slk.c +591 -0
- data/vendor/PDCurses/pdcurses/termattr.c +182 -0
- data/vendor/PDCurses/pdcurses/terminfo.c +217 -0
- data/vendor/PDCurses/pdcurses/touch.c +163 -0
- data/vendor/PDCurses/pdcurses/util.c +312 -0
- data/vendor/PDCurses/pdcurses/window.c +569 -0
- data/vendor/PDCurses/sdl1/Makefile.mng +110 -0
- data/vendor/PDCurses/sdl1/README.md +31 -0
- data/vendor/PDCurses/sdl1/deffont.h +385 -0
- data/vendor/PDCurses/sdl1/deficon.h +23 -0
- data/vendor/PDCurses/sdl1/pdcclip.c +131 -0
- data/vendor/PDCurses/sdl1/pdcdisp.c +373 -0
- data/vendor/PDCurses/sdl1/pdcgetsc.c +30 -0
- data/vendor/PDCurses/sdl1/pdckbd.c +405 -0
- data/vendor/PDCurses/sdl1/pdcscrn.c +414 -0
- data/vendor/PDCurses/sdl1/pdcsdl.h +31 -0
- data/vendor/PDCurses/sdl1/pdcsetsc.c +64 -0
- data/vendor/PDCurses/sdl1/pdcutil.c +40 -0
- data/vendor/PDCurses/sdl1/sdltest.c +79 -0
- data/vendor/PDCurses/sdl2/CMakeLists.txt +76 -0
- data/vendor/PDCurses/sdl2/Makefile.vc +164 -0
- data/vendor/PDCurses/sdl2/README.md +34 -0
- data/vendor/PDCurses/sdl2/deffont.h +385 -0
- data/vendor/PDCurses/sdl2/deficon.h +23 -0
- data/vendor/PDCurses/sdl2/pdcclip.c +93 -0
- data/vendor/PDCurses/sdl2/pdcdisp.c +534 -0
- data/vendor/PDCurses/sdl2/pdcgetsc.c +30 -0
- data/vendor/PDCurses/sdl2/pdckbd.c +480 -0
- data/vendor/PDCurses/sdl2/pdcscrn.c +443 -0
- data/vendor/PDCurses/sdl2/pdcsdl.h +33 -0
- data/vendor/PDCurses/sdl2/pdcsetsc.c +67 -0
- data/vendor/PDCurses/sdl2/pdcutil.c +39 -0
- data/vendor/PDCurses/sdl2/sdltest.c +81 -0
- data/vendor/PDCurses/term.h +48 -0
- data/vendor/PDCurses/version.mif +7 -0
- data/vendor/PDCurses/vt/CMakeLists.txt +28 -0
- data/vendor/PDCurses/vt/Makefile.bcc +111 -0
- data/vendor/PDCurses/vt/Makefile.dmc +258 -0
- data/vendor/PDCurses/vt/Makefile.vc +144 -0
- data/vendor/PDCurses/vt/Makefile.wcc +107 -0
- data/vendor/PDCurses/vt/README.md +64 -0
- data/vendor/PDCurses/vt/pdcclip.c +20 -0
- data/vendor/PDCurses/vt/pdcdisp.c +284 -0
- data/vendor/PDCurses/vt/pdcgetsc.c +27 -0
- data/vendor/PDCurses/vt/pdckbd.c +394 -0
- data/vendor/PDCurses/vt/pdcscrn.c +434 -0
- data/vendor/PDCurses/vt/pdcsetsc.c +45 -0
- data/vendor/PDCurses/vt/pdcutil.c +43 -0
- data/vendor/PDCurses/vt/pdcvt.h +16 -0
- data/vendor/PDCurses/watcom.mif +68 -0
- data/vendor/PDCurses/wincon/CMakeLists.txt +27 -0
- data/vendor/PDCurses/wincon/Makefile.bcc +88 -0
- data/vendor/PDCurses/wincon/Makefile.dmc +256 -0
- data/vendor/PDCurses/wincon/Makefile.lcc +273 -0
- data/vendor/PDCurses/wincon/Makefile.mng +176 -0
- data/vendor/PDCurses/wincon/Makefile.vc +144 -0
- data/vendor/PDCurses/wincon/Makefile.wcc +51 -0
- data/vendor/PDCurses/wincon/README.md +85 -0
- data/vendor/PDCurses/wincon/pdcclip.c +174 -0
- data/vendor/PDCurses/wincon/pdcdisp.c +143 -0
- data/vendor/PDCurses/wincon/pdcgetsc.c +55 -0
- data/vendor/PDCurses/wincon/pdckbd.c +786 -0
- data/vendor/PDCurses/wincon/pdcscrn.c +717 -0
- data/vendor/PDCurses/wincon/pdcsetsc.c +91 -0
- data/vendor/PDCurses/wincon/pdcurses.ico +0 -0
- data/vendor/PDCurses/wincon/pdcurses.rc +28 -0
- data/vendor/PDCurses/wincon/pdcutil.c +41 -0
- data/vendor/PDCurses/wincon/pdcwin.h +31 -0
- data/vendor/PDCurses/wingui/CMakeLists.txt +27 -0
- data/vendor/PDCurses/wingui/Makefile.bcc +85 -0
- data/vendor/PDCurses/wingui/Makefile.dmc +259 -0
- data/vendor/PDCurses/wingui/Makefile.lcc +273 -0
- data/vendor/PDCurses/wingui/Makefile.mng +171 -0
- data/vendor/PDCurses/wingui/Makefile.vc +144 -0
- data/vendor/PDCurses/wingui/Makefile.wcc +51 -0
- data/vendor/PDCurses/wingui/README.md +93 -0
- data/vendor/PDCurses/wingui/pdcclip.c +174 -0
- data/vendor/PDCurses/wingui/pdcdisp.c +718 -0
- data/vendor/PDCurses/wingui/pdcgetsc.c +30 -0
- data/vendor/PDCurses/wingui/pdckbd.c +143 -0
- data/vendor/PDCurses/wingui/pdcscrn.c +2797 -0
- data/vendor/PDCurses/wingui/pdcsetsc.c +89 -0
- data/vendor/PDCurses/wingui/pdcurses.ico +0 -0
- data/vendor/PDCurses/wingui/pdcurses.rc +28 -0
- data/vendor/PDCurses/wingui/pdcutil.c +61 -0
- data/vendor/PDCurses/wingui/pdcwin.h +122 -0
- data/vendor/PDCurses/x11/Makefile.in +754 -0
- data/vendor/PDCurses/x11/PDCurses.spec +82 -0
- data/vendor/PDCurses/x11/README.md +62 -0
- data/vendor/PDCurses/x11/ScrollBox.c +319 -0
- data/vendor/PDCurses/x11/ScrollBox.h +51 -0
- data/vendor/PDCurses/x11/ScrollBoxP.h +70 -0
- data/vendor/PDCurses/x11/aclocal.m4 +994 -0
- data/vendor/PDCurses/x11/big_icon.xbm +46 -0
- data/vendor/PDCurses/x11/compose.h +201 -0
- data/vendor/PDCurses/x11/config.guess +1500 -0
- data/vendor/PDCurses/x11/config.h.in +100 -0
- data/vendor/PDCurses/x11/config.sub +1616 -0
- data/vendor/PDCurses/x11/configure +6700 -0
- data/vendor/PDCurses/x11/configure.ac +295 -0
- data/vendor/PDCurses/x11/debian/changelog +6 -0
- data/vendor/PDCurses/x11/debian/compat +1 -0
- data/vendor/PDCurses/x11/debian/control +11 -0
- data/vendor/PDCurses/x11/debian/copyright +27 -0
- data/vendor/PDCurses/x11/debian/rules +98 -0
- data/vendor/PDCurses/x11/install-sh +253 -0
- data/vendor/PDCurses/x11/little_icon.xbm +14 -0
- data/vendor/PDCurses/x11/ncurses_cfg.h +45 -0
- data/vendor/PDCurses/x11/pdcclip.c +173 -0
- data/vendor/PDCurses/x11/pdcdisp.c +85 -0
- data/vendor/PDCurses/x11/pdcgetsc.c +28 -0
- data/vendor/PDCurses/x11/pdckbd.c +104 -0
- data/vendor/PDCurses/x11/pdcscrn.c +258 -0
- data/vendor/PDCurses/x11/pdcsetsc.c +95 -0
- data/vendor/PDCurses/x11/pdcutil.c +52 -0
- data/vendor/PDCurses/x11/pdcx11.c +316 -0
- data/vendor/PDCurses/x11/pdcx11.h +191 -0
- data/vendor/PDCurses/x11/sb.c +155 -0
- data/vendor/PDCurses/x11/x11.c +3686 -0
- data/vendor/PDCurses/x11/xcurses-config.in +81 -0
- metadata +255 -24
- data/.travis.yml +0 -13
- data/appveyor.yml +0 -16
@@ -0,0 +1,126 @@
|
|
1
|
+
/* Public Domain Curses */
|
2
|
+
|
3
|
+
#include <curspriv.h>
|
4
|
+
|
5
|
+
/*man-start**************************************************************
|
6
|
+
|
7
|
+
printw
|
8
|
+
------
|
9
|
+
|
10
|
+
### Synopsis
|
11
|
+
|
12
|
+
int printw(const char *fmt, ...);
|
13
|
+
int wprintw(WINDOW *win, const char *fmt, ...);
|
14
|
+
int mvprintw(int y, int x, const char *fmt, ...);
|
15
|
+
int mvwprintw(WINDOW *win, int y, int x, const char *fmt,...);
|
16
|
+
int vwprintw(WINDOW *win, const char *fmt, va_list varglist);
|
17
|
+
int vw_printw(WINDOW *win, const char *fmt, va_list varglist);
|
18
|
+
|
19
|
+
### Description
|
20
|
+
|
21
|
+
The printw() functions add a formatted string to the window at
|
22
|
+
the current or specified cursor position. The format strings are
|
23
|
+
the same as used in the standard C library's printf(). (printw()
|
24
|
+
can be used as a drop-in replacement for printf().)
|
25
|
+
|
26
|
+
### Return Value
|
27
|
+
|
28
|
+
All functions return the number of characters printed, or
|
29
|
+
ERR on error.
|
30
|
+
|
31
|
+
### Portability
|
32
|
+
X/Open BSD SYS V
|
33
|
+
printw Y Y Y
|
34
|
+
wprintw Y Y Y
|
35
|
+
mvprintw Y Y Y
|
36
|
+
mvwprintw Y Y Y
|
37
|
+
vwprintw Y - 4.0
|
38
|
+
vw_printw Y
|
39
|
+
|
40
|
+
**man-end****************************************************************/
|
41
|
+
|
42
|
+
#include <string.h>
|
43
|
+
|
44
|
+
int vwprintw(WINDOW *win, const char *fmt, va_list varglist)
|
45
|
+
{
|
46
|
+
char printbuf[513];
|
47
|
+
int len;
|
48
|
+
|
49
|
+
PDC_LOG(("vwprintw() - called\n"));
|
50
|
+
|
51
|
+
#ifdef HAVE_VSNPRINTF
|
52
|
+
len = vsnprintf(printbuf, 512, fmt, varglist);
|
53
|
+
#else
|
54
|
+
len = vsprintf(printbuf, fmt, varglist);
|
55
|
+
#endif
|
56
|
+
return (waddstr(win, printbuf) == ERR) ? ERR : len;
|
57
|
+
}
|
58
|
+
|
59
|
+
int printw(const char *fmt, ...)
|
60
|
+
{
|
61
|
+
va_list args;
|
62
|
+
int retval;
|
63
|
+
|
64
|
+
PDC_LOG(("printw() - called\n"));
|
65
|
+
|
66
|
+
va_start(args, fmt);
|
67
|
+
retval = vwprintw(stdscr, fmt, args);
|
68
|
+
va_end(args);
|
69
|
+
|
70
|
+
return retval;
|
71
|
+
}
|
72
|
+
|
73
|
+
int wprintw(WINDOW *win, const char *fmt, ...)
|
74
|
+
{
|
75
|
+
va_list args;
|
76
|
+
int retval;
|
77
|
+
|
78
|
+
PDC_LOG(("wprintw() - called\n"));
|
79
|
+
|
80
|
+
va_start(args, fmt);
|
81
|
+
retval = vwprintw(win, fmt, args);
|
82
|
+
va_end(args);
|
83
|
+
|
84
|
+
return retval;
|
85
|
+
}
|
86
|
+
|
87
|
+
int mvprintw(int y, int x, const char *fmt, ...)
|
88
|
+
{
|
89
|
+
va_list args;
|
90
|
+
int retval;
|
91
|
+
|
92
|
+
PDC_LOG(("mvprintw() - called\n"));
|
93
|
+
|
94
|
+
if (move(y, x) == ERR)
|
95
|
+
return ERR;
|
96
|
+
|
97
|
+
va_start(args, fmt);
|
98
|
+
retval = vwprintw(stdscr, fmt, args);
|
99
|
+
va_end(args);
|
100
|
+
|
101
|
+
return retval;
|
102
|
+
}
|
103
|
+
|
104
|
+
int mvwprintw(WINDOW *win, int y, int x, const char *fmt, ...)
|
105
|
+
{
|
106
|
+
va_list args;
|
107
|
+
int retval;
|
108
|
+
|
109
|
+
PDC_LOG(("mvwprintw() - called\n"));
|
110
|
+
|
111
|
+
if (wmove(win, y, x) == ERR)
|
112
|
+
return ERR;
|
113
|
+
|
114
|
+
va_start(args, fmt);
|
115
|
+
retval = vwprintw(win, fmt, args);
|
116
|
+
va_end(args);
|
117
|
+
|
118
|
+
return retval;
|
119
|
+
}
|
120
|
+
|
121
|
+
int vw_printw(WINDOW *win, const char *fmt, va_list varglist)
|
122
|
+
{
|
123
|
+
PDC_LOG(("vw_printw() - called\n"));
|
124
|
+
|
125
|
+
return vwprintw(win, fmt, varglist);
|
126
|
+
}
|
@@ -0,0 +1,279 @@
|
|
1
|
+
/* Public Domain Curses */
|
2
|
+
|
3
|
+
#include <curspriv.h>
|
4
|
+
|
5
|
+
/*man-start**************************************************************
|
6
|
+
|
7
|
+
refresh
|
8
|
+
-------
|
9
|
+
|
10
|
+
### Synopsis
|
11
|
+
|
12
|
+
int refresh(void);
|
13
|
+
int wrefresh(WINDOW *win);
|
14
|
+
int wnoutrefresh(WINDOW *win);
|
15
|
+
int doupdate(void);
|
16
|
+
int redrawwin(WINDOW *win);
|
17
|
+
int wredrawln(WINDOW *win, int beg_line, int num_lines);
|
18
|
+
|
19
|
+
### Description
|
20
|
+
|
21
|
+
wrefresh() copies the named window to the physical terminal
|
22
|
+
screen, taking into account what is already there in order to
|
23
|
+
optimize cursor movement. refresh() does the same, using stdscr.
|
24
|
+
These routines must be called to get any output on the terminal,
|
25
|
+
as other routines only manipulate data structures. Unless
|
26
|
+
leaveok() has been enabled, the physical cursor of the terminal
|
27
|
+
is left at the location of the window's cursor.
|
28
|
+
|
29
|
+
wnoutrefresh() and doupdate() allow multiple updates with more
|
30
|
+
efficiency than wrefresh() alone. wrefresh() works by first
|
31
|
+
calling wnoutrefresh(), which copies the named window to the
|
32
|
+
virtual screen. It then calls doupdate(), which compares the
|
33
|
+
virtual screen to the physical screen and does the actual
|
34
|
+
update. A series of calls to wrefresh() will result in
|
35
|
+
alternating calls to wnoutrefresh() and doupdate(), causing
|
36
|
+
several bursts of output to the screen. By first calling
|
37
|
+
wnoutrefresh() for each window, it is then possible to call
|
38
|
+
doupdate() only once.
|
39
|
+
|
40
|
+
In PDCurses, redrawwin() is equivalent to touchwin(), and
|
41
|
+
wredrawln() is the same as touchline(). In some other curses
|
42
|
+
implementations, there's a subtle distinction, but it has no
|
43
|
+
meaning in PDCurses.
|
44
|
+
|
45
|
+
### Return Value
|
46
|
+
|
47
|
+
All functions return OK on success and ERR on error.
|
48
|
+
|
49
|
+
### Portability
|
50
|
+
X/Open BSD SYS V
|
51
|
+
refresh Y Y Y
|
52
|
+
wrefresh Y Y Y
|
53
|
+
wnoutrefresh Y Y Y
|
54
|
+
doupdate Y Y Y
|
55
|
+
redrawwin Y - 4.0
|
56
|
+
wredrawln Y - 4.0
|
57
|
+
|
58
|
+
**man-end****************************************************************/
|
59
|
+
|
60
|
+
#include <string.h>
|
61
|
+
|
62
|
+
int wnoutrefresh(WINDOW *win)
|
63
|
+
{
|
64
|
+
int begy, begx; /* window's place on screen */
|
65
|
+
int i, j;
|
66
|
+
|
67
|
+
PDC_LOG(("wnoutrefresh() - called: win=%p\n", win));
|
68
|
+
|
69
|
+
if ( !win || (win->_flags & (_PAD|_SUBPAD)) )
|
70
|
+
return ERR;
|
71
|
+
|
72
|
+
begy = win->_begy;
|
73
|
+
begx = win->_begx;
|
74
|
+
|
75
|
+
for (i = 0, j = begy; i < win->_maxy; i++, j++)
|
76
|
+
{
|
77
|
+
if (win->_firstch[i] != _NO_CHANGE)
|
78
|
+
{
|
79
|
+
chtype *src = win->_y[i];
|
80
|
+
chtype *dest = curscr->_y[j] + begx;
|
81
|
+
|
82
|
+
int first = win->_firstch[i]; /* first changed */
|
83
|
+
int last = win->_lastch[i]; /* last changed */
|
84
|
+
|
85
|
+
/* ignore areas on the outside that are marked as changed,
|
86
|
+
but really aren't */
|
87
|
+
|
88
|
+
while (first <= last && src[first] == dest[first])
|
89
|
+
first++;
|
90
|
+
|
91
|
+
while (last >= first && src[last] == dest[last])
|
92
|
+
last--;
|
93
|
+
|
94
|
+
/* if any have really changed... */
|
95
|
+
|
96
|
+
if (first <= last)
|
97
|
+
{
|
98
|
+
memcpy(dest + first, src + first,
|
99
|
+
(last - first + 1) * sizeof(chtype));
|
100
|
+
|
101
|
+
first += begx;
|
102
|
+
last += begx;
|
103
|
+
|
104
|
+
if (first < curscr->_firstch[j] ||
|
105
|
+
curscr->_firstch[j] == _NO_CHANGE)
|
106
|
+
curscr->_firstch[j] = first;
|
107
|
+
|
108
|
+
if (last > curscr->_lastch[j])
|
109
|
+
curscr->_lastch[j] = last;
|
110
|
+
}
|
111
|
+
|
112
|
+
win->_firstch[i] = _NO_CHANGE; /* updated now */
|
113
|
+
}
|
114
|
+
|
115
|
+
win->_lastch[i] = _NO_CHANGE; /* updated now */
|
116
|
+
}
|
117
|
+
|
118
|
+
if (win->_clear)
|
119
|
+
win->_clear = FALSE;
|
120
|
+
|
121
|
+
if (!win->_leaveit)
|
122
|
+
{
|
123
|
+
curscr->_cury = win->_cury + begy;
|
124
|
+
curscr->_curx = win->_curx + begx;
|
125
|
+
}
|
126
|
+
|
127
|
+
return OK;
|
128
|
+
}
|
129
|
+
|
130
|
+
int doupdate(void)
|
131
|
+
{
|
132
|
+
int y;
|
133
|
+
bool clearall;
|
134
|
+
|
135
|
+
PDC_LOG(("doupdate() - called\n"));
|
136
|
+
|
137
|
+
if (!curscr)
|
138
|
+
return ERR;
|
139
|
+
|
140
|
+
if (isendwin()) /* coming back after endwin() called */
|
141
|
+
{
|
142
|
+
reset_prog_mode();
|
143
|
+
clearall = TRUE;
|
144
|
+
SP->alive = TRUE; /* so isendwin() result is correct */
|
145
|
+
}
|
146
|
+
else
|
147
|
+
clearall = curscr->_clear;
|
148
|
+
|
149
|
+
for (y = 0; y < SP->lines; y++)
|
150
|
+
{
|
151
|
+
PDC_LOG(("doupdate() - Transforming line %d of %d: %s\n",
|
152
|
+
y, SP->lines, (curscr->_firstch[y] != _NO_CHANGE) ?
|
153
|
+
"Yes" : "No"));
|
154
|
+
|
155
|
+
if (clearall || curscr->_firstch[y] != _NO_CHANGE)
|
156
|
+
{
|
157
|
+
int first, last;
|
158
|
+
|
159
|
+
chtype *src = curscr->_y[y];
|
160
|
+
chtype *dest = pdc_lastscr->_y[y];
|
161
|
+
|
162
|
+
if (clearall)
|
163
|
+
{
|
164
|
+
first = 0;
|
165
|
+
last = COLS - 1;
|
166
|
+
}
|
167
|
+
else
|
168
|
+
{
|
169
|
+
first = curscr->_firstch[y];
|
170
|
+
last = curscr->_lastch[y];
|
171
|
+
}
|
172
|
+
|
173
|
+
while (first <= last)
|
174
|
+
{
|
175
|
+
int len = 0;
|
176
|
+
|
177
|
+
/* build up a run of changed cells; if two runs are
|
178
|
+
separated by a single unchanged cell, ignore the
|
179
|
+
break */
|
180
|
+
|
181
|
+
if (clearall)
|
182
|
+
len = last - first + 1;
|
183
|
+
else
|
184
|
+
while (first + len <= last &&
|
185
|
+
(src[first + len] != dest[first + len] ||
|
186
|
+
(len && first + len < last &&
|
187
|
+
src[first + len + 1] != dest[first + len + 1])
|
188
|
+
)
|
189
|
+
)
|
190
|
+
len++;
|
191
|
+
|
192
|
+
/* update the screen, and pdc_lastscr */
|
193
|
+
|
194
|
+
if (len)
|
195
|
+
{
|
196
|
+
PDC_transform_line(y, first, len, src + first);
|
197
|
+
memcpy(dest + first, src + first, len * sizeof(chtype));
|
198
|
+
first += len;
|
199
|
+
}
|
200
|
+
|
201
|
+
/* skip over runs of unchanged cells */
|
202
|
+
|
203
|
+
while (first <= last && src[first] == dest[first])
|
204
|
+
first++;
|
205
|
+
}
|
206
|
+
|
207
|
+
curscr->_firstch[y] = _NO_CHANGE;
|
208
|
+
curscr->_lastch[y] = _NO_CHANGE;
|
209
|
+
}
|
210
|
+
}
|
211
|
+
|
212
|
+
curscr->_clear = FALSE;
|
213
|
+
|
214
|
+
if (SP->visibility)
|
215
|
+
PDC_gotoyx(curscr->_cury, curscr->_curx);
|
216
|
+
|
217
|
+
SP->cursrow = curscr->_cury;
|
218
|
+
SP->curscol = curscr->_curx;
|
219
|
+
|
220
|
+
return OK;
|
221
|
+
}
|
222
|
+
|
223
|
+
int wrefresh(WINDOW *win)
|
224
|
+
{
|
225
|
+
bool save_clear;
|
226
|
+
|
227
|
+
PDC_LOG(("wrefresh() - called\n"));
|
228
|
+
|
229
|
+
if ( !win || (win->_flags & (_PAD|_SUBPAD)) )
|
230
|
+
return ERR;
|
231
|
+
|
232
|
+
save_clear = win->_clear;
|
233
|
+
|
234
|
+
if (win == curscr)
|
235
|
+
curscr->_clear = TRUE;
|
236
|
+
else
|
237
|
+
wnoutrefresh(win);
|
238
|
+
|
239
|
+
if (save_clear && win->_maxy == SP->lines && win->_maxx == SP->cols)
|
240
|
+
curscr->_clear = TRUE;
|
241
|
+
|
242
|
+
return doupdate();
|
243
|
+
}
|
244
|
+
|
245
|
+
int refresh(void)
|
246
|
+
{
|
247
|
+
PDC_LOG(("refresh() - called\n"));
|
248
|
+
|
249
|
+
return wrefresh(stdscr);
|
250
|
+
}
|
251
|
+
|
252
|
+
int wredrawln(WINDOW *win, int start, int num)
|
253
|
+
{
|
254
|
+
int i;
|
255
|
+
|
256
|
+
PDC_LOG(("wredrawln() - called: win=%p start=%d num=%d\n",
|
257
|
+
win, start, num));
|
258
|
+
|
259
|
+
if (!win || start > win->_maxy || start + num > win->_maxy)
|
260
|
+
return ERR;
|
261
|
+
|
262
|
+
for (i = start; i < start + num; i++)
|
263
|
+
{
|
264
|
+
win->_firstch[i] = 0;
|
265
|
+
win->_lastch[i] = win->_maxx - 1;
|
266
|
+
}
|
267
|
+
|
268
|
+
return OK;
|
269
|
+
}
|
270
|
+
|
271
|
+
int redrawwin(WINDOW *win)
|
272
|
+
{
|
273
|
+
PDC_LOG(("redrawwin() - called: win=%p\n", win));
|
274
|
+
|
275
|
+
if (!win)
|
276
|
+
return ERR;
|
277
|
+
|
278
|
+
return wredrawln(win, 0, win->_maxy);
|
279
|
+
}
|
@@ -0,0 +1,578 @@
|
|
1
|
+
/* Public Domain Curses */
|
2
|
+
|
3
|
+
#include <curspriv.h>
|
4
|
+
|
5
|
+
/*man-start**************************************************************
|
6
|
+
|
7
|
+
scanw
|
8
|
+
-----
|
9
|
+
|
10
|
+
### Synopsis
|
11
|
+
|
12
|
+
int scanw(const char *fmt, ...);
|
13
|
+
int wscanw(WINDOW *win, const char *fmt, ...);
|
14
|
+
int mvscanw(int y, int x, const char *fmt, ...);
|
15
|
+
int mvwscanw(WINDOW *win, int y, int x, const char *fmt, ...);
|
16
|
+
int vwscanw(WINDOW *win, const char *fmt, va_list varglist);
|
17
|
+
int vw_scanw(WINDOW *win, const char *fmt, va_list varglist);
|
18
|
+
|
19
|
+
### Description
|
20
|
+
|
21
|
+
These routines correspond to the standard C library's scanf()
|
22
|
+
family. Each gets a string from the window via wgetnstr(), and
|
23
|
+
uses the resulting line as input for the scan.
|
24
|
+
|
25
|
+
### Return Value
|
26
|
+
|
27
|
+
On successful completion, these functions return the number of
|
28
|
+
items successfully matched. Otherwise they return ERR.
|
29
|
+
|
30
|
+
### Portability
|
31
|
+
X/Open BSD SYS V
|
32
|
+
scanw Y Y Y
|
33
|
+
wscanw Y Y Y
|
34
|
+
mvscanw Y Y Y
|
35
|
+
mvwscanw Y Y Y
|
36
|
+
vwscanw Y - 4.0
|
37
|
+
vw_scanw Y
|
38
|
+
|
39
|
+
**man-end****************************************************************/
|
40
|
+
|
41
|
+
#include <string.h>
|
42
|
+
|
43
|
+
#ifndef HAVE_VSSCANF
|
44
|
+
# include <stdlib.h>
|
45
|
+
# include <ctype.h>
|
46
|
+
# include <limits.h>
|
47
|
+
|
48
|
+
static int _pdc_vsscanf(const char *, const char *, va_list);
|
49
|
+
|
50
|
+
# define vsscanf _pdc_vsscanf
|
51
|
+
#endif
|
52
|
+
|
53
|
+
int vwscanw(WINDOW *win, const char *fmt, va_list varglist)
|
54
|
+
{
|
55
|
+
char scanbuf[256];
|
56
|
+
|
57
|
+
PDC_LOG(("vwscanw() - called\n"));
|
58
|
+
|
59
|
+
if (wgetnstr(win, scanbuf, 255) == ERR)
|
60
|
+
return ERR;
|
61
|
+
|
62
|
+
return vsscanf(scanbuf, fmt, varglist);
|
63
|
+
}
|
64
|
+
|
65
|
+
int scanw(const char *fmt, ...)
|
66
|
+
{
|
67
|
+
va_list args;
|
68
|
+
int retval;
|
69
|
+
|
70
|
+
PDC_LOG(("scanw() - called\n"));
|
71
|
+
|
72
|
+
va_start(args, fmt);
|
73
|
+
retval = vwscanw(stdscr, fmt, args);
|
74
|
+
va_end(args);
|
75
|
+
|
76
|
+
return retval;
|
77
|
+
}
|
78
|
+
|
79
|
+
int wscanw(WINDOW *win, const char *fmt, ...)
|
80
|
+
{
|
81
|
+
va_list args;
|
82
|
+
int retval;
|
83
|
+
|
84
|
+
PDC_LOG(("wscanw() - called\n"));
|
85
|
+
|
86
|
+
va_start(args, fmt);
|
87
|
+
retval = vwscanw(win, fmt, args);
|
88
|
+
va_end(args);
|
89
|
+
|
90
|
+
return retval;
|
91
|
+
}
|
92
|
+
|
93
|
+
int mvscanw(int y, int x, const char *fmt, ...)
|
94
|
+
{
|
95
|
+
va_list args;
|
96
|
+
int retval;
|
97
|
+
|
98
|
+
PDC_LOG(("mvscanw() - called\n"));
|
99
|
+
|
100
|
+
if (move(y, x) == ERR)
|
101
|
+
return ERR;
|
102
|
+
|
103
|
+
va_start(args, fmt);
|
104
|
+
retval = vwscanw(stdscr, fmt, args);
|
105
|
+
va_end(args);
|
106
|
+
|
107
|
+
return retval;
|
108
|
+
}
|
109
|
+
|
110
|
+
int mvwscanw(WINDOW *win, int y, int x, const char *fmt, ...)
|
111
|
+
{
|
112
|
+
va_list args;
|
113
|
+
int retval;
|
114
|
+
|
115
|
+
PDC_LOG(("mvscanw() - called\n"));
|
116
|
+
|
117
|
+
if (wmove(win, y, x) == ERR)
|
118
|
+
return ERR;
|
119
|
+
|
120
|
+
va_start(args, fmt);
|
121
|
+
retval = vwscanw(win, fmt, args);
|
122
|
+
va_end(args);
|
123
|
+
|
124
|
+
return retval;
|
125
|
+
}
|
126
|
+
|
127
|
+
int vw_scanw(WINDOW *win, const char *fmt, va_list varglist)
|
128
|
+
{
|
129
|
+
PDC_LOG(("vw_scanw() - called\n"));
|
130
|
+
|
131
|
+
return vwscanw(win, fmt, varglist);
|
132
|
+
}
|
133
|
+
|
134
|
+
#ifndef HAVE_VSSCANF
|
135
|
+
|
136
|
+
/* _pdc_vsscanf() - Internal routine to parse and format an input
|
137
|
+
buffer. It scans a series of input fields; each field is formatted
|
138
|
+
according to a supplied format string and the formatted input is
|
139
|
+
stored in the variable number of addresses passed. Returns the number
|
140
|
+
of input fields or EOF on error.
|
141
|
+
|
142
|
+
Don't compile this unless required. Some compilers (at least Borland
|
143
|
+
C++ 3.0) have to link with math libraries due to the use of floats.
|
144
|
+
|
145
|
+
Based on vsscanf.c and input.c from emx 0.8f library source,
|
146
|
+
Copyright (c) 1990-1992 by Eberhard Mattes, who has kindly agreed to
|
147
|
+
its inclusion in PDCurses. */
|
148
|
+
|
149
|
+
#define WHITE(x) ((x) == ' ' || (x) == '\t' || (x) == '\n')
|
150
|
+
|
151
|
+
#define NEXT(x) \
|
152
|
+
do { \
|
153
|
+
x = *buf++; \
|
154
|
+
if (!x) \
|
155
|
+
return (count ? count : EOF); \
|
156
|
+
++chars; \
|
157
|
+
} while (0)
|
158
|
+
|
159
|
+
#define UNGETC() \
|
160
|
+
do { \
|
161
|
+
--buf; --chars; \
|
162
|
+
} while (0)
|
163
|
+
|
164
|
+
static int _pdc_vsscanf(const char *buf, const char *fmt, va_list arg_ptr)
|
165
|
+
{
|
166
|
+
int count, chars, c, width, radix, d, i;
|
167
|
+
int *int_ptr;
|
168
|
+
long *long_ptr;
|
169
|
+
short *short_ptr;
|
170
|
+
char *char_ptr;
|
171
|
+
unsigned char f;
|
172
|
+
char neg, assign, ok, size;
|
173
|
+
long n;
|
174
|
+
char map[256], end;
|
175
|
+
double dx, dd, *dbl_ptr;
|
176
|
+
float *flt_ptr;
|
177
|
+
int exp;
|
178
|
+
char eneg;
|
179
|
+
|
180
|
+
count = 0;
|
181
|
+
chars = 0;
|
182
|
+
c = 0;
|
183
|
+
while ((f = *fmt) != 0)
|
184
|
+
{
|
185
|
+
if (WHITE(f))
|
186
|
+
{
|
187
|
+
do
|
188
|
+
{
|
189
|
+
++fmt;
|
190
|
+
f = *fmt;
|
191
|
+
}
|
192
|
+
while (WHITE(f));
|
193
|
+
do
|
194
|
+
{
|
195
|
+
c = *buf++;
|
196
|
+
if (!c)
|
197
|
+
{
|
198
|
+
if (!f || count)
|
199
|
+
return count;
|
200
|
+
else
|
201
|
+
return EOF;
|
202
|
+
} else
|
203
|
+
++chars;
|
204
|
+
}
|
205
|
+
while (WHITE(c));
|
206
|
+
UNGETC();
|
207
|
+
} else if (f != '%')
|
208
|
+
{
|
209
|
+
NEXT(c);
|
210
|
+
if (c != f)
|
211
|
+
return count;
|
212
|
+
++fmt;
|
213
|
+
} else
|
214
|
+
{
|
215
|
+
assign = TRUE;
|
216
|
+
width = INT_MAX;
|
217
|
+
char_ptr = NULL;
|
218
|
+
++fmt;
|
219
|
+
if (*fmt == '*')
|
220
|
+
{
|
221
|
+
assign = FALSE;
|
222
|
+
++fmt;
|
223
|
+
}
|
224
|
+
if (isdigit(*fmt))
|
225
|
+
{
|
226
|
+
width = 0;
|
227
|
+
while (isdigit(*fmt))
|
228
|
+
width = width * 10 + (*fmt++ - '0');
|
229
|
+
if (!width)
|
230
|
+
width = INT_MAX;
|
231
|
+
}
|
232
|
+
size = 0;
|
233
|
+
if (*fmt == 'h' || *fmt == 'l')
|
234
|
+
size = *fmt++;
|
235
|
+
f = *fmt;
|
236
|
+
switch (f)
|
237
|
+
{
|
238
|
+
case 'c':
|
239
|
+
if (width == INT_MAX)
|
240
|
+
width = 1;
|
241
|
+
if (assign)
|
242
|
+
char_ptr = va_arg(arg_ptr, char *);
|
243
|
+
while (width > 0)
|
244
|
+
{
|
245
|
+
--width;
|
246
|
+
NEXT(c);
|
247
|
+
if (assign)
|
248
|
+
{
|
249
|
+
*char_ptr++ = (char) c;
|
250
|
+
++count;
|
251
|
+
}
|
252
|
+
}
|
253
|
+
break;
|
254
|
+
case '[':
|
255
|
+
memset(map, 0, 256);
|
256
|
+
end = 0;
|
257
|
+
++fmt;
|
258
|
+
if (*fmt == '^')
|
259
|
+
{
|
260
|
+
++fmt;
|
261
|
+
end = 1;
|
262
|
+
}
|
263
|
+
i = 0;
|
264
|
+
for (;;)
|
265
|
+
{
|
266
|
+
f = (unsigned char) *fmt;
|
267
|
+
switch (f)
|
268
|
+
{
|
269
|
+
case 0:
|
270
|
+
/* avoid skipping past 0 */
|
271
|
+
--fmt;
|
272
|
+
NEXT(c);
|
273
|
+
goto string;
|
274
|
+
case ']':
|
275
|
+
if (i > 0)
|
276
|
+
{
|
277
|
+
NEXT(c);
|
278
|
+
goto string;
|
279
|
+
}
|
280
|
+
/* no break */
|
281
|
+
default:
|
282
|
+
if (fmt[1] == '-' && fmt[2]
|
283
|
+
&& f < (unsigned char)fmt[2])
|
284
|
+
{
|
285
|
+
memset(map + f, 1, (unsigned char)fmt[2] - f);
|
286
|
+
fmt += 2;
|
287
|
+
}
|
288
|
+
else
|
289
|
+
map[f] = 1;
|
290
|
+
break;
|
291
|
+
}
|
292
|
+
++fmt;
|
293
|
+
++i;
|
294
|
+
}
|
295
|
+
case 's':
|
296
|
+
memset(map, 0, 256);
|
297
|
+
map[' '] = 1;
|
298
|
+
map['\n'] = 1;
|
299
|
+
map['\r'] = 1;
|
300
|
+
map['\t'] = 1;
|
301
|
+
end = 1;
|
302
|
+
do
|
303
|
+
{
|
304
|
+
NEXT(c);
|
305
|
+
}
|
306
|
+
while (WHITE(c));
|
307
|
+
string:
|
308
|
+
if (assign)
|
309
|
+
char_ptr = va_arg(arg_ptr, char *);
|
310
|
+
while (width > 0 && map[(unsigned char) c] != end)
|
311
|
+
{
|
312
|
+
--width;
|
313
|
+
if (assign)
|
314
|
+
*char_ptr++ = (char) c;
|
315
|
+
c = *buf++;
|
316
|
+
if (!c)
|
317
|
+
break;
|
318
|
+
else
|
319
|
+
++chars;
|
320
|
+
}
|
321
|
+
if (assign)
|
322
|
+
{
|
323
|
+
*char_ptr = 0;
|
324
|
+
++count;
|
325
|
+
}
|
326
|
+
if (!c)
|
327
|
+
return count;
|
328
|
+
else
|
329
|
+
UNGETC();
|
330
|
+
break;
|
331
|
+
case 'f':
|
332
|
+
case 'e':
|
333
|
+
case 'E':
|
334
|
+
case 'g':
|
335
|
+
case 'G':
|
336
|
+
neg = ok = FALSE;
|
337
|
+
dx = 0.0;
|
338
|
+
do
|
339
|
+
{
|
340
|
+
NEXT(c);
|
341
|
+
}
|
342
|
+
while (WHITE(c));
|
343
|
+
if (c == '+')
|
344
|
+
{
|
345
|
+
NEXT(c);
|
346
|
+
--width;
|
347
|
+
} else if (c == '-')
|
348
|
+
{
|
349
|
+
neg = TRUE;
|
350
|
+
NEXT(c);
|
351
|
+
--width;
|
352
|
+
}
|
353
|
+
while (width > 0 && isdigit(c))
|
354
|
+
{
|
355
|
+
--width;
|
356
|
+
dx = dx * 10.0 + (double) (c - '0');
|
357
|
+
ok = TRUE;
|
358
|
+
c = *buf++;
|
359
|
+
if (!c)
|
360
|
+
break;
|
361
|
+
else
|
362
|
+
++chars;
|
363
|
+
}
|
364
|
+
if (width > 0 && c == '.')
|
365
|
+
{
|
366
|
+
--width;
|
367
|
+
dd = 10.0;
|
368
|
+
NEXT(c);
|
369
|
+
while (width > 0 && isdigit(c))
|
370
|
+
{
|
371
|
+
--width;
|
372
|
+
dx += (double) (c - '0') / dd;
|
373
|
+
dd *= 10.0;
|
374
|
+
ok = TRUE;
|
375
|
+
c = *buf++;
|
376
|
+
if (!c)
|
377
|
+
break;
|
378
|
+
else
|
379
|
+
++chars;
|
380
|
+
}
|
381
|
+
}
|
382
|
+
if (!ok)
|
383
|
+
return count;
|
384
|
+
if (width > 0 && (c == 'e' || c == 'E'))
|
385
|
+
{
|
386
|
+
eneg = FALSE;
|
387
|
+
exp = 0;
|
388
|
+
NEXT(c);
|
389
|
+
--width;
|
390
|
+
if (width > 0 && c == '+')
|
391
|
+
{
|
392
|
+
NEXT(c);
|
393
|
+
--width;
|
394
|
+
} else if (width > 0 && c == '-')
|
395
|
+
{
|
396
|
+
eneg = TRUE;
|
397
|
+
NEXT(c);
|
398
|
+
--width;
|
399
|
+
}
|
400
|
+
if (!(width > 0 && isdigit(c)))
|
401
|
+
{
|
402
|
+
UNGETC();
|
403
|
+
return count;
|
404
|
+
}
|
405
|
+
while (width > 0 && isdigit(c))
|
406
|
+
{
|
407
|
+
--width;
|
408
|
+
exp = exp * 10 + (c - '0');
|
409
|
+
c = *buf++;
|
410
|
+
if (!c)
|
411
|
+
break;
|
412
|
+
else
|
413
|
+
++chars;
|
414
|
+
}
|
415
|
+
if (eneg)
|
416
|
+
exp = -exp;
|
417
|
+
while (exp > 0)
|
418
|
+
{
|
419
|
+
dx *= 10.0;
|
420
|
+
--exp;
|
421
|
+
}
|
422
|
+
while (exp < 0)
|
423
|
+
{
|
424
|
+
dx /= 10.0;
|
425
|
+
++exp;
|
426
|
+
}
|
427
|
+
}
|
428
|
+
if (assign)
|
429
|
+
{
|
430
|
+
if (neg)
|
431
|
+
dx = -dx;
|
432
|
+
if (size == 'l')
|
433
|
+
{
|
434
|
+
dbl_ptr = va_arg(arg_ptr, double *);
|
435
|
+
*dbl_ptr = dx;
|
436
|
+
}
|
437
|
+
else
|
438
|
+
{
|
439
|
+
flt_ptr = va_arg(arg_ptr, float *);
|
440
|
+
*flt_ptr = (float)dx;
|
441
|
+
}
|
442
|
+
++count;
|
443
|
+
}
|
444
|
+
if (!c)
|
445
|
+
return count;
|
446
|
+
else
|
447
|
+
UNGETC();
|
448
|
+
break;
|
449
|
+
case 'i':
|
450
|
+
neg = FALSE;
|
451
|
+
radix = 10;
|
452
|
+
do
|
453
|
+
{
|
454
|
+
NEXT(c);
|
455
|
+
}
|
456
|
+
while (WHITE(c));
|
457
|
+
if (!(width > 0 && c == '0'))
|
458
|
+
goto scan_complete_number;
|
459
|
+
NEXT(c);
|
460
|
+
--width;
|
461
|
+
if (width > 0 && (c == 'x' || c == 'X'))
|
462
|
+
{
|
463
|
+
NEXT(c);
|
464
|
+
radix = 16;
|
465
|
+
--width;
|
466
|
+
}
|
467
|
+
else if (width > 0 && (c >= '0' && c <= '7'))
|
468
|
+
radix = 8;
|
469
|
+
goto scan_unsigned_number;
|
470
|
+
case 'd':
|
471
|
+
case 'u':
|
472
|
+
case 'o':
|
473
|
+
case 'x':
|
474
|
+
case 'X':
|
475
|
+
do
|
476
|
+
{
|
477
|
+
NEXT(c);
|
478
|
+
}
|
479
|
+
while (WHITE(c));
|
480
|
+
switch (f)
|
481
|
+
{
|
482
|
+
case 'o':
|
483
|
+
radix = 8;
|
484
|
+
break;
|
485
|
+
case 'x':
|
486
|
+
case 'X':
|
487
|
+
radix = 16;
|
488
|
+
break;
|
489
|
+
default:
|
490
|
+
radix = 10;
|
491
|
+
break;
|
492
|
+
}
|
493
|
+
scan_complete_number:
|
494
|
+
neg = FALSE;
|
495
|
+
if (width > 0 && c == '+')
|
496
|
+
{
|
497
|
+
NEXT(c);
|
498
|
+
--width;
|
499
|
+
}
|
500
|
+
else if (width > 0 && c == '-' && radix == 10)
|
501
|
+
{
|
502
|
+
neg = TRUE;
|
503
|
+
NEXT(c);
|
504
|
+
--width;
|
505
|
+
}
|
506
|
+
scan_unsigned_number:
|
507
|
+
n = 0;
|
508
|
+
ok = FALSE;
|
509
|
+
while (width > 0)
|
510
|
+
{
|
511
|
+
--width;
|
512
|
+
if (isdigit(c))
|
513
|
+
d = c - '0';
|
514
|
+
else if (isupper(c))
|
515
|
+
d = c - 'A' + 10;
|
516
|
+
else if (islower(c))
|
517
|
+
d = c - 'a' + 10;
|
518
|
+
else
|
519
|
+
break;
|
520
|
+
if (d < 0 || d >= radix)
|
521
|
+
break;
|
522
|
+
ok = TRUE;
|
523
|
+
n = n * radix + d;
|
524
|
+
c = *buf++;
|
525
|
+
if (!c)
|
526
|
+
break;
|
527
|
+
else
|
528
|
+
++chars;
|
529
|
+
}
|
530
|
+
if (!ok)
|
531
|
+
return count;
|
532
|
+
if (assign)
|
533
|
+
{
|
534
|
+
if (neg)
|
535
|
+
n = -n;
|
536
|
+
switch (size)
|
537
|
+
{
|
538
|
+
case 'h':
|
539
|
+
short_ptr = va_arg(arg_ptr, short *);
|
540
|
+
*short_ptr = (short) n;
|
541
|
+
break;
|
542
|
+
case 'l':
|
543
|
+
long_ptr = va_arg(arg_ptr, long *);
|
544
|
+
*long_ptr = (long) n;
|
545
|
+
break;
|
546
|
+
default:
|
547
|
+
int_ptr = va_arg(arg_ptr, int *);
|
548
|
+
*int_ptr = (int) n;
|
549
|
+
}
|
550
|
+
++count;
|
551
|
+
}
|
552
|
+
if (!c)
|
553
|
+
return count;
|
554
|
+
else
|
555
|
+
UNGETC();
|
556
|
+
break;
|
557
|
+
case 'n':
|
558
|
+
if (assign)
|
559
|
+
{
|
560
|
+
int_ptr = va_arg(arg_ptr, int *);
|
561
|
+
*int_ptr = chars;
|
562
|
+
++count;
|
563
|
+
}
|
564
|
+
break;
|
565
|
+
default:
|
566
|
+
if (!f) /* % at end of string */
|
567
|
+
return count;
|
568
|
+
NEXT(c);
|
569
|
+
if (c != f)
|
570
|
+
return count;
|
571
|
+
break;
|
572
|
+
}
|
573
|
+
++fmt;
|
574
|
+
}
|
575
|
+
}
|
576
|
+
return count;
|
577
|
+
}
|
578
|
+
#endif /* HAVE_VSSCANF */
|