/* * BRLTTY - A background process providing access to the console screen (when in * text mode) for a blind person using a refreshable braille display. * * Copyright (C) 1995-2021 by The BRLTTY Developers. * * BRLTTY comes with ABSOLUTELY NO WARRANTY. * * This is free software, placed under the terms of the * GNU Lesser General Public License, as published by the Free Software * Foundation; either version 2.1 of the License, or (at your option) any * later version. Please see the file LICENSE-LGPL for details. * * Web Page: http://brltty.app/ * * This software is maintained by Dave Mielke . */ #ifndef BRLAPI_INCLUDED_KEYRANGES #define BRLAPI_INCLUDED_KEYRANGES #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /* Header file for the range list management module */ #include "prologue.h" typedef uint64_t KeyrangeElem; #define KeyrangeFlags(v) (((v) >> 32) & 0xffffffffull) #define KeyrangeVal(v) ((v) & 0xffffffffull) #define KeyrangeElem(flags,val) (((KeyrangeElem)(flags) << 32) | (val)) typedef struct KeyrangeList { uint32_t minFlags, maxFlags; uint32_t minVal, maxVal; struct KeyrangeList *next; } KeyrangeList; /* Function : freeKeyrangeList */ /* Frees a whole list */ /* If you want to destroy a whole list, call this function, rather than */ /* calling freeKeyrange on each element, since th latter cares about links */ /* and hence is slower */ extern void freeKeyrangeList(KeyrangeList **l); /* Function : inKeyrangeList */ /* Determines if the range list l contains x */ /* If yes, returns the adress of the cell [a..b] such that a<=x<=b */ /* If no, returns NULL */ extern KeyrangeList *inKeyrangeList(KeyrangeList *l, KeyrangeElem n); /* Function : displayKeyrangeList */ /* Prints a range list on stdout */ /* This is for debugging only */ extern void displayKeyrangeList(KeyrangeList *l); /* Function : addKeyrange */ /* Adds a range to a range list */ /* Return 0 if success, -1 if an error occurs */ extern int addKeyrange(KeyrangeElem x0, KeyrangeElem y0, KeyrangeList **l); /* Function : removeKeyrange */ /* Removes a range from a range list */ /* Returns 0 if success, -1 if failure */ extern int removeKeyrange(KeyrangeElem x0, KeyrangeElem y0, KeyrangeList **l); #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* BRLAPI_INCLUDED_KEYRANGES */