ObjectP.h
上传用户:lctgjx
上传日期:2022-06-04
资源大小:8887k
文件大小:7k
源码类别:

流媒体/Mpeg4/MP4

开发平台:

Visual C++

  1. /* $Xorg: ObjectP.h,v 1.4 2001/02/09 02:03:56 xorgcvs Exp $ */
  2. /***********************************************************
  3. Copyright 1987, 1988, 1994, 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. #ifndef _Xt_ObjectP_h_
  38. #define _Xt_ObjectP_h_
  39. #include <X11/Object.h>
  40. /**********************************************************
  41.  * Object Instance Data Structures
  42.  *
  43.  **********************************************************/
  44. /* these fields match CorePart and can not be changed */
  45. typedef struct _ObjectPart {
  46.     Widget          self;               /* pointer to widget itself          */
  47.     WidgetClass     widget_class;       /* pointer to Widget's ClassRec      */
  48.     Widget          parent;             /* parent widget                     */
  49.     XrmName         xrm_name;           /* widget resource name quarkified   */
  50.     Boolean         being_destroyed;    /* marked for destroy                */
  51.     XtCallbackList  destroy_callbacks;  /* who to call when widget destroyed */
  52.     XtPointer       constraints;        /* constraint record                 */
  53. } ObjectPart;
  54. typedef struct _ObjectRec {
  55.     ObjectPart  object;
  56. } ObjectRec;
  57. /********************************************************
  58.  * Object Class Data Structures
  59.  *
  60.  ********************************************************/
  61. /* these fields match CoreClassPart and can not be changed */
  62. /* ideally these structures would only contain the fields required;
  63.    but because the CoreClassPart cannot be changed at this late date
  64.    extraneous fields are necessary to make the field offsets match */
  65. typedef struct _ObjectClassPart {
  66.     WidgetClass     superclass;         /* pointer to superclass ClassRec   */
  67.     String          class_name;         /* widget resource class name       */
  68.     Cardinal        widget_size;        /* size in bytes of widget record   */
  69.     XtProc          class_initialize;   /* class initialization proc        */
  70.     XtWidgetClassProc class_part_initialize; /* dynamic initialization      */
  71.     XtEnum          class_inited;       /* has class been initialized?      */
  72.     XtInitProc      initialize;         /* initialize subclass fields       */
  73.     XtArgsProc      initialize_hook;    /* notify that initialize called    */
  74.     XtProc          obj1; /* NULL                             */
  75.     XtPointer       obj2;               /* NULL                             */
  76.     Cardinal        obj3;               /* NULL                             */
  77.     XtResourceList  resources;          /* resources for subclass fields    */
  78.     Cardinal        num_resources;      /* number of entries in resources   */
  79.     XrmClass        xrm_class;          /* resource class quarkified        */
  80.     Boolean         obj4;               /* NULL                             */
  81.     XtEnum          obj5;               /* NULL                             */
  82.     Boolean         obj6;               /* NULL     */
  83.     Boolean         obj7;               /* NULL                             */
  84.     XtWidgetProc    destroy;            /* free data for subclass pointers  */
  85.     XtProc          obj8;               /* NULL                             */
  86.     XtProc          obj9;               /* NULL             */
  87.     XtSetValuesFunc set_values;         /* set subclass resource values     */
  88.     XtArgsFunc      set_values_hook;    /* notify that set_values called    */
  89.     XtProc          obj10;              /* NULL                             */
  90.     XtArgsProc      get_values_hook;    /* notify that get_values called    */
  91.     XtProc          obj11;              /* NULL                             */
  92.     XtVersionType   version;            /* version of intrinsics used       */
  93.     XtPointer       callback_private;   /* list of callback offsets         */
  94.     String          obj12;              /* NULL                             */
  95.     XtProc          obj13;              /* NULL                             */
  96.     XtProc          obj14;              /* NULL                             */
  97.     XtPointer       extension;          /* pointer to extension record      */
  98. }ObjectClassPart;
  99. typedef struct {
  100.     XtPointer next_extension; /* 1st 4 required for all extension records */
  101.     XrmQuark record_type; /* NULLQUARK; when on ObjectClassPart */
  102.     long version; /* must be XtObjectExtensionVersion */
  103.     Cardinal record_size; /* sizeof(ObjectClassExtensionRec) */
  104.     XtAllocateProc allocate;
  105.     XtDeallocateProc deallocate;
  106. } ObjectClassExtensionRec, *ObjectClassExtension;
  107. typedef struct _ObjectClassRec {
  108.     ObjectClassPart object_class;
  109. } ObjectClassRec;
  110. externalref ObjectClassRec objectClassRec;
  111. #define XtObjectExtensionVersion 1L
  112. #define XtInheritAllocate ((XtAllocateProc) _XtInherit)
  113. #define XtInheritDeallocate ((XtDeallocateProc) _XtInherit)
  114. #endif /*_Xt_ObjectP_h_*/