PageRenderTime 52ms CodeModel.GetById 24ms RepoModel.GetById 1ms app.codeStats 0ms

/user/microwin/nxlib/nxlib-0.45/X11/include/X11/Xresource.h

https://bitbucket.org/thelearninglabs/uclinux-distro-tll-public
C Header | 360 lines | 195 code | 64 blank | 101 comment | 1 complexity | b465dd0e123b516252a03ccb0a1f4448 MD5 | raw file
Possible License(s): LGPL-2.1, BSD-3-Clause, MPL-2.0-no-copyleft-exception, LGPL-3.0, Unlicense, GPL-2.0, GPL-3.0, CC-BY-SA-3.0, AGPL-1.0, ISC, MIT, 0BSD, LGPL-2.0
  1. /* $Xorg: Xresource.h,v 1.7 2001/02/09 02:03:39 xorgcvs Exp $ */
  2. /***********************************************************
  3. Copyright 1987, 1988, 1998 The Open Group
  4. Permission to use, copy, modify, distribute, and sell this software and its
  5. documentation for any purpose is hereby granted without fee, provided that
  6. the above copyright notice appear in all copies and that both that
  7. copyright notice and this permission notice appear in supporting
  8. documentation.
  9. The above copyright notice and this permission notice shall be included in
  10. all copies or substantial portions of the Software.
  11. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  12. IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  13. FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  14. OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
  15. AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  16. CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  17. Except as contained in this notice, the name of The Open Group shall not be
  18. used in advertising or otherwise to promote the sale, use or other dealings
  19. in this Software without prior written authorization from The Open Group.
  20. Copyright 1987, 1988 by Digital Equipment Corporation, Maynard, Massachusetts.
  21. All Rights Reserved
  22. Permission to use, copy, modify, and distribute this software and its
  23. documentation for any purpose and without fee is hereby granted,
  24. provided that the above copyright notice appear in all copies and that
  25. both that copyright notice and this permission notice appear in
  26. supporting documentation, and that the name of Digital not be
  27. used in advertising or publicity pertaining to distribution of the
  28. software without specific, written prior permission.
  29. DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
  30. ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
  31. DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
  32. ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
  33. WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
  34. ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
  35. SOFTWARE.
  36. ******************************************************************/
  37. /* $XFree86: xc/lib/X11/Xresource.h,v 3.8 2001/12/14 19:54:10 dawes Exp $ */
  38. #ifndef _XRESOURCE_H_
  39. #define _XRESOURCE_H_
  40. #ifndef _XP_PRINT_SERVER_
  41. #include <X11/Xlib.h>
  42. #endif
  43. /****************************************************************
  44. ****************************************************************
  45. *** ***
  46. *** ***
  47. *** X Resource Manager Intrinsics ***
  48. *** ***
  49. *** ***
  50. ****************************************************************
  51. ****************************************************************/
  52. _XFUNCPROTOBEGIN
  53. /****************************************************************
  54. *
  55. * Memory Management
  56. *
  57. ****************************************************************/
  58. extern char *Xpermalloc(
  59. unsigned int /* size */
  60. );
  61. /****************************************************************
  62. *
  63. * Quark Management
  64. *
  65. ****************************************************************/
  66. typedef int XrmQuark, *XrmQuarkList;
  67. #define NULLQUARK ((XrmQuark) 0)
  68. typedef char *XrmString;
  69. #define NULLSTRING ((XrmString) 0)
  70. /* find quark for string, create new quark if none already exists */
  71. extern XrmQuark XrmStringToQuark(
  72. _Xconst char* /* string */
  73. );
  74. extern XrmQuark XrmPermStringToQuark(
  75. _Xconst char* /* string */
  76. );
  77. /* find string for quark */
  78. extern XrmString XrmQuarkToString(
  79. XrmQuark /* quark */
  80. );
  81. extern XrmQuark XrmUniqueQuark(
  82. void
  83. );
  84. #define XrmStringsEqual(a1, a2) (strcmp(a1, a2) == 0)
  85. /****************************************************************
  86. *
  87. * Conversion of Strings to Lists
  88. *
  89. ****************************************************************/
  90. typedef enum {XrmBindTightly, XrmBindLoosely} XrmBinding, *XrmBindingList;
  91. extern void XrmStringToQuarkList(
  92. _Xconst char* /* string */,
  93. XrmQuarkList /* quarks_return */
  94. );
  95. extern void XrmStringToBindingQuarkList(
  96. _Xconst char* /* string */,
  97. XrmBindingList /* bindings_return */,
  98. XrmQuarkList /* quarks_return */
  99. );
  100. /****************************************************************
  101. *
  102. * Name and Class lists.
  103. *
  104. ****************************************************************/
  105. typedef XrmQuark XrmName;
  106. typedef XrmQuarkList XrmNameList;
  107. #define XrmNameToString(name) XrmQuarkToString(name)
  108. #define XrmStringToName(string) XrmStringToQuark(string)
  109. #define XrmStringToNameList(str, name) XrmStringToQuarkList(str, name)
  110. typedef XrmQuark XrmClass;
  111. typedef XrmQuarkList XrmClassList;
  112. #define XrmClassToString(c_class) XrmQuarkToString(c_class)
  113. #define XrmStringToClass(c_class) XrmStringToQuark(c_class)
  114. #define XrmStringToClassList(str,c_class) XrmStringToQuarkList(str, c_class)
  115. /****************************************************************
  116. *
  117. * Resource Representation Types and Values
  118. *
  119. ****************************************************************/
  120. typedef XrmQuark XrmRepresentation;
  121. #define XrmStringToRepresentation(string) XrmStringToQuark(string)
  122. #define XrmRepresentationToString(type) XrmQuarkToString(type)
  123. typedef struct {
  124. unsigned int size;
  125. XPointer addr;
  126. } XrmValue, *XrmValuePtr;
  127. /****************************************************************
  128. *
  129. * Resource Manager Functions
  130. *
  131. ****************************************************************/
  132. typedef struct _XrmHashBucketRec *XrmHashBucket;
  133. typedef XrmHashBucket *XrmHashTable;
  134. typedef XrmHashTable XrmSearchList[];
  135. typedef struct _XrmHashBucketRec *XrmDatabase;
  136. extern void XrmDestroyDatabase(
  137. XrmDatabase /* database */
  138. );
  139. extern void XrmQPutResource(
  140. XrmDatabase* /* database */,
  141. XrmBindingList /* bindings */,
  142. XrmQuarkList /* quarks */,
  143. XrmRepresentation /* type */,
  144. XrmValue* /* value */
  145. );
  146. extern void XrmPutResource(
  147. XrmDatabase* /* database */,
  148. _Xconst char* /* specifier */,
  149. _Xconst char* /* type */,
  150. XrmValue* /* value */
  151. );
  152. extern void XrmQPutStringResource(
  153. XrmDatabase* /* database */,
  154. XrmBindingList /* bindings */,
  155. XrmQuarkList /* quarks */,
  156. _Xconst char* /* value */
  157. );
  158. extern void XrmPutStringResource(
  159. XrmDatabase* /* database */,
  160. _Xconst char* /* specifier */,
  161. _Xconst char* /* value */
  162. );
  163. extern void XrmPutLineResource(
  164. XrmDatabase* /* database */,
  165. _Xconst char* /* line */
  166. );
  167. extern Bool XrmQGetResource(
  168. XrmDatabase /* database */,
  169. XrmNameList /* quark_name */,
  170. XrmClassList /* quark_class */,
  171. XrmRepresentation* /* quark_type_return */,
  172. XrmValue* /* value_return */
  173. );
  174. extern Bool XrmGetResource(
  175. XrmDatabase /* database */,
  176. _Xconst char* /* str_name */,
  177. _Xconst char* /* str_class */,
  178. char** /* str_type_return */,
  179. XrmValue* /* value_return */
  180. );
  181. extern Bool XrmQGetSearchList(
  182. XrmDatabase /* database */,
  183. XrmNameList /* names */,
  184. XrmClassList /* classes */,
  185. XrmSearchList /* list_return */,
  186. int /* list_length */
  187. );
  188. extern Bool XrmQGetSearchResource(
  189. XrmSearchList /* list */,
  190. XrmName /* name */,
  191. XrmClass /* class */,
  192. XrmRepresentation* /* type_return */,
  193. XrmValue* /* value_return */
  194. );
  195. /****************************************************************
  196. *
  197. * Resource Database Management
  198. *
  199. ****************************************************************/
  200. #ifndef _XP_PRINT_SERVER_
  201. extern void XrmSetDatabase(
  202. Display* /* display */,
  203. XrmDatabase /* database */
  204. );
  205. extern XrmDatabase XrmGetDatabase(
  206. Display* /* display */
  207. );
  208. #endif /* !_XP_PRINT_SERVER_ */
  209. extern XrmDatabase XrmGetFileDatabase(
  210. _Xconst char* /* filename */
  211. );
  212. extern Status XrmCombineFileDatabase(
  213. _Xconst char* /* filename */,
  214. XrmDatabase* /* target */,
  215. Bool /* override */
  216. );
  217. extern XrmDatabase XrmGetStringDatabase(
  218. _Xconst char* /* data */ /* null terminated string */
  219. );
  220. extern void XrmPutFileDatabase(
  221. XrmDatabase /* database */,
  222. _Xconst char* /* filename */
  223. );
  224. extern void XrmMergeDatabases(
  225. XrmDatabase /* source_db */,
  226. XrmDatabase* /* target_db */
  227. );
  228. extern void XrmCombineDatabase(
  229. XrmDatabase /* source_db */,
  230. XrmDatabase* /* target_db */,
  231. Bool /* override */
  232. );
  233. #define XrmEnumAllLevels 0
  234. #define XrmEnumOneLevel 1
  235. extern Bool XrmEnumerateDatabase(
  236. XrmDatabase /* db */,
  237. XrmNameList /* name_prefix */,
  238. XrmClassList /* class_prefix */,
  239. int /* mode */,
  240. Bool (*)(
  241. XrmDatabase* /* db */,
  242. XrmBindingList /* bindings */,
  243. XrmQuarkList /* quarks */,
  244. XrmRepresentation* /* type */,
  245. XrmValue* /* value */,
  246. XPointer /* closure */
  247. ) /* proc */,
  248. XPointer /* closure */
  249. );
  250. extern const char *XrmLocaleOfDatabase(
  251. XrmDatabase /* database */
  252. );
  253. /****************************************************************
  254. *
  255. * Command line option mapping to resource entries
  256. *
  257. ****************************************************************/
  258. typedef enum {
  259. XrmoptionNoArg, /* Value is specified in OptionDescRec.value */
  260. XrmoptionIsArg, /* Value is the option string itself */
  261. XrmoptionStickyArg, /* Value is characters immediately following option */
  262. XrmoptionSepArg, /* Value is next argument in argv */
  263. XrmoptionResArg, /* Resource and value in next argument in argv */
  264. XrmoptionSkipArg, /* Ignore this option and the next argument in argv */
  265. XrmoptionSkipLine, /* Ignore this option and the rest of argv */
  266. XrmoptionSkipNArgs /* Ignore this option and the next
  267. OptionDescRes.value arguments in argv */
  268. } XrmOptionKind;
  269. typedef struct {
  270. char *option; /* Option abbreviation in argv */
  271. char *specifier; /* Resource specifier */
  272. XrmOptionKind argKind; /* Which style of option it is */
  273. XPointer value; /* Value to provide if XrmoptionNoArg */
  274. } XrmOptionDescRec, *XrmOptionDescList;
  275. extern void XrmParseCommand(
  276. XrmDatabase* /* database */,
  277. XrmOptionDescList /* table */,
  278. int /* table_count */,
  279. _Xconst char* /* name */,
  280. int* /* argc_in_out */,
  281. char** /* argv_in_out */
  282. );
  283. _XFUNCPROTOEND
  284. #endif /* _XRESOURCE_H_ */
  285. /* DON'T ADD STUFF AFTER THIS #endif */