Mercurial > hg > xemacs-beta
view lwlib/xlwscrollbarP.h @ 4549:68d1ca56cffa
First part of interactive checks that coding systems encode regions.
2008-01-21 Aidan Kehoe <kehoea@parhasard.net>
* coding.el (decode-coding-string):
(encode-coding-string): Accept GNU's NOCOPY argument for
these. Todo; write compiler macros to use it.
(query-coding-warning-face): New face, to show unencodable
characters.
(default-query-coding-region-safe-charset-skip-chars-map):
New variable, a cache used by #'default-query-coding-region.
(default-query-coding-region): Default implementation of
#'query-coding-region, using the safe-charsets and safe-chars
coding systemproperties.
(query-coding-region): New function; can a given coding system
encode a given region?
(query-coding-string): New function; can a given coding system
encode a given string?
(unencodable-char-position): Function API taken from GNU; return
the first unencodable position given a string and coding system.
(encode-coding-char): Function API taken from GNU; return CHAR
encoded using CODING-SYSTEM, or nil if CODING-SYSTEM would trash
CHAR.
((unless (featurep 'mule)): Override the default
query-coding-region implementation on non-Mule.
* mule/mule-coding.el (make-8-bit-generate-helper): Eliminate a
duplicate comment.
(make-8-bit-choose-category): Simplify implementation.
(8-bit-fixed-query-coding-region): Implementation of
#'query-coding-region for coding systems created with
#'make-8-bit-coding-system.
(make-8-bit-coding-system): Initialise the #'query-coding-region
implementation for these character sets.
(make-8-bit-coding-system): Ditto for the compiler macro version
of this function.
* unicode.el (unicode-query-coding-skip-chars-arg): New variable,
used by unicode-query-coding-region, initialised in
mule/general-late.el.
(unicode-query-coding-region): New function, the
#'query-coding-region implementation for Unicode coding systems.
Initialise the query-coding-function property for the Unicode
coding systems to #'unicode-query-coding-region.
* mule/mule-charset.el (charset-skip-chars-string): New
function. Return a #'skip-chars-forward argument that skips all
characters in CHARSET.
(map-charset-chars): Function synced from GNU, modified to work
with XEmacs. Map FUNC across the int value charset ranges of
CHARSET.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Mon, 21 Jan 2008 22:51:21 +0100 |
parents | 3ecd8885ac67 |
children | ade4c7e2c6cb |
line wrap: on
line source
/* Implements a lightweight scrollbar widget. Copyright (C) 1992, 1993, 1994 Lucid, Inc. This file is part of the Lucid Widget Library. The Lucid Widget Library is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. The Lucid Widget Library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with XEmacs; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* Created by Douglas Keller <dkeller@vnet.ibm.com> */ #ifndef _XlwScrollBarP_h #define _XlwScrollBarP_h /* ** Widget class */ typedef struct { int dummy_field; /* keep compiler happy */ } XlwScrollBarClassPart; typedef struct _XlwScrollbarClassRec { CoreClassPart core_class; XlwScrollBarClassPart scrollbar_class; } XlwScrollBarClassRec; enum XlwScrollbarArm { ARM_NONE, ARM_SLIDER, ARM_UP, ARM_DOWN, ARM_PAGEUP, ARM_PAGEDOWN }; enum XlwScrollbarForcedScroll { FORCED_SCROLL_NONE, FORCED_SCROLL_DOWNRIGHT, FORCED_SCROLL_UPLEFT }; /* ** Widget instance */ typedef struct { /* resources */ XtCallbackList valueChangedCBL; XtCallbackList incrementCBL; XtCallbackList decrementCBL; XtCallbackList pageIncrementCBL; XtCallbackList pageDecrementCBL; XtCallbackList toTopCBL; XtCallbackList toBottomCBL; XtCallbackList dragCBL; Pixel foreground; Pixel topShadowColor; Pixel bottomShadowColor; Pixel troughColor; Pixel armColor; Pixel armTopShadowColor; Pixel armBottomShadowColor; Pixmap topShadowPixmap; Pixmap bottomShadowPixmap; int shadowThickness; Boolean showArrows; int minimum; int maximum; int sliderSize; int value; int pageIncrement; int increment; int initialDelay; int repeatDelay; unsigned char orientation; char *sliderStyle; char *knobStyle; char *arrowPosition; /* private */ Pixmap grayPixmap; GC backgroundGC; GC topShadowGC; GC bottomShadowGC; int above, ss, below; int lastY; enum XlwScrollbarArm armed; enum XlwScrollbarForcedScroll forced_scroll; int savedValue; Boolean fullRedrawNext; Boolean timerActive; XtIntervalId timerId; } XlwScrollBarPart; typedef struct _XlwScrollBarRec { CorePart core; XlwScrollBarPart sb; } XlwScrollBarRec; #endif /* _XlwScrollBarP_h */