X-Git-Url: http://ncurses.scripts.mit.edu/?p=ncurses.git;a=blobdiff_plain;f=ncurses%2Fcurses.priv.h;h=57fd2409aae9ed13a2655fadf0bca4632590275a;hp=86505e839cd9c3722cc571ce09582dfc0d3c56dd;hb=9378ce0407e95f6b1e2c20ec5035f0916d278944;hpb=28e9f9700c7bf7280cf9d71304a880b570a0b4ea diff --git a/ncurses/curses.priv.h b/ncurses/curses.priv.h index 86505e83..57fd2409 100644 --- a/ncurses/curses.priv.h +++ b/ncurses/curses.priv.h @@ -34,7 +34,7 @@ /* - * $Id: curses.priv.h,v 1.344 2007/10/06 21:29:02 tom Exp $ + * $Id: curses.priv.h,v 1.351 2007/11/25 00:57:29 tom Exp $ * * curses.priv.h * @@ -305,20 +305,25 @@ color_t; #include #define _nc_lock_global(name) pthread_mutex_lock(&_nc_globals.mutex_##name) #define _nc_unlock_global(name) pthread_mutex_unlock(&_nc_globals.mutex_##name) + +extern NCURSES_EXPORT(void) _nc_lock_window(WINDOW *); +extern NCURSES_EXPORT(void) _nc_unlock_window(WINDOW *); + #else #error POSIX threads requires --enable-reentrant option #endif #else #define _nc_lock_global(name) /* nothing */ #define _nc_unlock_global(name) /* nothing */ + +#define _nc_lock_window(name) TRUE +#define _nc_unlock_window(name) /* nothing */ + #endif #define _nc_lock_screen(name) /* nothing */ #define _nc_unlock_screen(name) /* nothing */ -#define _nc_lock_window(name) /* nothing */ -#define _nc_unlock_window(name) /* nothing */ - /* * Definitions for color pairs */ @@ -477,6 +482,17 @@ typedef struct { size_t size; } TRACEBUF; +/* + * The filesystem database normally uses a single-letter for the lower level + * of directories. Use a hexadecimal code for filesystems which do not + * preserve mixed-case names. + */ +#if MIXEDCASE_FILENAMES +#define LEAF_FMT "%c" +#else +#define LEAF_FMT "%02x" +#endif + /* * TRACEMSE_FMT is no longer than 80 columns, there are 5 numbers that * could at most have 10 digits, and the mask contains no more than 32 bits @@ -559,6 +575,7 @@ typedef struct { #ifdef USE_PTHREADS pthread_mutex_t mutex_set_SP; pthread_mutex_t mutex_use_screen; + pthread_mutex_t mutex_use_window; pthread_mutex_t mutex_windowlist; pthread_mutex_t mutex_tst_tracef; pthread_mutex_t mutex_tracef; @@ -840,6 +857,9 @@ extern NCURSES_EXPORT_VAR(SIG_ATOMIC_T) _nc_have_sigwinch; int addch_x; /* x-position for addch_work[] */ int addch_y; /* y-position for addch_work[] */ #endif +#ifdef USE_PTHREADS + pthread_mutex_t mutex_use_window; +#endif }; #define WINDOW_EXT(win,field) (((WINDOWLIST *)(win))->field) @@ -926,7 +946,7 @@ extern NCURSES_EXPORT_VAR(SIG_ATOMIC_T) _nc_have_sigwinch; #endif #if USE_WIDEC_SUPPORT /* { */ -#define isEILSEQ(status) ((status == (size_t)-1) && (errno == EILSEQ)) +#define isEILSEQ(status) (((size_t)status == (size_t)-1) && (errno == EILSEQ)) #define init_mb(state) memset(&state, 0, sizeof(state)) @@ -936,43 +956,29 @@ extern NCURSES_EXPORT_VAR(SIG_ATOMIC_T) _nc_have_sigwinch; #define NulColor /* nothing */ #endif -#define AttrEq(a,b) ((a).attr == (b).attr) -#define ExtcEq(a,b) ((a).ext_color == (b).ext_color) -#define TextEq(a,b) (!memcmp((a).chars, (b).chars, sizeof(a.chars))) - -/* - * cchar_t may not be packed, e.g., on a 64-bit platform. - * - * Set "NCURSES_CHAR_EQ" to use a workaround that compares the structure - * member-by-member so that valgrind will not see compares against the - * uninitialized filler bytes. - */ -#if NCURSES_CHAR_EQ -#if defined(USE_TERMLIB) && !defined(NEED_NCURSES_CH_T) -#else -static NCURSES_INLINE int -_nc_char_eq(NCURSES_CH_T a, NCURSES_CH_T b) -{ -#if NCURSES_EXT_COLORS - return (AttrEq(a,b) && TextEq(a,b) && ExtcEq(a,b)); -#else - return (AttrEq(a,b) && TextEq(a,b)); -#endif -} -#define CharEq(a,b) _nc_char_eq(a,b) -#endif -#else -#define CharEq(a,b) (!memcmp(&(a), &(b), sizeof(a))) -#endif - #define NulChar 0,0,0,0 /* FIXME: see CCHARW_MAX */ #define CharOf(c) ((c).chars[0]) #define AttrOf(c) ((c).attr) + #define AddAttr(c,a) AttrOf(c) |= ((a) & A_ATTRIBUTES) #define RemAttr(c,a) AttrOf(c) &= ~((a) & A_ATTRIBUTES) #define SetAttr(c,a) AttrOf(c) = ((a) & A_ATTRIBUTES) | WidecExt(c) + #define NewChar2(c,a) { a, { c, NulChar } NulColor } #define NewChar(ch) NewChar2(ChCharOf(ch), ChAttrOf(ch)) + +#if CCHARW_MAX == 5 +#define CharEq(a,b) (((a).attr == (b).attr) \ + && (a).chars[0] == (b).chars[0] \ + && (a).chars[1] == (b).chars[1] \ + && (a).chars[2] == (b).chars[2] \ + && (a).chars[3] == (b).chars[3] \ + && (a).chars[4] == (b).chars[4] \ + if_EXT_COLORS(&& (a).ext_color == (b).ext_color)) +#else +#define CharEq(a,b) (!memcmp(&(a), &(b), sizeof(a))) +#endif + #define SetChar(ch,c,a) do { \ NCURSES_CH_T *_cp = &ch; \ memset(_cp, 0, sizeof(ch)); \ @@ -1509,9 +1515,11 @@ extern NCURSES_EXPORT(void) _nc_trace_tries (TRIES *); #if NO_LEAKS extern NCURSES_EXPORT(void) _nc_alloc_entry_leaks(void); extern NCURSES_EXPORT(void) _nc_captoinfo_leaks(void); +extern NCURSES_EXPORT(void) _nc_codes_leaks(void); extern NCURSES_EXPORT(void) _nc_comp_captab_leaks(void); extern NCURSES_EXPORT(void) _nc_comp_scan_leaks(void); extern NCURSES_EXPORT(void) _nc_keyname_leaks(void); +extern NCURSES_EXPORT(void) _nc_names_leaks(void); extern NCURSES_EXPORT(void) _nc_tgetent_leaks(void); #endif @@ -1522,11 +1530,7 @@ extern NCURSES_EXPORT(void) _nc_scroll_window (WINDOW *, int const, NCURSES_SIZE #endif #if USE_WIDEC_SUPPORT && !defined(USE_TERMLIB) -#ifdef linux extern NCURSES_EXPORT(size_t) _nc_wcrtomb (char *, wchar_t, mbstate_t *); -#else -#define _nc_wcrtomb(s,wc,ps) wcrtomb(s,wc,ps) -#endif #endif #if USE_SIZECHANGE