003 File Manager
Current Path:
/usr/src/contrib/ncurses/ncurses/base
usr
/
src
/
contrib
/
ncurses
/
ncurses
/
base
/
📁
..
📄
MKkeyname.awk
(6.48 KB)
📄
MKlib_gen.sh
(13.34 KB)
📄
MKunctrl.awk
(5.76 KB)
📄
README
(2.52 KB)
📄
define_key.c
(3.73 KB)
📄
key_defined.c
(3.61 KB)
📄
keybound.c
(3.17 KB)
📄
keyok.c
(4.03 KB)
📄
legacy_coding.c
(3.01 KB)
📄
lib_addch.c
(15.66 KB)
📄
lib_addstr.c
(7.21 KB)
📄
lib_beep.c
(3.54 KB)
📄
lib_bkgd.c
(6.98 KB)
📄
lib_box.c
(5.24 KB)
📄
lib_chgat.c
(3.42 KB)
📄
lib_clear.c
(2.77 KB)
📄
lib_clearok.c
(2.78 KB)
📄
lib_clrbot.c
(3.28 KB)
📄
lib_clreol.c
(3.5 KB)
📄
lib_color.c
(28.66 KB)
📄
lib_colorset.c
(3.12 KB)
📄
lib_delch.c
(3.1 KB)
📄
lib_delwin.c
(3.61 KB)
📄
lib_dft_fgbg.c
(4.27 KB)
📄
lib_driver.c
(4.88 KB)
📄
lib_echo.c
(3.37 KB)
📄
lib_endwin.c
(3.42 KB)
📄
lib_erase.c
(3.64 KB)
📄
lib_flash.c
(3.53 KB)
📄
lib_freeall.c
(5.58 KB)
📄
lib_getch.c
(18.86 KB)
📄
lib_getstr.c
(6.7 KB)
📄
lib_hline.c
(3.55 KB)
📄
lib_immedok.c
(2.75 KB)
📄
lib_inchstr.c
(3.16 KB)
📄
lib_initscr.c
(4.18 KB)
📄
lib_insch.c
(5.2 KB)
📄
lib_insdel.c
(3 KB)
📄
lib_insnstr.c
(3.85 KB)
📄
lib_instr.c
(4.2 KB)
📄
lib_isendwin.c
(3.01 KB)
📄
lib_leaveok.c
(2.78 KB)
📄
lib_mouse.c
(52.49 KB)
📄
lib_move.c
(2.97 KB)
📄
lib_mvwin.c
(4.87 KB)
📄
lib_newterm.c
(10.81 KB)
📄
lib_newwin.c
(10.96 KB)
📄
lib_nl.c
(3.53 KB)
📄
lib_overlay.c
(6.42 KB)
📄
lib_pad.c
(10.73 KB)
📄
lib_printw.c
(4.91 KB)
📄
lib_redrawln.c
(3.52 KB)
📄
lib_refresh.c
(9.38 KB)
📄
lib_restart.c
(4.4 KB)
📄
lib_scanw.c
(4.05 KB)
📄
lib_screen.c
(24.15 KB)
📄
lib_scroll.c
(5.8 KB)
📄
lib_scrollok.c
(2.78 KB)
📄
lib_scrreg.c
(2.96 KB)
📄
lib_set_term.c
(21.57 KB)
📄
lib_slk.c
(7.85 KB)
📄
lib_slkatr_set.c
(3.58 KB)
📄
lib_slkatrof.c
(3.28 KB)
📄
lib_slkatron.c
(3.29 KB)
📄
lib_slkatrset.c
(3.05 KB)
📄
lib_slkattr.c
(3.09 KB)
📄
lib_slkclear.c
(3.52 KB)
📄
lib_slkcolor.c
(3.66 KB)
📄
lib_slkinit.c
(3.63 KB)
📄
lib_slklab.c
(3.17 KB)
📄
lib_slkrefr.c
(5.66 KB)
📄
lib_slkset.c
(5.02 KB)
📄
lib_slktouch.c
(3.01 KB)
📄
lib_touch.c
(3.77 KB)
📄
lib_ungetch.c
(3.58 KB)
📄
lib_vline.c
(3.57 KB)
📄
lib_wattroff.c
(3.09 KB)
📄
lib_wattron.c
(3.1 KB)
📄
lib_winch.c
(2.78 KB)
📄
lib_window.c
(7.83 KB)
📄
nc_panel.c
(2.81 KB)
📄
new_pair.c
(9.92 KB)
📄
resizeterm.c
(14.29 KB)
📄
safe_sprintf.c
(7.86 KB)
📄
sigaction.c
(3.62 KB)
📄
tries.c
(4.86 KB)
📄
use_window.c
(2.79 KB)
📄
version.c
(2.59 KB)
📄
vsscanf.c
(8.54 KB)
📄
wresize.c
(8.41 KB)
Editing: vsscanf.c
/**************************************************************************** * Copyright 2020 Thomas E. Dickey * * Copyright 1998-2004,2012 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * * "Software"), to deal in the Software without restriction, including * * without limitation the rights to use, copy, modify, merge, publish, * * distribute, distribute with modifications, sublicense, and/or sell * * copies of the Software, and to permit persons to whom the Software is * * furnished to do so, subject to the following conditions: * * * * The above copyright notice and this permission notice shall be included * * in all copies or substantial portions of the Software. * * * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, * * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR * * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * * THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * * * Except as contained in this notice, the name(s) of the above copyright * * holders shall not be used in advertising or otherwise to promote the * * sale, use or other dealings in this Software without prior written * * authorization. * ****************************************************************************/ /**************************************************************************** * State-machine fallback written by Thomas E. Dickey 2002 * ****************************************************************************/ /* * This function is needed to support vwscanw */ #include <curses.priv.h> #if !HAVE_VSSCANF MODULE_ID("$Id: vsscanf.c,v 1.21 2020/02/02 23:34:34 tom Exp $") #if !(HAVE_VFSCANF || HAVE__DOSCAN) #include <ctype.h> #define L_SQUARE '[' #define R_SQUARE ']' typedef enum { cUnknown ,cError /* anything that isn't ANSI */ ,cAssigned ,cChar ,cInt ,cFloat ,cDouble ,cPointer ,cLong ,cShort ,cRange ,cString } ChunkType; typedef enum { oUnknown ,oShort ,oLong } OtherType; typedef enum { sUnknown ,sPercent /* last was '%' beginning a format */ ,sNormal /* ...somewhere in the middle */ ,sLeft /* last was left square bracket beginning a range */ ,sRange /* ...somewhere in the middle */ ,sFinal /* last finished a format */ } ScanState; static ChunkType final_ch(int ch, OtherType other) { ChunkType result = cUnknown; switch (ch) { case 'c': if (other == oUnknown) result = cChar; else result = cError; break; case 'd': case 'i': case 'X': case 'x': switch (other) { case oUnknown: result = cInt; break; case oShort: result = cShort; break; case oLong: result = cLong; break; } break; case 'E': case 'e': case 'f': case 'g': switch (other) { case oUnknown: result = cFloat; break; case oShort: result = cError; break; case oLong: result = cDouble; break; } break; case 'n': if (other == oUnknown) result = cAssigned; else result = cError; break; case 'p': if (other == oUnknown) result = cPointer; else result = cError; break; case 's': if (other == oUnknown) result = cString; else result = cError; break; } return result; } static OtherType other_ch(int ch) { OtherType result = oUnknown; switch (ch) { case 'h': result = oShort; break; case 'l': result = oLong; break; } return result; } #endif /*VARARGS2*/ NCURSES_EXPORT(int) vsscanf(const char *str, const char *format, va_list ap) { #if HAVE_VFSCANF || HAVE__DOSCAN /* * This code should work on anything descended from AT&T SVr1. */ FILE strbuf; strbuf._flag = _IOREAD; strbuf._ptr = strbuf._base = (unsigned char *) str; strbuf._cnt = strlen(str); strbuf._file = _NFILE; #if HAVE_VFSCANF return (vfscanf(&strbuf, format, ap)); #else return (_doscan(&strbuf, format, ap)); #endif #else static int can_convert = -1; int assigned = 0; int consumed = 0; T((T_CALLED("vsscanf(%s,%s,...)"), _nc_visbuf2(1, str), _nc_visbuf2(2, format))); /* * This relies on having a working "%n" format conversion. Check if it * works. Only very old C libraries do not support it. * * FIXME: move this check into the configure script. */ if (can_convert < 0) { int check1; int check2; if (sscanf("123", "%d%n", &check1, &check2) > 0 && check1 == 123 && check2 == 3) { can_convert = 1; } else { can_convert = 0; } } if (can_convert) { size_t len_fmt = strlen(format) + 32; char *my_fmt = malloc(len_fmt); ChunkType chunk, ctest; OtherType other, otest; ScanState state; unsigned n; int eaten; void *pointer; if (my_fmt != 0) { /* * Split the original format into chunks, adding a "%n" to the end * of each (except of course if it used %n), and use that * information to decide where to start scanning the next chunk. * * FIXME: does %n count bytes or characters? If the latter, this * will require further work for multibyte strings. */ while (*format != '\0') { /* find a chunk */ state = sUnknown; chunk = cUnknown; other = oUnknown; pointer = 0; for (n = 0; format[n] != 0 && state != sFinal; ++n) { my_fmt[n] = format[n]; switch (state) { case sUnknown: if (format[n] == '%') state = sPercent; break; case sPercent: if (format[n] == '%') { state = sUnknown; } else if (format[n] == L_SQUARE) { state = sLeft; } else { state = sNormal; --n; } break; case sLeft: state = sRange; if (format[n] == '^') { ++n; my_fmt[n] = format[n]; } break; case sRange: if (format[n] == R_SQUARE) { state = sFinal; chunk = cRange; } break; case sNormal: if (format[n] == '*') { state = sUnknown; } else { if ((ctest = final_ch(format[n], other)) != cUnknown) { state = sFinal; chunk = ctest; } else if ((otest = other_ch(format[n])) != oUnknown) { other = otest; } else if (isalpha(UChar(format[n]))) { state = sFinal; chunk = cError; } } break; case sFinal: break; } } my_fmt[n] = '\0'; format += n; if (chunk == cUnknown || chunk == cError) { if (assigned == 0) assigned = EOF; break; } /* add %n, if the format was not that */ if (chunk != cAssigned) { _nc_STRCAT(my_fmt, "%n", len_fmt); } switch (chunk) { case cAssigned: _nc_STRCAT(my_fmt, "%n", len_fmt); pointer = &eaten; break; case cInt: pointer = va_arg(ap, int *); break; case cShort: pointer = va_arg(ap, short *); break; case cFloat: pointer = va_arg(ap, float *); break; case cDouble: pointer = va_arg(ap, double *); break; case cLong: pointer = va_arg(ap, long *); break; case cPointer: pointer = va_arg(ap, void *); break; case cChar: case cRange: case cString: pointer = va_arg(ap, char *); break; case cError: case cUnknown: break; } /* do the conversion */ T(("...converting chunk #%d type %d(%s,%s)", assigned + 1, chunk, _nc_visbuf2(1, str + consumed), _nc_visbuf2(2, my_fmt))); if (sscanf(str + consumed, my_fmt, pointer, &eaten) > 0) consumed += eaten; else break; ++assigned; } free(my_fmt); } } returnCode(assigned); #endif } #else extern NCURSES_EXPORT(void) _nc_vsscanf(void); /* quiet's gcc warning */ NCURSES_EXPORT(void) _nc_vsscanf(void) { } /* nonempty for strict ANSI compilers */ #endif /* !HAVE_VSSCANF */
Upload File
Create Folder