X10.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*
  2. * Copyright 1985, 1986, 1987 by the Massachusetts Institute of Technology
  3. *
  4. * Permission to use, copy, modify, and distribute this software and its
  5. * documentation for any purpose and without fee is hereby granted, provided
  6. * that the above copyright notice appear in all copies and that both that
  7. * copyright notice and this permission notice appear in supporting
  8. * documentation, and that the name of M.I.T. not be used in advertising
  9. * or publicity pertaining to distribution of the software without specific,
  10. * written prior permission. M.I.T. makes no representations about the
  11. * suitability of this software for any purpose. It is provided "as is"
  12. * without express or implied warranty.
  13. *
  14. * The X Window System is a Trademark of MIT.
  15. *
  16. */
  17. /*
  18. * X10.h - Header definition and support file for the C subroutine
  19. * interface library for V10 support routines.
  20. */
  21. #ifndef _X10_H_
  22. #define _X10_H_
  23. /* Used in XDraw and XDrawFilled */
  24. typedef struct {
  25. short x, y;
  26. unsigned short flags;
  27. } Vertex;
  28. /* The meanings of the flag bits. If the bit is 1 the predicate is true */
  29. #define VertexRelative 0x0001 /* else absolute */
  30. #define VertexDontDraw 0x0002 /* else draw */
  31. #define VertexCurved 0x0004 /* else straight */
  32. #define VertexStartClosed 0x0008 /* else not */
  33. #define VertexEndClosed 0x0010 /* else not */
  34. /*#define VertexDrawLastPoint 0x0020 */ /* else don't */
  35. /*
  36. The VertexDrawLastPoint option has not been implemented in XDraw and
  37. XDrawFilled so it shouldn't be defined.
  38. */
  39. /*
  40. * XAssoc - Associations used in the XAssocTable data structure. The
  41. * associations are used as circular queue entries in the association table
  42. * which is contains an array of circular queues (buckets).
  43. */
  44. typedef struct _XAssoc {
  45. struct _XAssoc *next; /* Next object in this bucket. */
  46. struct _XAssoc *prev; /* Previous object in this bucket. */
  47. Display *display; /* Display which owns the id. */
  48. XID x_id; /* X Window System id. */
  49. void *data; /* Pointer to untyped memory. */
  50. } XAssoc;
  51. /*
  52. * XAssocTable - X Window System id to data structure pointer association
  53. * table. An XAssocTable is a hash table whose buckets are circular
  54. * queues of XAssoc's. The XAssocTable is constructed from an array of
  55. * XAssoc's which are the circular queue headers (bucket headers).
  56. * An XAssocTable consists an XAssoc pointer that points to the first
  57. * bucket in the bucket array and an integer that indicates the number
  58. * of buckets in the array.
  59. */
  60. typedef struct {
  61. XAssoc *buckets; /* Pointer to first bucket in bucket array.*/
  62. int size; /* Table size (number of buckets). */
  63. } XAssocTable;
  64. XAssocTable *XCreateAssocTable(int size);
  65. char *XLookUpAssoc(Display *dpy, XAssocTable *table, XID x_id);
  66. #endif /* _X10_H_ */