mirror of
				https://github.com/halpz/re3.git
				synced 2025-10-26 01:07:05 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			4792 lines
		
	
	
		
			168 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			4792 lines
		
	
	
		
			168 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /******************************************/
 | |
| /*                                        */
 | |
| /*    RenderWare(TM) Graphics Library     */
 | |
| /*                                        */
 | |
| /******************************************/
 | |
| 
 | |
| /*
 | |
|  * This file is a product of Criterion Software Ltd.
 | |
|  *
 | |
|  * This file is provided as is with no warranties of any kind and is
 | |
|  * provided without any obligation on Criterion Software Ltd.
 | |
|  * or Canon Inc. to assist in its use or modification.
 | |
|  *
 | |
|  * Criterion Software Ltd. and Canon Inc. will not, under any
 | |
|  * circumstances, be liable for any lost revenue or other damages
 | |
|  * arising from the use of this file.
 | |
|  *
 | |
|  * Copyright (c) 1999. Criterion Software Ltd.
 | |
|  * All Rights Reserved.
 | |
|  */
 | |
| 
 | |
| /*************************************************************************
 | |
|  *
 | |
|  * Filename: <C:/daily/rwsdk/include/d3d8/rwcore.h>
 | |
|  * Automatically Generated on: Wed Jul 10 10:45:00 2002
 | |
|  *
 | |
|  ************************************************************************/
 | |
| 
 | |
| #ifndef RWCORE_H
 | |
| #define RWCORE_H
 | |
| 
 | |
| /*--- System Header Files ---*/
 | |
| #include <rwplcore.h>
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/common/barwasmm.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2resort.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2macros.h ---*/
 | |
| 
 | |
| #define RxClusterDecCursorByStride(_cluster, _stride)                           \
 | |
|     ((_cluster)->currentData =                                                  \
 | |
|       (void *)(((RwUInt8 *)(_cluster)->currentData) -                           \
 | |
|          (_stride)))
 | |
| 
 | |
| #define RxClusterDecCursor(_cluster) \
 | |
|     RxClusterDecCursorByStride(_cluster, (_cluster)->stride)
 | |
| 
 | |
| #define RxClusterIncCursorByStride(_cluster, _stride)                           \
 | |
|     ((_cluster)->currentData =                                                  \
 | |
|      (void *)(((RwUInt8 *)(_cluster)->currentData) +                            \
 | |
|               (_stride)))
 | |
| 
 | |
| #define RxClusterIncCursor(_cluster) \
 | |
|     RxClusterIncCursorByStride(_cluster, (_cluster)->stride)
 | |
| 
 | |
| #define RxClusterResetCursor(_cluster) \
 | |
|     ((_cluster)->currentData = (_cluster)->data)
 | |
| 
 | |
| #define RxClusterGetCursorData(_cluster, _type) \
 | |
|     ((_type *)(_cluster)->currentData)
 | |
| 
 | |
| #define RxClusterGetIndexedData(_cluster, _type, _index)                        \
 | |
|     ((_type *)(((RwUInt8 *)(_cluster)->data) + (_cluster)->stride*(_index)))
 | |
| 
 | |
| #define RxClusterGetFreeIndex(_cluster) ( (_cluster)->numUsed++ )
 | |
| 
 | |
| #define RxPipelineClusterAssertAttributeSet(_cluster, _attributeSet)    \
 | |
|     RWASSERT( (_cluster)->clusterRef->attributeSet != NULL &&           \
 | |
|               rwstrcmp((_cluster)->clusterRef->attributeSet,              \
 | |
|                      (_attributeSet)) == 0 )
 | |
| 
 | |
| #define RxPipelineNodeParamGetData(_param) \
 | |
|     ( (_param)->dataParam )
 | |
| 
 | |
| #define RxPipelineNodeParamGetHeap(_param) \
 | |
|     ( (_param)->heap )
 | |
| 
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2heap.h ---*/
 | |
| 
 | |
| #if (defined(RWDEBUG) && (defined(RWMEMDEBUG)))
 | |
| 
 | |
| #if (!defined(DISABLERWHEAP))
 | |
| #define DISABLERWHEAP
 | |
| #endif /* (!defined(DISABLERWHEAP)) */
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) && (defined(RWMEMDEBUG))) */
 | |
| 
 | |
| typedef struct rxHeapFreeBlock rxHeapFreeBlock;
 | |
| typedef struct rxHeapSuperBlockDescriptor rxHeapSuperBlockDescriptor;
 | |
| typedef struct RxHeap RxHeap;
 | |
| typedef struct rxHeapBlockHeader rxHeapBlockHeader;
 | |
| 
 | |
| struct rxHeapFreeBlock
 | |
| {
 | |
|     RwUInt32            size;
 | |
|     rxHeapBlockHeader  *ptr;
 | |
| };
 | |
| 
 | |
| struct rxHeapSuperBlockDescriptor
 | |
| {
 | |
|     void *start;
 | |
|     RwUInt32 size;
 | |
|     rxHeapSuperBlockDescriptor *next;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxHeap 
 | |
|  * structure describing a pipeline execution heap 
 | |
|  */
 | |
| struct RxHeap
 | |
| {
 | |
|     RwUInt32            superBlockSize; /**< Granularity of heap growth */
 | |
|     rxHeapSuperBlockDescriptor *head;   /**< Internally used superblock pointer */
 | |
|     rxHeapBlockHeader  *headBlock;      /**< Internally used block pointer */
 | |
|     rxHeapFreeBlock    *freeBlocks;     /**< Internally used free blocks pointer */
 | |
|     RwUInt32            entriesAlloced; /**< Number of entries allocated */
 | |
|     RwUInt32            entriesUsed;    /**< Number of entries used */
 | |
|     RwBool              dirty;          /**< Internally used boolean, flags whether
 | |
|                                          *   the heap needs resetting or not. */
 | |
| };
 | |
| 
 | |
| struct rxHeapBlockHeader
 | |
| {
 | |
|     /* present in all blocks (used & unused) */
 | |
|     rxHeapBlockHeader  *prev, *next;
 | |
|     RwUInt32            size;
 | |
|     rxHeapFreeBlock    *freeEntry; /* (or null) */
 | |
|     RwUInt32            pad[4]; /* alignment padding to 32 bytes */
 | |
| };
 | |
| 
 | |
| /* This wrapper cheaply early-outs when a heap doesn't *need* resetting */
 | |
| #define RxHeapReset(heap) \
 | |
|     ((FALSE == (heap)->dirty) ? (TRUE) : (_rxHeapReset(heap)))
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxHeap      *RxHeapCreate(RwUInt32 size);
 | |
| extern void         RxHeapDestroy(RxHeap * heap);
 | |
| extern RwBool       _rxHeapReset(RxHeap * heap);
 | |
| extern void        *RxHeapAlloc(RxHeap * heap, RwUInt32 size);
 | |
| extern void         RxHeapFree(RxHeap * heap, void *block);
 | |
| extern void        *RxHeapRealloc(RxHeap * heap, void *block,
 | |
|                                   RwUInt32 newSize, RwBool allowCopy);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #if (defined(DISABLERWHEAP))
 | |
| 
 | |
| typedef struct rxHeapMallocTrace rxHeapMallocTrace;
 | |
| struct rxHeapMallocTrace
 | |
| {
 | |
|     rxHeapMallocTrace *next;
 | |
|     rxHeapBlockHeader *block;
 | |
| };
 | |
| 
 | |
| #endif                          /* (defined(DISABLERWHEAP)) */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2dep.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2core.h ---*/
 | |
| 
 | |
| extern RwInt32 _rxPipelineMaxNodes;
 | |
| extern RwInt32 _rxHeapInitialSize;
 | |
| /* LEGACY-SUPPORT MACRO */
 | |
| #define _rwRxHeapInitialSize _rxHeapInitialSize
 | |
| 
 | |
| /* Beneficial padding of PowerPipe types is still being worked out... */
 | |
| #define PADCLUSTERSx
 | |
| 
 | |
| 
 | |
| /*************************************************************
 | |
|  * Global Defines
 | |
|  */
 | |
| 
 | |
| #define RWBOOLTOGGLE(bVar) ((bVar == FALSE)?(bVar = TRUE):(bVar = FALSE))
 | |
| 
 | |
| /* Both these currently limited due to the use of RwUInt32 bit-fields */
 | |
| #define RXNODEMAXCLUSTERSOFINTEREST 32
 | |
| #define RXNODEMAXOUTPUTS            32
 | |
| 
 | |
| /* Useful (for memory alloc) to limit this during pipeline construction */
 | |
| #define RXPIPELINEDEFAULTMAXNODES   64
 | |
| 
 | |
| /*
 | |
|  * Cluster flags
 | |
|  */
 | |
| 
 | |
| #define rxCLFLAGS_NULL          ((RwUInt16) 0x0000U)
 | |
| #define rxCLFLAGS_CLUSTERVALID  ((RwUInt16) 0x0001U)
 | |
| #define rxCLFLAGS_EXTERNAL ((RwUInt16) 0x0002U)
 | |
| #define rxCLFLAGS_EXTERNALMODIFIABLE ((RwUInt16) 0x0004U | 0x0002U)
 | |
| #define rxCLFLAGS_MODIFIED ((RwUInt16) 0x0008U)
 | |
| 
 | |
| /*
 | |
|  * Packet flags
 | |
|  */
 | |
| 
 | |
| #define rxPKFLAGS_NULL        ((RwUInt16) 0x0000U)
 | |
| 
 | |
| /*
 | |
|  * used in input specification
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \ref RxClusterValidityReq
 | |
|  * Flags specifying the state requirements for
 | |
|  * a \ref RxCluster on entry to a node */
 | |
| enum RxClusterValidityReq
 | |
| {
 | |
|     rxCLREQ_DONTWANT = 0, /**<The cluster is required but any data within it is
 | |
|                            * not wanted and will be overwritten */
 | |
|     rxCLREQ_REQUIRED = 1, /**<The cluster is required and it must contain
 | |
|                            * valid data */
 | |
|     rxCLREQ_OPTIONAL = 2, /**<The cluster will be used if it is present and
 | |
|                            * contains valid data, otherwise the node will
 | |
|                            * make do without it. */
 | |
|     rxCLUSTERVALIDITYREQFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \ref RxClusterValid
 | |
|  * Flags specifying the state requirements for
 | |
|  * a \ref RxCluster on exit from a node */
 | |
| enum RxClusterValid
 | |
| {
 | |
|     rxCLVALID_NOCHANGE = 0, /**<The cluster and its data will not change in
 | |
|                              * validity on passing through this node */
 | |
|     rxCLVALID_VALID = 1,    /**<The cluster and its data will be valid on
 | |
|                              * exit from this node */
 | |
|     rxCLVALID_INVALID = 2,  /**<The cluster's data will be invalid on
 | |
|                              * exit from this node */
 | |
|     rxCLUSTERVALIDFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| typedef struct RxClusterDefinition RxClusterDefinition;
 | |
| 
 | |
| typedef struct rxReq rxReq;
 | |
| 
 | |
| typedef enum RxClusterValidityReq RxClusterValidityReq;
 | |
| typedef enum RxClusterValid RxClusterValid;
 | |
| typedef struct RxOutputSpec RxOutputSpec;
 | |
| typedef struct RxClusterRef RxClusterRef;
 | |
| typedef struct RxIoSpec RxIoSpec;
 | |
| 
 | |
| typedef struct RxNodeMethods RxNodeMethods;
 | |
| typedef struct RxNodeDefinition RxNodeDefinition;
 | |
| 
 | |
| typedef struct RxCluster RxCluster;
 | |
| typedef struct RxPipelineCluster RxPipelineCluster;
 | |
| typedef struct RxPacket RxPacket;
 | |
| typedef struct RxPipelineNode RxPipelineNode;
 | |
| typedef struct RxPipelineNodeTopSortData RxPipelineNodeTopSortData;
 | |
| typedef struct RxPipelineNode RxPipelineNodeInstance;
 | |
| typedef struct RxPipelineNodeParam RxPipelineNodeParam;
 | |
| typedef struct RxExecutionContext RxExecutionContext;
 | |
| typedef struct RxPipelineRequiresCluster RxPipelineRequiresCluster;
 | |
| typedef struct RxPipeline RxPipeline;
 | |
| 
 | |
| /***************************************************************************
 | |
|  *
 | |
|  * C L U S T E R   D E F I N I T I O N
 | |
|  *
 | |
|  ***************************************************************************/
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxClusterDefinition
 | |
|  * Structure describing a cluster */
 | |
| struct RxClusterDefinition
 | |
| {
 | |
|     RwChar             *name;                  /**< Name */
 | |
|     RwUInt32            defaultStride;         /**< Default stride */
 | |
|     RwUInt32            defaultAttributes;     /**< Default attributes */
 | |
|     const RwChar         *attributeSet;           /**< Attribute set */
 | |
| };
 | |
| 
 | |
| 
 | |
| /***************************************************************************
 | |
|  *
 | |
|  * N O D E   D E F I N I T I O N   S T R U C T S
 | |
|  *
 | |
|  ***************************************************************************/
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxOutputSpec
 | |
|  * Structure describing an output specification of a node */
 | |
| struct RxOutputSpec
 | |
| {
 | |
|      RwChar             *name;                  /**< Name */
 | |
|      RxClusterValid     *outputClusters;        /**< States of clusters of interest on output */
 | |
|      RxClusterValid      allOtherClusters;      /**< States of clusters not of interest on output */
 | |
| };
 | |
| 
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \ref RxClusterForcePresent
 | |
|  *  Flags specifying whether an \ref RxCluster
 | |
|  * should be forced to be present in an \ref RxPipelineNode */
 | |
| enum RxClusterForcePresent
 | |
| {
 | |
|     rxCLALLOWABSENT = FALSE, /**<The cluster is allowed to be absent if no prior
 | |
|                               *  nodes create it and no subsequent nodes require it */
 | |
|     rxCLFORCEPRESENT = TRUE, /**<The cluster must be present even if no prior
 | |
|                               *  nodes create it and no subsequent nodes require it */
 | |
| 
 | |
|     rxCLUSTERFORCEPRESENTFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RxClusterForcePresent RxClusterForcePresent;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxClusterRef
 | |
|  * Structure describing a cluster reference */
 | |
| struct RxClusterRef
 | |
| {
 | |
|     RxClusterDefinition  *clusterDef;           /**< Cluster definition */
 | |
|     RxClusterForcePresent forcePresent;         /**< Specifies whether the cluster should be forced present */
 | |
|     RwUInt32              reserved;             /**< Omit or initialize to zero */
 | |
| };
 | |
| 
 | |
| #define rxCLRESERVED       ((RwUInt32)0)
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxIoSpec
 | |
|  * Structure describing an input/output specification of a node */
 | |
| struct RxIoSpec
 | |
| {
 | |
|     RwUInt32              numClustersOfInterest;/**< Number of Clusters of interest */
 | |
|     RxClusterRef         *clustersOfInterest;   /**< Clusters of interest array */
 | |
|     RxClusterValidityReq *inputRequirements;    /**< Requirements of the clusters of interest on input to the node */
 | |
|     RwUInt32              numOutputs;           /**< Number of outputs from the node */
 | |
|     RxOutputSpec         *outputs;              /**< Output specification array */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxNodeBodyFn
 | |
|  * is the callback to be
 | |
|  * called during pipeline execution -- and, typically, process
 | |
|  * \ref RxPacket's -- for the owning pipeline node.
 | |
|  *
 | |
|  * \param  self   A pointer to the pipeline node being executed
 | |
|  * \param  params   A pointer to a parameter structure
 | |
|  *
 | |
|  * \return TRUE on success, FALSE otherwise.
 | |
|  *
 | |
|  * \see RxNodeMethods
 | |
|  */
 | |
| typedef RwBool (*RxNodeBodyFn) (RxPipelineNode * self,
 | |
|                                 const RxPipelineNodeParam *params);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxNodeInitFn
 | |
|  * is the callback to be called,
 | |
|  * for the owning node definition, the first time an \ref RxPipeline
 | |
|  * referencing that node definition is unlocked.
 | |
|  *
 | |
|  * \param  self   A pointer to the node definition
 | |
|  *
 | |
|  * \return TRUE on success, FALSE otherwise.
 | |
|  *
 | |
|  * \see RxNodeMethods
 | |
|  */
 | |
| typedef RwBool (*RxNodeInitFn) (RxNodeDefinition * self);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxNodeTermFn
 | |
|  * is the callback to be called,
 | |
|  * for the owning node definition, the last time an \ref RxPipeline
 | |
|  * referencing that node definition is destroyed or locked.
 | |
|  *
 | |
|  * \param  self   A pointer to the node definition
 | |
|  *
 | |
|  * \return None
 | |
|  *
 | |
|  * \see RxNodeMethods
 | |
|  */
 | |
| typedef void   (*RxNodeTermFn) (RxNodeDefinition * self);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxPipelineNodeInitFn
 | |
|  * is the callback to be called, for the owning pipeline node, whenever a
 | |
|  * \ref RxPipeline containing that that pipeline node is unlocked.
 | |
|  *
 | |
|  * \param  self   A pointer to the pipeline node
 | |
|  *
 | |
|  * \return TRUE on success, FALSE otherwise.
 | |
|  *
 | |
|  * \see RxNodeMethods
 | |
|  */
 | |
| typedef RwBool (*RxPipelineNodeInitFn) (RxPipelineNode * self);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxPipelineNodeTermFn
 | |
|  * is the callback to be called, for the owning pipeline node, whenever a
 | |
|  * \ref RxPipeline containing that that pipeline node is locked or
 | |
|  * destroyed.
 | |
|  *
 | |
|  * \param  self   A pointer to the pipeline node
 | |
|  *
 | |
|  * \return None
 | |
|  *
 | |
|  * \see RxNodeMethods
 | |
|  */
 | |
| typedef void   (*RxPipelineNodeTermFn) (RxPipelineNode * self);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxPipelineNodeConfigFn
 | |
|  * is the callback to be called, for the owning pipeline node, whenever a
 | |
|  * \ref RxPipeline containing that that pipeline node is unlocked,
 | |
|  * *after* all \ref RxPipelineNodeInitFn's have been called for the
 | |
|  * pipeline in question. This func is to be used as described in
 | |
|  * RxPipelineNodeSendConfigMsg.
 | |
|  *
 | |
|  * \param  self   A pointer to the pipeline node
 | |
|  * \param  pipeline   A pointer to the containing pipeline
 | |
|  *
 | |
|  * \return TRUE on success, FALSE otherwise.
 | |
|  *
 | |
|  * \see RxNodeMethods
 | |
|  */
 | |
| typedef RwBool (*RxPipelineNodeConfigFn) (RxPipelineNode * self,
 | |
|                                           RxPipeline * pipeline);
 | |
| 
 | |
| /* - removed from the API Reference  January 2002 -
 | |
|    typedef RxConfigMsgHandlerFn
 | |
|    is the callback to be called, for the owning pipeline node, whenever
 | |
|    a message is sent to it by the ref RxPipelineNodeConfigFn of another
 | |
|    pipeline node in the same pipeline. See ref RxPipelineNodeSendConfigMsg.
 | |
|   
 | |
|    param  self   A pointer to the pipeline node
 | |
|    param  msg   Message ID
 | |
|    param  intparam   Meaning is message-specific
 | |
|    param  ptrparam   Meaning is message-specific
 | |
|   
 | |
|    return A RwInt32 value, 0: unserviced; -ve: error; +ve: informative success
 | |
|   
 | |
|    see RxNodeMethods
 | |
|   */
 | |
| typedef RwUInt32 (*RxConfigMsgHandlerFn) (RxPipelineNode * self,
 | |
|                                           RwUInt32 msg,
 | |
|                                           RwUInt32 intparam,
 | |
|                                           void *ptrparam);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxNodeMethods
 | |
|  * A structure describing a set
 | |
|  * of node methods
 | |
|  *
 | |
|  * \see RxNodeBodyFn
 | |
|  * \see RxNodeInitFn
 | |
|  * \see RxNodeTermFn
 | |
|  * \see RxPipelineNodeInitFn
 | |
|  * \see RxPipelineNodeTermFn
 | |
|  * \see RxPipelineNodeConfigFn
 | |
|  * \see RxConfigMsgHandlerFn
 | |
|  */
 | |
| struct RxNodeMethods
 | |
| {
 | |
|     RxNodeBodyFn         nodeBody;              /**< Node body function */
 | |
|     RxNodeInitFn         nodeInit;              /**< Node initialization function */
 | |
|     RxNodeTermFn         nodeTerm;              /**< Node termination function */
 | |
|     RxPipelineNodeInitFn pipelineNodeInit;      /**< Pipeline node initialization function */
 | |
|     RxPipelineNodeTermFn pipelineNodeTerm;      /**< Pipeline node termination function */
 | |
|     RxPipelineNodeConfigFn pipelineNodeConfig;  /**< Pipleline node configuation function */
 | |
|     RxConfigMsgHandlerFn configMsgHandler;      /**< Configuaraton message handler function */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \ref RxNodeDefEditable
 | |
|  * Flags specifying whether an \ref RxNodeDefinition
 | |
|  * is editable or not (\ref RxPipelineNodeCloneDefinition,
 | |
|  * \ref RxPipelineNodeReplaceCluster and \ref RxPipelineNodeRequestCluster
 | |
|  * create editable copies of node definitions as the originals may be
 | |
|  * static definitions). */
 | |
| enum RxNodeDefEditable
 | |
| {
 | |
|     /**<This node definition should not be freed */
 | |
|     rxNODEDEFCONST = FALSE,
 | |
|     /**< This node definition is a temporary,
 | |
|      * modified copy of another and can be freed */
 | |
|     rxNODEDEFEDITABLE = TRUE,
 | |
|     rxNODEDEFEDITABLEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RxNodeDefEditable RxNodeDefEditable;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxNodeDefinition
 | |
|  * A structure describing a node definition */
 | |
| struct RxNodeDefinition
 | |
| {
 | |
|     RwChar             *name;                   /**< Name */
 | |
|     RxNodeMethods       nodeMethods;            /**< Node methods */
 | |
|     RxIoSpec            io;                     /**< Input/output specification */
 | |
|     RwUInt32            pipelineNodePrivateDataSize; /**< Size in bytes of node's private data  */
 | |
|     RxNodeDefEditable   editable;               /**< Flags whether a node is editable */
 | |
|     RwInt32             InputPipesCnt;          /**< Count of the unlocked pipelines containing this node */
 | |
| };
 | |
| 
 | |
| /***************************************************************************
 | |
|  *
 | |
|  * P I P E L I N E - E X E C U T I O N - T I M E   S T R U C T S
 | |
|  *
 | |
|  ***************************************************************************/
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPipelineCluster
 | |
|  * A structure describing a pipeline cluster;
 | |
|  * that is, an \ref RxClusterDefinition in the context of a specific \ref RxPipeline
 | |
|  * (in the same way as an \ref RxPipelineNode is an \ref RxNodeDefinition in the
 | |
|  * context of a specific \ref RxPipeline). The \ref RxCluster is the structure
 | |
|  * representing this and the \ref RxClusterDefinition within \ref RxPacket's at
 | |
|  * pipeline-execution-time */
 | |
| struct RxPipelineCluster
 | |
| {
 | |
|     RxClusterDefinition *clusterRef;            /**< Cluster refererence */
 | |
|     RwUInt32             creationAttributes;    /**< Creation Attributes */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxCluster
 | |
|  * A structure describing a cluster; this is
 | |
|  * the representative of an \ref RxClusterDefinition and \ref RxPipelineCluster
 | |
|  * within \ref RxPacket's at pipeline-execution-time. */
 | |
| struct RxCluster
 | |
| {
 | |
|     RwUInt16            flags;                  /**< Bitfield of flags e.g. modification permissions */
 | |
|     RwUInt16            stride;                 /**< Stride in bytes of the cluster's data */
 | |
|     void               *data;                   /**< The Cluster's data */
 | |
|     void               *currentData;            /**< A 'cursor', referencing the current element in the data */
 | |
|     RwUInt32            numAlloced;             /**< Allocated count */
 | |
|     RwUInt32            numUsed;                /**< Used count */
 | |
|     RxPipelineCluster  *clusterRef;             /**< Valid after a cluster has been locked for writing,
 | |
|                                                  *   otherwise NULL. Analog of \ref RxPipelineNode and
 | |
|                                                  *   its 'nodeDef' member. */
 | |
|     RwUInt32            attributes;             /**< Attributes */
 | |
| #ifdef PADCLUSTERS
 | |
|     RwUInt32 pad[1];                            /**< Alignment padding */
 | |
| #endif
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPacket
 | |
|  * A structure describing a packet header */
 | |
| struct RxPacket
 | |
| {
 | |
|     RwUInt16            flags;                  /**< Flags to guide pipeline execution */
 | |
|     RwUInt16            numClusters;            /**< Maximum number of clusters simultanesouly present in the current pipeline */
 | |
|     RxPipeline         *pipeline;               /**< The pipeline in which this packet is embedded (the current pipeline) */
 | |
|     RwUInt32           *inputToClusterSlot;     /**< LUT to locate clusters of interest in the packet */
 | |
|     RwUInt32           *slotsContinue;          /**< Bitfields specifying clusters persisting to output node */
 | |
|     RxPipelineCluster **slotClusterRefs;        /**< Internal Use */
 | |
| #ifdef PADCLUSTERS
 | |
|     RwUInt32 pad[3];                            /**< Alignment padding */
 | |
| #endif
 | |
|     RxCluster           clusters[1];            /**< Cluster array large enough for widest part of the pipeline */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPipelineNode
 | |
|  * Structure describing a pipeline Node;
 | |
|  * that is an \ref RxNodeDefinition in the context 
 | |
|  * of a specific \ref RxPipeline. 
 | |
|  */
 | |
| struct RxPipelineNode
 | |
| {
 | |
|     RxNodeDefinition   *nodeDef;            /**< Node definition reference */
 | |
|     RwUInt32            numOutputs;         /**< Output count */
 | |
|     RwUInt32           *outputs;            /**< Output array, indexing the pipeline's array of pipeline nodes */
 | |
|     RxPipelineCluster **slotClusterRefs;    /**< For packets passing through this node, SlotClusterRefs[n]
 | |
|                                              * identifies the cluster to be found at index n in the packet's
 | |
|                                              * Clusters[] array. These assignments are determined at pipeline
 | |
|                                              * Unlock() time and are good for the life of the pipeline. */
 | |
|     RwUInt32           *slotsContinue;      /**< Cluster persistence table for the node's outputs */
 | |
|     void               *privateData;        /**< Pointer to the pipeline Node's private data */
 | |
|     RwUInt32           *inputToClusterSlot; /**< LUT to locate clusters of interest in packets passing through this pipeline Node */
 | |
|     RxPipelineNodeTopSortData *topSortData; /**< Internal Use */
 | |
|     void               *initializationData; /**< Used by the pipeline node initialisation
 | |
|                                              * function in setting up the Private data. */
 | |
|     RwUInt32        initializationDataSize; /**< Present so that if the node is cloned
 | |
|                                              * we can copy the initialisation data. */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPipelineNodeTopSortData
 | |
|  * Structure describing data used during topological sorting 
 | |
|  * during \ref RxLockedPipeUnlock ; 
 | |
|  * RenderWare users do not need to understand this */
 | |
| struct RxPipelineNodeTopSortData
 | |
| {
 | |
|     RwUInt32            numIns;                 /**< Input count */
 | |
|     RwUInt32            numInsVisited;          /**< Count of inputs visited during dependencies
 | |
|                                                  * propagation/cluster slot allocation */
 | |
|     rxReq              *req;                    /**< Req used in dependencies propagation/cluster
 | |
|                                                  * slot allocation */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPipelineNodeParam
 | |
|  * Structure holding parameters
 | |
|  * to pass to node body functions */
 | |
| struct RxPipelineNodeParam
 | |
| {
 | |
|     void   *dataParam;   /**< The data pointer passed in to \ref RxPipelineExecute */
 | |
|     RxHeap *heap;        /**< The heap associated with the current pipeline exeuction */
 | |
| };
 | |
| 
 | |
| enum rxEmbeddedPacketState
 | |
| {
 | |
|     rxPKST_PACKETLESS = 0, /* Packet not created */
 | |
|     rxPKST_UNUSED     = 1, /* Packet created and then destroyed */
 | |
|     rxPKST_INUSE      = 2, /* Packet created but not yet destroyed and fetched but not yet dispatched */
 | |
|     rxPKST_PENDING    = 3, /* Packet created but not destroyed and dispatched but not yet fetched */
 | |
|     rxEMBEDDEDPACKETSTATEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum rxEmbeddedPacketState rxEmbeddedPacketState;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxExecutionContext
 | |
|  * Structure describing an execution context */
 | |
| struct RxExecutionContext
 | |
| {
 | |
|     RxPipeline           *pipeline;     /**< Currently executing pipeline */
 | |
|     RxPipelineNode       *currentNode;  /**< Currently executing node */
 | |
|     RwInt32               exitCode;     /**< Used internally for nodes returning error codes on exit */
 | |
|     RwUInt32              pad;          /**< Alignment padding */
 | |
|     RxPipelineNodeParam   params;       /**< The parameters passed to node bodies */
 | |
|     /*RwUInt32              pad[2];*/
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPipelineRequiresCluster
 | |
|  * Structure describing a pipeline requirement of a cluster */
 | |
| struct RxPipelineRequiresCluster
 | |
| {
 | |
|     RxClusterDefinition *clusterDef;    /**< Reference to a Cluster definition */
 | |
|     RxClusterValidityReq rqdOrOpt;      /**< Cluster validity requirement (rxCLREQ_DONTWANT, rxCLREQ_REQUIRED or rxCLREQ_OPTIONAL) */
 | |
|     RwUInt32             slotIndex;     /**< Index into the packet's cluster array within this pipeline */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPipeline
 | |
|  * Structure describing a pipeline */
 | |
| struct RxPipeline
 | |
| {
 | |
|     RwBool                     locked;                /**< Flags whether the pipeline is locked for editing */
 | |
|     RwUInt32                   numNodes;              /**< Node count */
 | |
|     RxPipelineNode            *nodes;                 /**< Topologically sorted array of pipeline nodes */
 | |
|     RwUInt32                   packetNumClusterSlots; /**< Number of slots allocated for clusters */
 | |
|     rxEmbeddedPacketState      embeddedPacketState;   /**< The state of this pipeline's embedded packet */
 | |
|     RxPacket                  *embeddedPacket;        /**< This pipeline's embedded packet */
 | |
| 
 | |
|     RwUInt32                   numInputRequirements;  /**< Input requirements count */
 | |
|     RxPipelineRequiresCluster *inputRequirements;     /**< Input requirements array */
 | |
| 
 | |
|     void                      *superBlock;            /**< Internally used block of memory */
 | |
|     RwUInt32                   superBlockSize;        /**< Internally used block of memory */
 | |
| 
 | |
|     RwUInt32                   entryPoint;            /**< The index of the node which is the entry point of this pipeline */
 | |
|     RwUInt32                   pluginId;              /**< If required, the Id of the plugin owning this pipeline, or 0 */
 | |
|     RwUInt32                   pluginData;            /**< Rights callback extra data */
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  * Global Prototypes
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxPipelineNodeOutputCallBack 
 | |
|  * is the callback function supplied 
 | |
|  * to \ref RxPipelineNodeForAllConnectedOutputs.
 | |
|  *
 | |
|  * The callback will be passed a pointer to the \ref RxPipelineNode whose
 | |
|  * outputs are being traversed and a pointer to the current output
 | |
|  * \ref RxPipelineNode, as well as a pointer to an optional user-defined
 | |
|  * data structure (callbackdata). If no such structure was specified, this
 | |
|  * will be NULL.
 | |
|  *
 | |
|  * \param  node   A pointer to the pipeline node whose outputs
 | |
|  * are being traversed
 | |
|  * \param  outputnode   A pointer to the current output
 | |
|  * pipeline node
 | |
|  * \param  callbackdata   A pointer to optional user-supplied data
 | |
|  *
 | |
|  * \return Returns a pointer to the \ref RxPipelineNode whose outputs are being
 | |
|  * traversed, or NULL to terminate traversal
 | |
|  */
 | |
| typedef RxPipelineNode * (*RxPipelineNodeOutputCallBack) (RxPipelineNode * node,
 | |
|                                                   RxPipelineNode * outputnode,
 | |
|                                                   void *callbackdata);
 | |
| 
 | |
| #ifdef RWDEBUG
 | |
| #define RXCHECKFORUSERTRAMPLING(_pipeline)                       \
 | |
|     ( _rwPipelineCheckForTramplingOfNodePrivateSpace(_pipeline) )
 | |
| #endif /* RWDEBUG */
 | |
| 
 | |
| #if (!defined(RXCHECKFORUSERTRAMPLING))
 | |
| #define RXCHECKFORUSERTRAMPLING(_pipeline) /* No op */
 | |
| #endif /* (!defined(RXCHECKFORUSERTRAMPLING)) */
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RwBool
 | |
| _rxPipelineOpen(void);
 | |
| 
 | |
| extern RwBool
 | |
| _rxPipelineClose(void);
 | |
| 
 | |
| extern RwBool
 | |
| rxPipelinePluginsAttach(void);
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxPipelineCreate(void);
 | |
| 
 | |
| 
 | |
| extern void
 | |
| _rxPipelineDestroy(RxPipeline * Pipeline);
 | |
| 
 | |
| #define _RxPipelineDestroy(_ppln)  _rxPipelineDestroy(_ppln)
 | |
| #define RxPipelineDestroy(_ppln) (_rxPipelineDestroy(_ppln), TRUE)
 | |
| 
 | |
| extern RxHeap      *
 | |
| RxHeapGetGlobalHeap(void);
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxPipelineExecute(RxPipeline  * pipeline,
 | |
|                   void        * data,
 | |
|                   RwBool       heapReset);
 | |
| 
 | |
| extern RxPacket *
 | |
| RxPacketCreate(RxPipelineNode * node);
 | |
| 
 | |
| extern RxCluster   *
 | |
| RxClusterSetStride(RxCluster * cluster,
 | |
|                    RwInt32 stride);
 | |
| 
 | |
| extern RxCluster   *
 | |
| RxClusterSetExternalData(RxCluster * cluster,
 | |
|                          void *data,
 | |
|                          RwInt32 stride,
 | |
|                          RwInt32 numElements);
 | |
| 
 | |
| extern RxCluster   *
 | |
| RxClusterSetData(RxCluster * cluster,
 | |
|                  void *data,
 | |
|                  RwInt32 stride,
 | |
|                  RwInt32 numElements);
 | |
| 
 | |
| /* underlying PacketDestroy function */
 | |
| extern void
 | |
| _rxPacketDestroy(RxPacket * Packet);
 | |
| 
 | |
| /* more convenient parameterization */
 | |
| #define RxPacketDestroy(pk, self) \
 | |
|     ( _rxPacketDestroy(pk) )
 | |
| 
 | |
| #if (defined(RWDEBUG))
 | |
| extern RxPacket *RxPacketFetch(RxPipelineNode * Node);
 | |
| extern void      RxPacketDispatch(RxPacket * packet,
 | |
|                                   RwUInt32 output,
 | |
|                                   RxPipelineNode * self);
 | |
| extern void      RxPacketDispatchToPipeline(RxPacket * packet,
 | |
|                                             RxPipeline * dest,
 | |
|                                             RxPipelineNode * self);
 | |
| #else /* (defined(RWDEBUG)) */
 | |
| #define RxPacketFetch(_self) \
 | |
|     rxPacketFetchMacro(_self)
 | |
| #define RxPacketDispatch(     _packet, _output, _self) \
 | |
|     rxPacketDispatchMacro(_packet, _output, _self)
 | |
| #define RxPacketDispatchToPipeline(     _packet, _pipeline, _self) \
 | |
|     rxPacketDispatchToPipelineMacro(_packet, _pipeline, _self)
 | |
| #endif /* (defined(RWDEBUG)) */
 | |
| 
 | |
| #define RxClusterInitialiseData(_clstr, _nmlmnts, _strd) \
 | |
|     ( RxClusterInitializeData((_clstr), (_nmlmnts), (_strd)) )
 | |
| extern RxCluster   *
 | |
| RxClusterInitializeData(RxCluster *cluster, RwUInt32 numElements, RwUInt16 stride);
 | |
| 
 | |
| extern RxCluster   *
 | |
| RxClusterResizeData(RxCluster *CurrentCluster, RwUInt32 NumElements);
 | |
| 
 | |
| extern RxCluster   *
 | |
| RxClusterDestroyData(RxCluster *CurrentCluster);
 | |
| 
 | |
| #if (defined(RWDEBUG))
 | |
| 
 | |
| extern RxCluster *RxClusterLockRead(RxPacket * packet, RwUInt32 clusterIndex);
 | |
| 
 | |
| #else  /* !RWDEBUG */
 | |
| 
 | |
| #define RXCLSLOT(PKT, CLIND)             \
 | |
|     ((PKT)->inputToClusterSlot[(CLIND)])
 | |
| 
 | |
| #define RxClusterLockRead(PKT, CLIND)                               \
 | |
|     ( (((RwInt32)RXCLSLOT(PKT, CLIND)) == -1) ?                     \
 | |
|       ((RxCluster *)NULL) :                                         \
 | |
|       (RxClusterResetCursor(&PKT->clusters[RXCLSLOT(PKT, CLIND)]),  \
 | |
|        &PKT->clusters[RXCLSLOT(PKT, CLIND)]) )
 | |
| 
 | |
| #endif /* !RWDEBUG */
 | |
| 
 | |
| extern RxCluster   *
 | |
| RxClusterLockWrite(RxPacket * packet,
 | |
|                    RwUInt32 clusterIndex,
 | |
|                    RxPipelineNode * node);
 | |
| 
 | |
| extern void
 | |
| RxClusterUnlock(RxCluster * cluster);
 | |
| 
 | |
| extern RwUInt32
 | |
| RxPipelineNodeSendConfigMsg(RxPipelineNode * dest,
 | |
|                             RwUInt32 msg,
 | |
|                             RwUInt32 intparam,
 | |
|                             void *ptrparam);
 | |
| 
 | |
| extern RxPipelineNode *
 | |
| RxPipelineNodeForAllConnectedOutputs(RxPipelineNode * node,
 | |
|                                      RxPipeline * pipeline,
 | |
|                                      RxPipelineNodeOutputCallBack callbackfn,
 | |
|                                      void *callbackdata);
 | |
| 
 | |
| /* Cluster attributes api [pipeline construction time] */
 | |
| 
 | |
| extern RxPipelineCluster *
 | |
| RxPipelineNodeGetPipelineCluster(RxPipelineNode *node,
 | |
|                                    RwUInt32 clustersOfInterestIndex);
 | |
| 
 | |
| extern RwUInt32
 | |
| RxPipelineClusterGetCreationAttributes(RxPipelineCluster *cluster);
 | |
| 
 | |
| extern RxPipelineCluster *
 | |
| RxPipelineClusterSetCreationAttributes(RxPipelineCluster *cluster,
 | |
|                                          RwUInt32 creationAttributes);
 | |
| 
 | |
| /* Cluster attributes api [pipeline execution time] */
 | |
| 
 | |
| extern RwUInt32
 | |
| RxClusterGetAttributes(RxCluster *cluster);
 | |
| 
 | |
| extern RxCluster *
 | |
| RxClusterSetAttributes(RxCluster *cluster, RwUInt32 attributes);
 | |
| 
 | |
| 
 | |
| extern void
 | |
| _rxEmbeddedPacketBetweenPipelines(RxPipeline * fromPipeline,
 | |
|                                  RxPipeline * toPipeline);
 | |
| 
 | |
| extern RxPipelineNode *
 | |
| _rxEmbeddedPacketBetweenNodes(RxPipeline     *pipeline,
 | |
|                              RxPipelineNode *nodeFrom,
 | |
|                              RwUInt32        whichOutput);
 | |
| 
 | |
| extern RxExecutionContext _rxExecCtxGlobal;
 | |
| 
 | |
| /* Summary of dispatch rules:
 | |
|  * o nodes that never fetch are safe to dispatch NULL, whether
 | |
|  *   nodes above pass them a packet or not
 | |
|  * o if you destroy the packet you can dispatch(NULL,,)
 | |
|  * o if you fetch/create and dispatch(NULL), it doesn't really
 | |
|  *   matter - the packet'll get passed on anyway */
 | |
| 
 | |
| /* TODO: there's currently no way to prematurely terminate the pipeline
 | |
|  *      without doing so as an error condition. You should create an
 | |
|  *      enum for the exit code, either RXNODEEXITCONTINUE, RXNODEEXITTERMINATE
 | |
|  *      or RXNODEEXTTERMINATEERROR and then test for RXNODEEXITCONTINUE in
 | |
|  *      the below macros rather than FALSE. */
 | |
| 
 | |
| /* TODO: _packet redundant here... create a new macro and legacy wrapper */
 | |
| #define rxPacketDispatchMacro(_packet, _output, _self)                      \
 | |
| MACRO_START                                                                 \
 | |
| {                                                                           \
 | |
|     RxPipeline *curPipeline = _rxExecCtxGlobal.pipeline;                    \
 | |
|                                                                             \
 | |
|     /* _packet is now an obsolete parameter */                              \
 | |
|                                                                             \
 | |
|     if ( FALSE != _rxExecCtxGlobal.exitCode )                               \
 | |
|     {                                                                       \
 | |
|         RxPipelineNode *nextNode =                                          \
 | |
|             _rxEmbeddedPacketBetweenNodes(curPipeline,                      \
 | |
|                                          _self,                             \
 | |
|                                          (_output));                        \
 | |
|         if ( nextNode != NULL )                                             \
 | |
|         {                                                                   \
 | |
|             RwUInt32 exitCode =                                             \
 | |
|                 nextNode->nodeDef->nodeMethods.nodeBody(                    \
 | |
|                     nextNode, &(_rxExecCtxGlobal.params));                  \
 | |
|             /* Don't overwrite 'error' with 'success' */                    \
 | |
|             if (FALSE == exitCode) _rxExecCtxGlobal.exitCode = exitCode;    \
 | |
|         }                                                                   \
 | |
|     }                                                                       \
 | |
|     if ( curPipeline->embeddedPacketState > rxPKST_UNUSED                   \
 | |
|          /* !UNUSED and !PACKETLESS */ )                                    \
 | |
|     {                                                                       \
 | |
|         curPipeline->embeddedPacketState = rxPKST_INUSE;                    \
 | |
|         _rxPacketDestroy(curPipeline->embeddedPacket);                      \
 | |
|     }                                                                       \
 | |
| }                                                                           \
 | |
| MACRO_STOP
 | |
| 
 | |
| /* TODO: _self redundant here... create a new macro and legacy wrapper */
 | |
| #define rxPacketDispatchToPipelineMacro(_packet, _pipeline, _self)          \
 | |
| MACRO_START                                                                 \
 | |
| {                                                                           \
 | |
|     RxPipeline *toPipeline = (_pipeline);                                   \
 | |
|                                                                             \
 | |
|     /* _packet is now an obsolete parameter */                              \
 | |
|                                                                             \
 | |
|     if ( FALSE != _rxExecCtxGlobal.exitCode )                               \
 | |
|     {                                                                       \
 | |
|         RwUInt32 exitCode;                                                  \
 | |
|         RxPipeline *fromPipeline = _rxExecCtxGlobal.pipeline; /* save */    \
 | |
|         _rxEmbeddedPacketBetweenPipelines(fromPipeline,                     \
 | |
|                                          toPipeline);                       \
 | |
|         _rxExecCtxGlobal.pipeline = toPipeline; /* modify */                \
 | |
|         exitCode =                                                          \
 | |
|             toPipeline->nodes[0].nodeDef->nodeMethods.nodeBody(             \
 | |
|                 &toPipeline->nodes[0], &(_rxExecCtxGlobal.params));         \
 | |
|         if ( FALSE == exitCode ) _rxExecCtxGlobal.exitCode = exitCode;      \
 | |
|         _rxExecCtxGlobal.pipeline = fromPipeline; /* restore */             \
 | |
|     }                                                                       \
 | |
|     if ( toPipeline->embeddedPacketState > rxPKST_UNUSED                    \
 | |
|          /* !UNUSED and !PACKETLESS */ )                                    \
 | |
|     {                                                                       \
 | |
|         toPipeline->embeddedPacketState = rxPKST_INUSE;                     \
 | |
|         _rxPacketDestroy(toPipeline->embeddedPacket);                       \
 | |
|     }                                                                       \
 | |
| }                                                                           \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define rxPacketFetchMacro(_node)                                           \
 | |
|     ( ((_rxExecCtxGlobal.pipeline)->embeddedPacketState == rxPKST_PENDING) ?\
 | |
|       ((_rxExecCtxGlobal.pipeline)->embeddedPacketState = rxPKST_INUSE,     \
 | |
|        (_rxExecCtxGlobal.pipeline)->embeddedPacket) :                       \
 | |
|       (NULL) )
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/d3d8/nodeD3D8SubmitNoLight.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2define.h ---*/
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxNodeOutput 
 | |
|  * typedef for a reference to an output of a pipeline node */
 | |
| typedef RwUInt32       *RxNodeOutput;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxNodeInput 
 | |
|  *  typedef for a reference to the input of a pipeline node */
 | |
| typedef RxPipelineNode *RxNodeInput;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxLockedPipe
 | |
|  * typedef for a reference to a locked pipeline 
 | |
|  */
 | |
| typedef RxPipeline      RxLockedPipe;
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /* PIPELINENODE API */
 | |
| 
 | |
| extern RxNodeOutput
 | |
| RxPipelineNodeFindOutputByName(RxPipelineNode *node,
 | |
|                                const RwChar *outputname);
 | |
| 
 | |
| extern RxNodeOutput
 | |
| RxPipelineNodeFindOutputByIndex(RxPipelineNode *node,
 | |
|                                 RwUInt32 outputindex);
 | |
| 
 | |
| extern RxNodeInput
 | |
| RxPipelineNodeFindInput(RxPipelineNode *node);
 | |
| 
 | |
| extern RxNodeDefinition *
 | |
| RxPipelineNodeCloneDefinition(RxPipelineNode *node,
 | |
|                               RxClusterDefinition *cluster2add);
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxPipelineNodeRequestCluster(RxPipeline *pipeline,
 | |
|                              RxPipelineNode *node,
 | |
|                              RxClusterDefinition *clusterDef);
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxPipelineNodeReplaceCluster(RxPipeline *pipeline,
 | |
|                              RxPipelineNode *node,
 | |
|                              RxClusterDefinition *oldClusterDef,
 | |
|                              RxClusterDefinition *newClusterDef);
 | |
| 
 | |
| extern void *
 | |
| RxPipelineNodeGetInitData(RxPipelineNode *node);
 | |
| 
 | |
| extern void *
 | |
| RxPipelineNodeCreateInitData(RxPipelineNode *node,
 | |
|                              RwUInt32 size);
 | |
| 
 | |
| /* PIPELINE MANIPULATION API */
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxPipelineClone(RxPipeline *pipeline);
 | |
| 
 | |
| extern RxPipelineNode *
 | |
| RxPipelineFindNodeByName(RxPipeline *pipeline,
 | |
|                          const RwChar *name,
 | |
|                          RxPipelineNode *start,
 | |
|                          RwInt32 *nodeIndex);
 | |
| 
 | |
| extern RxPipelineNode *
 | |
| RxPipelineFindNodeByIndex(RxPipeline *pipeline,
 | |
|                           RwUInt32 nodeindex);
 | |
| 
 | |
| extern RxLockedPipe *
 | |
| RxPipelineLock(RxPipeline *pipeline);
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxLockedPipeUnlock(RxLockedPipe *pipeline);
 | |
| 
 | |
| 
 | |
| extern RxLockedPipe *
 | |
| RxLockedPipeAddFragment(RxLockedPipe *pipeline,
 | |
|                         RwUInt32 *firstIndex,
 | |
|                         RxNodeDefinition *nodeDef0,
 | |
|                         ...);
 | |
| 
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxLockedPipeReplaceNode(RxLockedPipe *pipeline,
 | |
|                         RxPipelineNode *node,
 | |
|                         RxNodeDefinition *nodeDef);
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxLockedPipeDeleteNode(RxLockedPipe *pipeline,
 | |
|                        RxPipelineNode *node);
 | |
| 
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxLockedPipeSetEntryPoint(RxLockedPipe *pipeline,
 | |
|                           RxNodeInput in);
 | |
| 
 | |
| 
 | |
| extern RxPipelineNode *
 | |
| RxLockedPipeGetEntryPoint(RxLockedPipe *pipeline);
 | |
| 
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxLockedPipeAddPath(RxLockedPipe *pipeline,
 | |
|                     RxNodeOutput out,
 | |
|                     RxNodeInput in);
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxLockedPipeDeletePath(RxLockedPipe *pipeline,
 | |
|                        RxNodeOutput out,
 | |
|                        RxNodeInput in);
 | |
| 
 | |
| 
 | |
| extern RxPipeline *
 | |
| RxPipelineInsertDebugNode(RxPipeline *pipeline,
 | |
|                           RxPipelineNode *before,
 | |
|                           RxPipelineNode *after,
 | |
|                           RxNodeDefinition *debugNode);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2altmdl.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeTransform.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetTransform(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeSubmitTriangle.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetSubmitTriangle(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeSubmitLine.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetSubmitLine(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeScatter.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetScatter(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeClone.h ---*/
 | |
| 
 | |
| typedef struct RxPacketCacheCluster RxPacketCacheCluster;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPacketCacheCluster
 | |
|  * structure containing a cache of an \ref RxCluster's
 | |
|  * within an \ref RxPacketCache 
 | |
|  */
 | |
| struct RxPacketCacheCluster
 | |
| {
 | |
|     RwUInt32            slot;       /**< A \ref RwUInt32 index into the \ref RxPacketCache's
 | |
|                                      * array of RxPacketCacheCluster's */
 | |
|     RwUInt16            flags;      /**< A cache of the original cluster's flags */
 | |
|     RwUInt16            stride;     /**< A cache of the original cluster's stride */
 | |
|     void               *data;       /**< A cache of the original cluster's data */
 | |
|     RwUInt32            numAlloced; /**< A cache of the original cluster's numAlloced */
 | |
|     RwUInt32            numUsed;    /**< A cache of the original cluster's numUsed */
 | |
|     RxPipelineCluster  *clusterRef; /**< A cache of the original cluster's \ref RxPipelineCluster */
 | |
| };
 | |
| typedef struct RxPacketCache RxPacketCache;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxPacketCache
 | |
|  * structure containing a cache of a \ref RxPacket */
 | |
| struct RxPacketCache
 | |
| {
 | |
|     RwUInt16             packetFlags; /**< A cache of the original packet's flags */
 | |
|     RwUInt16             pad[1];      /**< Alignment padding */
 | |
|     RwUInt32             numClusters; /**< The number of present clusters in the
 | |
|                                        * original packet when it was cloned */
 | |
|     RwBool               lastCloneDone;/**< Once the cache has been cloned by \ref RxPacketCacheClone
 | |
|                                        * with (lastClone == TRUE), it should not be used again! */
 | |
|     RwUInt32             pad2[1];      /**< Alignment padding */
 | |
|     RxPacketCacheCluster clusters[1]; /**< An array of \ref RxPacketCacheCluster's,
 | |
|                                        * extending beyond 1 element */
 | |
| };
 | |
|     
 | |
| 
 | |
| typedef struct RxNodeCloneInitData RxNodeCloneInitData;
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxNodeCloneInitData
 | |
|  * structure with which to initialize 
 | |
|  * clone a \ref RxNodeDefinition, 
 | |
|  * through \ref RxNodeDefinitionCloneCreate and
 | |
|  * set up cloned \ref RxPipelineNode modes, through
 | |
|  * \ref RxPipelineNodeCloneDefineModes */
 | |
| struct RxNodeCloneInitData
 | |
| {
 | |
|     RwUInt32   numModes;   /**< Specifies the number of modes in
 | |
|                               which the node should operate */
 | |
|     RwUInt32   numOutputs; /**< Specifies the number of outputs of this
 | |
|                               Clone node, which is also the maximum
 | |
|                               number of outputs to which any one mode
 | |
|                               may dispatch packets */
 | |
|     RwUInt32  *modeSizes;  /**< Specifies the number of outputs to which
 | |
|                               each mode dispatches packets */
 | |
|     RwUInt32 **modes;      /**< An array of numModes pointers to arrays
 | |
|                               (of length numOutputs) specifying the
 | |
|                               outputs, in order, to which each mode
 | |
|                               should dispatch packets (output zero is
 | |
|                               the first output) */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxNodeCloneData
 | |
|  * structure which is the private
 | |
|  * data of Clone nodes \ref RxPipelineNode */
 | |
| typedef struct RxNodeCloneData RxNodeCloneData;
 | |
| struct RxNodeCloneData
 | |
| {
 | |
|     RwBool optimized;         /**< \ref RwBool specifying whether \ref RxPipelineNodeCloneOptimize
 | |
|                                * has been run on this \ref RxPipelineNode yet */
 | |
|     RwUInt32 currentMode;     /**< \ref RwUInt32 The current mode of operation */
 | |
|     RxNodeCloneInitData *data;/**< A pointer to \ref RxNodeCloneInitData data
 | |
|                                * specifying the modes of operation */
 | |
| };
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionCloneCreate(RxNodeCloneInitData *data);
 | |
| extern RwBool            RxPipelineNodeCloneDefineModes(
 | |
|                              RxPipeline          *pipeline,
 | |
|                              RxPipelineNode      *node,
 | |
|                              RxNodeCloneInitData   *data);
 | |
| extern RwBool            RxNodeDefinitionCloneDestroy(RxNodeDefinition *def);
 | |
| extern RwBool            RxPipelineNodeCloneOptimize(RxPipeline     *pipeline,
 | |
|                                                      RxPipelineNode *node);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeImmStash.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetImmStash(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeImmRenderSetup.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetImmRenderSetup(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeImmMangleTriangleIndices.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetImmMangleTriangleIndices(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeImmMangleLineIndices.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetImmMangleLineIndices(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeImmInstance.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetImmInstance(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeCullTriangle.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetCullTriangle(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeClipTriangle.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetClipTriangle(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeClipLine.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetClipLine(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/d3d8texdic.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/d3d8rendst.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/d3d8raster.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/d3d8device.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/d3d8convrt.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/d3d82drend.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/common/ssematml.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/common/cpuext.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/common/palquant.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/common/datblkcb.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/baraster.h ---*/
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwRasterLockMode represents the options available for locking 
 | |
|  * a raster so that it may be modified (see API function \ref RwRasterLock). An 
 | |
|  * application may wish to write to the raster, read from the raster or
 | |
|  * simultaneously write and read a raster (rwRASTERLOCKWRITE | rwRASTERLOCKREAD).
 | |
|  */
 | |
| enum RwRasterLockMode
 | |
| {
 | |
|     rwRASTERLOCKWRITE = 0x01,   /**<Lock for writing */
 | |
|     rwRASTERLOCKREAD = 0x02,    /**<Lock for reading */
 | |
|     rwRASTERLOCKNOFETCH = 0x04, /**<When used in combination with
 | |
|                                  *  rwRASTERLOCKWRITE, asks the driver not to
 | |
|                                  *  fetch the pixel data. This is only useful
 | |
|                                  *  if it is known that ALL the raster data is
 | |
|                                  *  going to be overwritten before the raster
 | |
|                                  *  is unlocked, i.e. from an 
 | |
|                                  *  \ref RwRasterSetFromImage call. This flag
 | |
|                                  *  is not supported by all drivers. */
 | |
|     rwRASTERLOCKRAW = 0x08,    /**<When used in combination with
 | |
|                                    rwRASTERLOCKWRITE or rwRASTERLOCKREAD
 | |
|                                    allows access to the raw platform specific
 | |
|                                    pixel format */
 | |
|     rwRASTERLOCKMODEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| 
 | |
| #define rwRASTERLOCKREADWRITE   (rwRASTERLOCKREAD|rwRASTERLOCKWRITE)
 | |
| 
 | |
| typedef enum RwRasterLockMode RwRasterLockMode;
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  *  \ref RwRasterFlipMode represents
 | |
|  *  raster flip modes */
 | |
| enum RwRasterFlipMode
 | |
| {
 | |
|     rwRASTERFLIPDONTWAIT = 0,   /**<Don't wait for VSync */
 | |
|     rwRASTERFLIPWAITVSYNC = 1,  /**<Flip on VSync */
 | |
|     rwRASTERFLIPMODEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwRasterFlipMode RwRasterFlipMode;
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  *  RwRasterType 
 | |
|  *  This type represents the options available for creating a new 
 | |
|  * raster (se API function \ref RwRasterCreate)*/
 | |
| enum RwRasterType
 | |
| {
 | |
|     rwRASTERTYPENORMAL = 0x00,          /**<Normal */
 | |
|     rwRASTERTYPEZBUFFER = 0x01,         /**<Z Buffer */
 | |
|     rwRASTERTYPECAMERA = 0x02,          /**<Camera */
 | |
|     rwRASTERTYPETEXTURE = 0x04,         /**<Texture */
 | |
|     rwRASTERTYPECAMERATEXTURE = 0x05,   /**<Camera texture */
 | |
|     rwRASTERTYPEMASK = 0x07,            /**<Mask for finding type */
 | |
| 
 | |
|     rwRASTERDONTALLOCATE = 0x80,        /**<If set the raster is not allocated */
 | |
|     rwRASTERTYPEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwRasterType RwRasterType;
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwRasterFormat is a set of values and flags which may be combined to
 | |
|  * specify a raster format. The format chosen for a particular raster depends
 | |
|  * on the hardware device and the raster type specified at creation time
 | |
|  * (see API function \ref RwRasterCreate). The format may be retrieved using
 | |
|  * API function \ref RwRasterGetFormat.
 | |
|  *
 | |
|  * The raster format is a packed set of bits which contains the following
 | |
|  * four pieces of information (these may be combined with bitwise OR):-
 | |
|  *
 | |
|  * <ol>
 | |
|  * <li> The pixel color format corresponding to one of the following values:-
 | |
|  *      <ul>
 | |
|  *      <li> rwRASTERFORMAT1555
 | |
|  *      <li> rwRASTERFORMAT565
 | |
|  *      <li> rwRASTERFORMAT4444
 | |
|  *      <li> rwRASTERFORMATLUM8
 | |
|  *      <li> rwRASTERFORMAT8888
 | |
|  *      <li> rwRASTERFORMAT888
 | |
|  *      <li> rwRASTERFORMAT16
 | |
|  *      <li> rwRASTERFORMAT24
 | |
|  *      <li> rwRASTERFORMAT32
 | |
|  *      <li> rwRASTERFORMAT555
 | |
|  *      </ul>
 | |
|  *      This value may be masked out of the raster format using
 | |
|  *      rwRASTERFORMATPIXELFORMATMASK.
 | |
|  * <li> The palette depth if the raster is palettized:-
 | |
|  *      <ul> 
 | |
|  *      <li> rwRASTERFORMATPAL4
 | |
|  *      <li> rwRASTERFORMATPAL8
 | |
|  *      </ul>
 | |
|  *      In these cases, the color format refers to that of the palette.
 | |
|  * <li> Flag rwRASTERFORMATMIPMAP. Set if the raster contains mipmap levels.
 | |
|  * <li> Flag rwRASTERFORMATAUTOMIPMAP. Set if the mipmap levels were generated
 | |
|  *      automatically by RenderWare.
 | |
|  * </ol>
 | |
|  */
 | |
| enum RwRasterFormat
 | |
| {
 | |
|     rwRASTERFORMATDEFAULT = 0x0000, /* Whatever the hardware likes best */
 | |
| 
 | |
|     rwRASTERFORMAT1555 = 0x0100,    /**<16 bits - 1 bit alpha, 5 bits red, green and blue */
 | |
|     rwRASTERFORMAT565 = 0x0200,     /**<16 bits - 5 bits red and blue, 6 bits green */
 | |
|     rwRASTERFORMAT4444 = 0x0300,    /**<16 bits - 4 bits per component */
 | |
|     rwRASTERFORMATLUM8 = 0x0400,    /**<Gray scale */
 | |
|     rwRASTERFORMAT8888 = 0x0500,    /**<32 bits - 8 bits per component */
 | |
|     rwRASTERFORMAT888 = 0x0600,     /**<24 bits - 8 bits per component */
 | |
|     rwRASTERFORMAT16 = 0x0700,      /**<16 bits - undefined: useful for things like Z buffers */
 | |
|     rwRASTERFORMAT24 = 0x0800,      /**<24 bits - undefined: useful for things like Z buffers */
 | |
|     rwRASTERFORMAT32 = 0x0900,      /**<32 bits - undefined: useful for things like Z buffers */
 | |
|     rwRASTERFORMAT555 = 0x0a00,     /**<16 bits - 5 bits red, green and blue */
 | |
| 
 | |
|     rwRASTERFORMATAUTOMIPMAP = 0x1000, /**<RenderWare generated the mip levels */
 | |
| 
 | |
|     rwRASTERFORMATPAL8 = 0x2000,    /**<8 bit palettised */
 | |
|     rwRASTERFORMATPAL4 = 0x4000,    /**<4 bit palettised */
 | |
| 
 | |
|     rwRASTERFORMATMIPMAP = 0x8000,  /**<Mip mapping on */
 | |
| 
 | |
|     rwRASTERFORMATPIXELFORMATMASK = 0x0f00, /**<The pixel color format 
 | |
|                                              *  (excluding palettised bits) */
 | |
|     rwRASTERFORMATMASK = 0xff00     /**<The whole format */ ,
 | |
|     rwRASTERFORMATFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwRasterFormat RwRasterFormat;
 | |
| 
 | |
| enum RwRasterPrivateFlag
 | |
| {
 | |
|     rwRASTERGAMMACORRECTED = 0x01,
 | |
|     rwRASTERPIXELLOCKEDREAD = 0x02, /* pixels are locked for reading */
 | |
|     rwRASTERPIXELLOCKEDWRITE = 0x04, /* pixels are locked for writing */
 | |
|     rwRASTERPALETTELOCKEDREAD = 0x08, /* palette is locked for reading */
 | |
|     rwRASTERPALETTELOCKEDWRITE = 0x10, /* palette is locked for writing */
 | |
|     rwRASTERPIXELLOCKEDRAW = 0x20, /* the pixels are in platform specific
 | |
|                                       format, used in combination with
 | |
|                                       rwRASTERPIXELLOCKEDREAD &
 | |
|                                       rwRASTERPIXELLOCKEDWRITE */
 | |
|     rwRASTERPRIVATEFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwRasterPrivateFlag RwRasterPrivateFlag;
 | |
| 
 | |
| #define rwRASTERPIXELLOCKED     (rwRASTERPIXELLOCKEDREAD | rwRASTERPIXELLOCKEDWRITE)
 | |
| #define rwRASTERPALETTELOCKED   (rwRASTERPALETTELOCKEDREAD | rwRASTERPALETTELOCKEDWRITE)
 | |
| #define rwRASTERLOCKED          (rwRASTERPIXELLOCKED|rwRASTERPALETTELOCKED)
 | |
| 
 | |
| /* How big is my stack!!! */
 | |
| #define rwRASTERCONTEXTSTACKSIZE 10
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwRaster 
 | |
|  * Raster containing device-dependent pixels. 
 | |
|  * This should be considered an opaque type.
 | |
|  * Use the RwRaster API functions to access.
 | |
|  */
 | |
| typedef struct RwRaster RwRaster;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RwRaster
 | |
| {
 | |
|     RwRaster           *parent; /* Top level raster if a sub raster */
 | |
|     RwUInt8            *cpPixels; /* Pixel pointer when locked */
 | |
|     RwUInt8            *palette; /* Raster palette */
 | |
|     RwInt32             width, height, depth; /* Dimensions of raster */
 | |
|     RwInt32             stride; /* Lines bytes of raster */
 | |
|     RwInt16             nOffsetX, nOffsetY; /* Sub raster offset */
 | |
|     RwUInt8             cType;  /* Type of raster */
 | |
|     RwUInt8             cFlags; /* Raster flags */
 | |
|     RwUInt8             privateFlags; /* Raster private flags */
 | |
|     RwUInt8             cFormat; /* Raster format */
 | |
| 
 | |
|     RwUInt8            *originalPixels;
 | |
|     RwInt32             originalWidth;
 | |
|     RwInt32             originalHeight;
 | |
|     RwInt32             originalStride;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
|  */
 | |
| 
 | |
| #define RwRasterGetWidthMacro(_raster) \
 | |
|     ((_raster)->width)
 | |
| 
 | |
| #define RwRasterGetHeightMacro(_raster) \
 | |
|     ((_raster)->height)
 | |
| 
 | |
| #define RwRasterGetStrideMacro(_raster) \
 | |
|     ((_raster)->stride)
 | |
| 
 | |
| #define RwRasterGetDepthMacro(_raster) \
 | |
|     ((_raster)->depth)
 | |
| 
 | |
| #define RwRasterGetFormatMacro(_raster) \
 | |
|     ((((_raster)->cFormat) & (rwRASTERFORMATMASK >> 8)) << 8)
 | |
| 
 | |
| #define RwRasterGetTypeMacro(_raster) \
 | |
|     (((_raster)->cType) & rwRASTERTYPEMASK)
 | |
| 
 | |
| #define RwRasterGetParentMacro(_raster) \
 | |
|     ((_raster)->parent)
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RwRasterGetWidth(_raster)                   \
 | |
|     RwRasterGetWidthMacro(_raster)
 | |
| 
 | |
| #define RwRasterGetHeight(_raster)                  \
 | |
|     RwRasterGetHeightMacro(_raster)
 | |
| 
 | |
| #define RwRasterGetStride(_raster)                  \
 | |
|     RwRasterGetStrideMacro(_raster)
 | |
| 
 | |
| #define RwRasterGetDepth(_raster)                   \
 | |
|     RwRasterGetDepthMacro(_raster)
 | |
| 
 | |
| #define RwRasterGetFormat(_raster)                  \
 | |
|     RwRasterGetFormatMacro(_raster)
 | |
| 
 | |
| #define RwRasterGetType(_raster)                  \
 | |
|     RwRasterGetTypeMacro(_raster)
 | |
| 
 | |
| #define RwRasterGetParent(_raster)                  \
 | |
|     RwRasterGetParentMacro(_raster)
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Creating destroying rasters */
 | |
| extern RwRaster    *RwRasterCreate(RwInt32 width, RwInt32 height,
 | |
|                                    RwInt32 depth, RwInt32 flags);
 | |
| extern RwBool       RwRasterDestroy(RwRaster * raster);
 | |
| 
 | |
| /* Pulling info out of raster structure */
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| extern RwInt32      RwRasterGetWidth(const RwRaster *raster);
 | |
| extern RwInt32      RwRasterGetHeight(const RwRaster *raster);
 | |
| extern RwInt32      RwRasterGetStride(const RwRaster *raster);
 | |
| extern RwInt32      RwRasterGetDepth(const RwRaster *raster);
 | |
| extern RwInt32      RwRasterGetFormat(const RwRaster *raster);
 | |
| extern RwInt32      RwRasterGetType(const RwRaster *raster);
 | |
| extern RwRaster    *RwRasterGetParent(const RwRaster *raster);
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| extern RwRaster    *RwRasterGetOffset(RwRaster *raster, 
 | |
|                                       RwInt16 *xOffset, RwInt16 *yOffset);
 | |
| 
 | |
| extern RwInt32      RwRasterGetNumLevels(RwRaster * raster);
 | |
| 
 | |
| extern RwRaster    *RwRasterSubRaster(RwRaster * subRaster,
 | |
|                                       RwRaster * raster, RwRect * rect);
 | |
| 
 | |
| extern RwRaster    *RwRasterRenderFast(RwRaster * raster, RwInt32 x,
 | |
|                                        RwInt32 y);
 | |
| extern RwRaster    *RwRasterRender(RwRaster * raster, RwInt32 x,
 | |
|                                        RwInt32 y);
 | |
| extern RwRaster    *RwRasterRenderScaled(RwRaster * raster,
 | |
|                                          RwRect * rect);
 | |
| 
 | |
| /* Raster rendering context */
 | |
| extern RwRaster    *RwRasterPushContext(RwRaster * raster);
 | |
| extern RwRaster    *RwRasterPopContext(void);
 | |
| extern RwRaster    *RwRasterGetCurrentContext(void);
 | |
| 
 | |
| /* Clearing rasters */
 | |
| extern RwBool       RwRasterClear(RwInt32 pixelValue);
 | |
| extern RwBool       RwRasterClearRect(RwRect * rpRect,
 | |
|                                           RwInt32 pixelValue);
 | |
| 
 | |
| /* Displaying rasters */
 | |
| extern RwRaster    *RwRasterShowRaster(RwRaster * raster, void *dev,
 | |
|                                        RwUInt32 flags);
 | |
| 
 | |
| /* Locking and releasing */
 | |
| extern RwUInt8     *RwRasterLock(RwRaster * raster, RwUInt8 level,
 | |
|                                  RwInt32 lockMode);
 | |
| extern RwRaster    *RwRasterUnlock(RwRaster * raster);
 | |
| extern RwUInt8     *RwRasterLockPalette(RwRaster * raster,
 | |
|                                         RwInt32 lockMode);
 | |
| extern RwRaster    *RwRasterUnlockPalette(RwRaster * raster);
 | |
| 
 | |
| /* Attaching toolkits */
 | |
| extern RwInt32      RwRasterRegisterPlugin(RwInt32 size,
 | |
|                                            RwUInt32 pluginID,
 | |
|                                            RwPluginObjectConstructor
 | |
|                                            constructCB,
 | |
|                                            RwPluginObjectDestructor
 | |
|                                            destructCB,
 | |
|                                            RwPluginObjectCopy copyCB);
 | |
| extern RwInt32      RwRasterGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool       RwRasterValidatePlugins(const RwRaster * raster);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/drvmodel.h ---*/
 | |
| #ifndef D3D8_DRVMODEL_H
 | |
| #define D3D8_DRVMODEL_H
 | |
| 
 | |
| #if (defined(__ICL))
 | |
| /* Avoid voluminous
 | |
|  *   'warning #344: typedef name has already been declared (with same type)'
 | |
|  * warnings from MS include files
 | |
|  */
 | |
| #pragma warning( disable : 344 )
 | |
| #endif /* (defined(__ICL)) */
 | |
| 
 | |
| 
 | |
| #include <windows.h>
 | |
| 
 | |
| #if (defined(RWDEBUG))
 | |
| #if (defined(RWMEMDEBUG) && !defined(_CRTDBG_MAP_ALLOC))
 | |
| #define _CRTDBG_MAP_ALLOC
 | |
| #endif /* defined(RWMEMDEBUG) && !defined(_CRTDBG_MAP_ALLOC)) */
 | |
| #include <crtdbg.h>
 | |
| #define ERR_WRAP(A) (_rwRePrintErrorDDD3D((A), __FILE__, __LINE__))
 | |
| #endif /* (defined(RWDEBUG)) */
 | |
| 
 | |
| #if (!defined(ERR_WRAP))
 | |
| #define ERR_WRAP(A) (A)
 | |
| #endif /* (!defined(ERR_WRAP)) */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* Set true depth information (for fogging, eg) */
 | |
| #define RwIm2DVertexSetCameraX(vert, camx)          /* Nothing */
 | |
| #define RwIm2DVertexSetCameraY(vert, camy)          /* Nothing */
 | |
| #define RwIm2DVertexSetCameraZ(vert, camz)          /* Nothing */
 | |
| 
 | |
| #define RwIm2DVertexSetRecipCameraZ(vert, recipz)   ((vert)->rhw = recipz)
 | |
| 
 | |
| #define RwIm2DVertexGetCameraX(vert)                (cause an error)
 | |
| #define RwIm2DVertexGetCameraY(vert)                (cause an error)
 | |
| #define RwIm2DVertexGetCameraZ(vert)                (cause an error)
 | |
| #define RwIm2DVertexGetRecipCameraZ(vert)           ((vert)->rhw)
 | |
| 
 | |
| /* Set screen space coordinates in a device vertex */
 | |
| #define RwIm2DVertexSetScreenX(vert, scrnx)         ((vert)->x = (scrnx))
 | |
| #define RwIm2DVertexSetScreenY(vert, scrny)         ((vert)->y = (scrny))
 | |
| #define RwIm2DVertexSetScreenZ(vert, scrnz)         ((vert)->z = (scrnz))
 | |
| #define RwIm2DVertexGetScreenX(vert)                ((vert)->x)
 | |
| #define RwIm2DVertexGetScreenY(vert)                ((vert)->y)
 | |
| #define RwIm2DVertexGetScreenZ(vert)                ((vert)->z)
 | |
| 
 | |
| /* Set texture coordinates in a device vertex */
 | |
| #define RwIm2DVertexSetU(vert, texU, recipz)        ((vert)->u = (texU))
 | |
| #define RwIm2DVertexSetV(vert, texV, recipz)        ((vert)->v = (texV))
 | |
| #define RwIm2DVertexGetU(vert)                      ((vert)->u)
 | |
| #define RwIm2DVertexGetV(vert)                      ((vert)->v)
 | |
| 
 | |
| /* Modify the luminance stuff */
 | |
| #define RwIm2DVertexSetRealRGBA(vert, red, green, blue, alpha)  \
 | |
|     ((vert)->emissiveColor =                                    \
 | |
|      (((RwFastRealToUInt32(alpha)) << 24) |                        \
 | |
|       ((RwFastRealToUInt32(red)) << 16) |                          \
 | |
|       ((RwFastRealToUInt32(green)) << 8) |                         \
 | |
|       ((RwFastRealToUInt32(blue)))))
 | |
| 
 | |
| #define RwIm2DVertexSetIntRGBA(vert, red, green, blue, alpha)   \
 | |
|     ((vert)->emissiveColor =                                    \
 | |
|      ((((RwUInt32)(alpha)) << 24) |                             \
 | |
|       (((RwUInt32)(red)) << 16) |                               \
 | |
|       (((RwUInt32)(green)) << 8) |                              \
 | |
|       (((RwUInt32)(blue)))))
 | |
| 
 | |
| #define RwIm2DVertexGetRed(vert)    \
 | |
|     (((vert)->emissiveColor >> 16) & 0xFF)
 | |
| 
 | |
| #define RwIm2DVertexGetGreen(vert)  \
 | |
|     (((vert)->emissiveColor >> 8) & 0xFF)
 | |
| 
 | |
| #define RwIm2DVertexGetBlue(vert)   \
 | |
|     ((vert)->emissiveColor & 0xFF)
 | |
| 
 | |
| #define RwIm2DVertexGetAlpha(vert)  \
 | |
|     (((vert)->emissiveColor >> 24) & 0xFF)
 | |
| 
 | |
| #define RwIm2DVertexCopyRGBA(dst, src)  \
 | |
|     ((dst)->emissiveColor = (src)->emissiveColor)
 | |
| 
 | |
| /* Clipper stuff */
 | |
| 
 | |
| #define RwIm2DVertexClipRGBA(o, i, n, f)                                \
 | |
| MACRO_START                                                             \
 | |
| {                                                                       \
 | |
|     const RwInt32        _factor =                                      \
 | |
|         (RwFastRealToUInt32(i * (RwReal)(255))) & 255;                  \
 | |
|                                                                         \
 | |
|     (o)->emissiveColor =                                                \
 | |
|         (((((RwIm2DVertexGetAlpha(f) - RwIm2DVertexGetAlpha(n)) *       \
 | |
|             _factor) >> 8) + RwIm2DVertexGetAlpha(n)) << 24) |          \
 | |
|         (((((RwIm2DVertexGetRed(f) - RwIm2DVertexGetRed(n)) *           \
 | |
|             _factor) >> 8) + RwIm2DVertexGetRed(n)) << 16) |            \
 | |
|         (((((RwIm2DVertexGetGreen(f) - RwIm2DVertexGetGreen(n)) *       \
 | |
|             _factor) >> 8) + RwIm2DVertexGetGreen(n)) << 8) |           \
 | |
|         (((((RwIm2DVertexGetBlue(f) - RwIm2DVertexGetBlue(n)) *         \
 | |
|             _factor) >> 8) + RwIm2DVertexGetBlue(n)));                  \
 | |
| }                                                                       \
 | |
| MACRO_STOP
 | |
| 
 | |
| /* LEGACY-SUPPORT macros */
 | |
| #define RWIM2DVERTEXSetCameraX(vert, camx)  RwIm2DVertexSetCameraX(vert, camx)
 | |
| #define RWIM2DVERTEXSetCameraY(vert, camy)  RwIm2DVertexSetCameraY(vert, camy)
 | |
| #define RWIM2DVERTEXSetCameraZ(vert, camz)  RwIm2DVertexSetCameraZ(vert, camz)
 | |
| #define RWIM2DVERTEXSetRecipCameraZ(vert, recipz) \
 | |
|     RwIm2DVertexSetRecipCameraZ(vert, recipz)
 | |
| #define RWIM2DVERTEXGetCameraX(vert)        RwIm2DVertexGetCameraX(vert)
 | |
| #define RWIM2DVERTEXGetCameraY(vert)        RwIm2DVertexGetCameraY(vert)
 | |
| #define RWIM2DVERTEXGetCameraZ(vert)        RwIm2DVertexGetCameraZ(vert)
 | |
| #define RWIM2DVERTEXGetRecipCameraZ(vert)   RwIm2DVertexGetRecipCameraZ(vert)
 | |
| #define RWIM2DVERTEXSetScreenX(vert, scrnx) RwIm2DVertexSetScreenX(vert, scrnx)
 | |
| #define RWIM2DVERTEXSetScreenY(vert, scrny) RwIm2DVertexSetScreenY(vert, scrny)
 | |
| #define RWIM2DVERTEXSetScreenZ(vert, scrnz) RwIm2DVertexSetScreenZ(vert, scrnz)
 | |
| #define RWIM2DVERTEXGetScreenX(vert)        RwIm2DVertexGetScreenX(vert)
 | |
| #define RWIM2DVERTEXGetScreenY(vert)        RwIm2DVertexGetScreenY(vert)
 | |
| #define RWIM2DVERTEXGetScreenZ(vert)        RwIm2DVertexGetScreenZ(vert)
 | |
| #define RWIM2DVERTEXSetU(vert, u, recipz)   RwIm2DVertexSetU(vert, u, recipz)
 | |
| #define RWIM2DVERTEXSetV(vert, v, recipz)   RwIm2DVertexSetV(vert, v, recipz)
 | |
| #define RWIM2DVERTEXGetU(vert)              RwIm2DVertexGetU(vert)
 | |
| #define RWIM2DVERTEXGetV(vert)              RwIm2DVertexGetV(vert)
 | |
| #define RWIM2DVERTEXSetRealRGBA(vert, red, green, blue, alpha) \
 | |
|     RwIm2DVertexSetRealRGBA(vert, red, green, blue, alpha)
 | |
| #define RWIM2DVERTEXSetIntRGBA(vert, red, green, blue, alpha)  \
 | |
|     RwIm2DVertexSetIntRGBA(vert, red, green, blue, alpha)
 | |
| #define RWIM2DVERTEXGetRed(vert)            RwIm2DVertexGetRed(vert)
 | |
| #define RWIM2DVERTEXGetGreen(vert)          RwIm2DVertexGetGreen(vert)
 | |
| #define RWIM2DVERTEXGetBlue(vert)           RwIm2DVertexGetBlue(vert)
 | |
| #define RWIM2DVERTEXGetAlpha(vert)          RwIm2DVertexGetAlpha(vert)
 | |
| #define RWIM2DVERTEXCopyRGBA(dst, src)      RwIm2DVertexCopyRGBA(dst, src)
 | |
| #define RWIM2DVERTEXClipRGBA(o, i, n, f)    RwIm2DVertexClipRGBA(o, i, n, f)
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| /* We use RwD3D8Vertex to drive the hardware in 2D mode */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \typedef RwD3D8Vertex
 | |
|  * D3D8 vertex structure definition for 2D geometry
 | |
|  */
 | |
| typedef struct RwD3D8Vertex RwD3D8Vertex;
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \struct RwD3D8Vertex
 | |
|  * D3D8 vertex structure definition for 2D geometry
 | |
|  */
 | |
| struct RwD3D8Vertex
 | |
| {
 | |
|     RwReal      x;              /**< Screen X */
 | |
|     RwReal      y;              /**< Screen Y */
 | |
|     RwReal      z;              /**< Screen Z */
 | |
|     RwReal      rhw;            /**< Reciprocal of homogeneous W */
 | |
| 
 | |
|     RwUInt32    emissiveColor;  /**< Vertex color */
 | |
| 
 | |
|     RwReal      u;              /**< Texture coordinate U */
 | |
|     RwReal      v;              /**< Texture coordinate V */
 | |
| };
 | |
| 
 | |
| /* Define types used */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \typedef RwIm2DVertex
 | |
|  * Typedef for a RenderWare Graphics Immediate Mode 2D Vertex
 | |
|  */
 | |
| typedef RwD3D8Vertex    RwIm2DVertex;
 | |
| 
 | |
| /* LEGACY-SUPPORT macro */
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \def RWIM2DVERTEX
 | |
|  * RWIM2DVERTEX is a legacy macro for RwIm2DVertex
 | |
|  */
 | |
| #define RWIM2DVERTEX    RwIm2DVertex
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \typedef RxVertexIndex
 | |
|  *
 | |
|  * Typedef for a RenderWare Graphics PowerPipe Immediate
 | |
|  * Mode Vertex
 | |
|  */
 | |
| typedef RwUInt16        RxVertexIndex;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \typedef RwImVertexIndex
 | |
|  * Typedef for a RenderWare Graphics Immediate Mode Vertex.
 | |
|  */
 | |
| typedef RxVertexIndex   RwImVertexIndex;
 | |
| 
 | |
| /* LEGACY-SUPPORT macro */
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \def RWIMVERTEXINDEX
 | |
|  * RWIMVERTEXINDEX is a legacy macro for RwImVertexIndex
 | |
|  */
 | |
| #define RWIMVERTEXINDEX RwImVertexIndex
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \struct RwD3D8Metrics
 | |
|  * Structure containing metrics counters
 | |
|  */
 | |
| typedef struct
 | |
| {
 | |
|     RwUInt32    numRenderStateChanges;          /**< Number of Render States changed */
 | |
|     RwUInt32    numTextureStageStateChanges;    /**< Number of Texture Stage States changed */
 | |
|     RwUInt32    numMaterialChanges;             /**< Number of Material changes */
 | |
|     RwUInt32    numLightsChanged;               /**< Number of Lights changed */
 | |
| }
 | |
| RwD3D8Metrics;
 | |
| 
 | |
| #endif /* D3D8_DRVMODEL_H */
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/d3d8/pip2model.h ---*/
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Defines
 | |
|  */
 | |
| 
 | |
| #define RXHEAPPLATFORMDEFAULTSIZE  (1 << 12) /* 4k */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| /* We use D3D8 formats for the instanced versions, to allow hardware T&L */
 | |
| 
 | |
| /**
 | |
|  * \ingroup corep2d3d8
 | |
|  * \typedef RxObjSpace3DVertex
 | |
|  * Typedef for an RxObjSpace3DVertex.
 | |
|  */
 | |
| typedef struct RxObjSpace3DVertex RxObjSpace3DVertex;
 | |
| 
 | |
| /**
 | |
|  * \ingroup corep2d3d8
 | |
|  * \struct RxObjSpace3DVertex
 | |
|  * Structure representing object space vertex.
 | |
|  */
 | |
| struct RxObjSpace3DVertex
 | |
| {
 | |
|     RwV3d       objVertex;        /**< position */
 | |
|     RwV3d       objNormal;        /**< normal */
 | |
|     RwUInt32    color;            /**< emissive color*/
 | |
|     RwReal      u;                /**< u */
 | |
|     RwReal      v;                /**< v */
 | |
| };
 | |
| 
 | |
| /* This vertex is non truncatable */
 | |
| #define RxObjSpace3DVertexNoUVsNoNormalsSize (sizeof(RxObjSpace3DVertex))
 | |
| #define RxObjSpace3DVertexNoUVsSize          (sizeof(RxObjSpace3DVertex))
 | |
| #define RxObjSpace3DVertexFullSize           (sizeof(RxObjSpace3DVertex))
 | |
| 
 | |
| /**
 | |
|  * \ingroup corep2d3d8
 | |
|  * \typedef RxObjSpace3DLitVertex
 | |
|  * Typedef for an RxObjSpace3DLitVertex.
 | |
|  */
 | |
| typedef RxObjSpace3DVertex RxObjSpace3DLitVertex;
 | |
| 
 | |
| /** 
 | |
|  * \ingroup corep2d3d8
 | |
|  * \typedef RwIm3DVertex
 | |
|  * Typedef for an RwIm3DVertex.
 | |
|  */
 | |
| typedef RxObjSpace3DLitVertex RwIm3DVertex;
 | |
| 
 | |
| /* LEGACY-SUPPORT macro */
 | |
| #define RWIM3DVERTEX RwIm3DVertex
 | |
| typedef RwIm2DVertex RxScrSpace2DVertex;
 | |
| 
 | |
| /****************************************************************************
 | |
|  Object-space 3D unlit vertex macros
 | |
|  */
 | |
| 
 | |
| /* Vertex positions */
 | |
| #define RxObjSpace3DVertexGetPos(_vert, _pos) \
 | |
|     (*(_pos) = (_vert)->objVertex)
 | |
| #define RxObjSpace3DVertexSetPos(_vert, _pos) \
 | |
|     ((_vert)->objVertex = *(_pos))
 | |
| 
 | |
| /* Pre-lighting colours */
 | |
| #define RxObjSpace3DVertexGetPreLitColor(_vert, _col) \
 | |
| MACRO_START \
 | |
| { \
 | |
|     (_col)->alpha = (RwUInt8)((_vert)->color >> 24) & 0xFF; \
 | |
|     (_col)->red   = (RwUInt8)((_vert)->color >> 16) & 0xFF; \
 | |
|     (_col)->green = (RwUInt8)((_vert)->color >>  8) & 0xFF; \
 | |
|     (_col)->blue  = (RwUInt8)((_vert)->color      ) & 0xFF; \
 | |
| } \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RxObjSpace3DVertexSetPreLitColor(_vert, _col) \
 | |
|     ((_vert)->color = (((RwUInt32)(_col)->alpha) << 24) | \
 | |
|                               (((RwUInt32)(_col)->red)   << 16) | \
 | |
|                               (((RwUInt32)(_col)->green) <<  8) | \
 | |
|                               (((RwUInt32)(_col)->blue)       ))
 | |
| 
 | |
| /* This uses the same slot as color (they are mutually exclusive) */
 | |
| #define RxObjSpace3DVertexGetColor RxObjSpace3DVertexGetPreLitColor
 | |
| 
 | |
| /* Normals */
 | |
| #define RxObjSpace3DVertexGetNormal(_vert, _normal)             \
 | |
|     (*(_normal) = (_vert)->objNormal)
 | |
| #define RxObjSpace3DVertexSetNormal(_vert, _normal)             \
 | |
|     ((_vert)->objNormal = *(_normal))
 | |
| 
 | |
| /* Us and Vs */
 | |
| #define RxObjSpace3DVertexGetU(_vert)                          \
 | |
|     ((_vert)->u)
 | |
| #define RxObjSpace3DVertexGetV(_vert)                          \
 | |
|     ((_vert)->v)
 | |
| #define RxObjSpace3DVertexSetU(_vert, _imu)                     \
 | |
|     ((_vert)->u = (_imu))
 | |
| #define RxObjSpace3DVertexSetV(_vert, _imv)                     \
 | |
|     ((_vert)->v = (_imv))
 | |
| 
 | |
| /****************************************************************************
 | |
|  Object-space 3D lit vertex macros
 | |
|  */
 | |
| 
 | |
| /* Vertex positions */
 | |
| #define RxObjSpace3DLitVertexGetPos(_vert, _pos) \
 | |
|     (*(_pos) = (_vert)->objVertex)
 | |
| #define RxObjSpace3DLitVertexSetPos(_vert, _pos) \
 | |
|     ((_vert)->objVertex = *(_pos))
 | |
| 
 | |
| /* Vertex colours */
 | |
| #define RxObjSpace3DLitVertexGetColor(_vert, _col) \
 | |
| MACRO_START \
 | |
| { \
 | |
|     (_col)->red   = ((_vert)->color >> 16) & 0xFF; \
 | |
|     (_col)->green = ((_vert)->color >>  8) & 0xFF; \
 | |
|     (_col)->blue  = ((_vert)->color      ) & 0xFF; \
 | |
|     (_col)->alpha = ((_vert)->color >> 24) & 0xFF; \
 | |
| } \
 | |
| MACRO_STOP
 | |
| #define RxObjSpace3DLitVertexSetColor(_vert, _col) \
 | |
|     ((_vert)->color = (((RwUInt32)(_col)->alpha) << 24) | \
 | |
|                               (((RwUInt32)(_col)->red)   << 16) | \
 | |
|                               (((RwUInt32)(_col)->green) <<  8) | \
 | |
|                               (((RwUInt32)(_col)->blue)       ))
 | |
| 
 | |
| /* Us and Vs */
 | |
| #define RxObjSpace3DLitVertexGetU(_vert) \
 | |
|     ((_vert)->u)
 | |
| #define RxObjSpace3DLitVertexGetV(_vert) \
 | |
|     ((_vert)->v)
 | |
| #define RxObjSpace3DLitVertexSetU(_vert, _imu) \
 | |
|     ((_vert)->u = (_imu))
 | |
| #define RxObjSpace3DLitVertexSetV(_vert, _imv) \
 | |
|     ((_vert)->v = (_imv))
 | |
| 
 | |
| /* LEGACY-SUPPORT for old objvert names - NB does NOT guarantee the
 | |
|  * app will work, because the old IM3DVERTEX macros are NOT correctly
 | |
|  * abstracted - 'Get' will return pointers to RwV3ds inside the
 | |
|  * ObjVert, but you can't assume there are any RwV3ds inside an
 | |
|  * opaque vertex type */
 | |
| 
 | |
| #define RwIm3DVertexSetU   RxObjSpace3DLitVertexSetU
 | |
| #define RwIm3DVertexSetV   RxObjSpace3DLitVertexSetV
 | |
| #define RwIm3DVertexGetNext(_vert)      ((_vert) + 1)
 | |
| 
 | |
| #define RwIm2DCameraVertexSetU(_devvert, _camvert, _u, _recipz) \
 | |
| MACRO_START                                                     \
 | |
| {                                                               \
 | |
|     RwReal _uTmp = _u;                                          \
 | |
|     _camvert->u = _uTmp;                                        \
 | |
|     RwIm2DVertexSetU(_devvert, _uTmp, _recipz);                 \
 | |
| }                                                               \
 | |
| MACRO_STOP
 | |
| #define RwIm2DCameraVertexSetV(_devvert, _camvert, _v, _recipz) \
 | |
| MACRO_START                                                     \
 | |
| {                                                               \
 | |
|     RwReal _vTmp = _v;                                          \
 | |
|     _camvert->v = _vTmp;                                        \
 | |
|     RwIm2DVertexSetV(_devvert, _vTmp, _recipz);                 \
 | |
| }                                                               \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RwIm3DVertexSetPos(_vert, _imx, _imy, _imz) \
 | |
| MACRO_START \
 | |
| { \
 | |
|     (_vert)->objVertex.x = _imx; \
 | |
|     (_vert)->objVertex.y = _imy; \
 | |
|     (_vert)->objVertex.z = _imz; \
 | |
| } \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RwIm3DVertexSetNormal(vert, imx, imy, imz)         \
 | |
| MACRO_START                                                \
 | |
| {                                                          \
 | |
|     RwV3d packed;                                          \
 | |
|     packed.x = imx;                                        \
 | |
|     packed.y = imy;                                        \
 | |
|     packed.z = imz;                                        \
 | |
|     RxObjSpace3DVertexSetNormal(vert, &packed);            \
 | |
| }                                                          \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RwIm3DVertexSetRGBA(_vert, _r, _g, _b, _a) \
 | |
| MACRO_START \
 | |
| { \
 | |
|     ((_vert)->color = ((_a) << 24) | \
 | |
|                               ((_r) << 16) | \
 | |
|                               ((_g) << 8) | \
 | |
|                               ((_b))); \
 | |
| } \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RwIm3DVertexGetPos(_vert) (&((_vert)->objVertex))
 | |
| #define RwIm3DVertexGetNormal(vert) (&((vert)->objNormal))
 | |
| 
 | |
| #define RwIm3DVertexCopyRGBA(_dst, _src) (((_dst)->color) = ((_src)->color))
 | |
| 
 | |
| /* LEGACY-SUPPORT macros */
 | |
| #define RWIM2DCAMERAVERTEXSetU(_devvert, _camvert, _u, _recipz) \
 | |
|     RwIm2DCameraVertexSetU(_devvert, _camvert, _u, _recipz)
 | |
| #define RWIM2DCAMERAVERTEXSetV(_devvert, _camvert, _v, _recipz) \
 | |
|     RwIm2DCameraVertexSetV(_devvert, _camvert, _v, _recipz)
 | |
| #define RWIM3DVERTEXGetNext(vert)                   RwIm3DVertexGetNext(vert)
 | |
| #define RWIM3DVERTEXSetPos(vert, imx, imy, imz)     RwIm3DVertexSetPos(vert, imx, imy, imz)
 | |
| #define RWIM3DVERTEXGetPos(vert)                    RwIm3DVertexGetPos(vert)
 | |
| #define RWIM3DVERTEXSetU(vert, imu)                 RwIm3DVertexSetU(vert, imu)
 | |
| #define RWIM3DVERTEXSetV(vert, imv)                 RwIm3DVertexSetV(vert, imv)
 | |
| #define RWIM3DVERTEXSetRGBA(vert, r, g, b, a)       RwIm3DVertexSetRGBA(vert, r, g, b, a)
 | |
| #define RWIM3DVERTEXSetNormal(vert, imx, imy, imz)  RwIm3DVertexSetNormal(vert, imx, imy, imz)
 | |
| #define RWIM3DVERTEXCopyRGBA(dst,src)               RwIm3DVertexCopyRGBA(dst,src)
 | |
| #define RXOBJSPACE3DVERTEXGetPos(_vert, _pos) \
 | |
|     RxObjSpace3DVertexGetPos(_vert, _pos)
 | |
| #define RXOBJSPACE3DVERTEXSetPos(_vert, _pos) \
 | |
|     RxObjSpace3DVertexSetPos(_vert, _pos)
 | |
| #define RXOBJSPACE3DVERTEXGetPreLitColor(_vert, _col) \
 | |
|     RxObjSpace3DVertexGetPreLitColor(_vert, _col)
 | |
| #define RXOBJSPACE3DVERTEXSetPreLitColor(_vert, _col) \
 | |
|     RxObjSpace3DVertexSetPreLitColor(_vert, _col)
 | |
| #define RXOBJSPACE3DVERTEXGetColor              RxObjSpace3DVertexGetColor
 | |
| #define RXOBJSPACE3DVERTEXGetNormal(_vert, _normal) \
 | |
|     RxObjSpace3DVertexGetNormal(_vert, _normal)
 | |
| #define RXOBJSPACE3DVERTEXSetNormal(_vert, _normal) \
 | |
|     RxObjSpace3DVertexSetNormal(_vert, _normal)
 | |
| #define RXOBJSPACE3DVERTEXGetU(_vert)           RxObjSpace3DVertexGetU(_vert)
 | |
| #define RXOBJSPACE3DVERTEXGetV(_vert)           RxObjSpace3DVertexGetV(_vert)
 | |
| #define RXOBJSPACE3DVERTEXSetU(_vert, _imu) \
 | |
|     RxObjSpace3DVertexSetU(_vert, _imu)
 | |
| #define RXOBJSPACE3DVERTEXSetV(_vert, _imv) \
 | |
|     RxObjSpace3DVertexSetV(_vert, _imv)
 | |
| #define RXOBJSPACE3DLITVERTEXGetPos(vert, pos)   \
 | |
|     RxObjSpace3DLitVertexGetPos(vert, pos)
 | |
| #define RXOBJSPACE3DLITVERTEXSetPos(vert, pos)   \
 | |
|     RxObjSpace3DLitVertexSetPos(vert, pos)
 | |
| #define RXOBJSPACE3DLITVERTEXGetColor(vert, col) \
 | |
|     RxObjSpace3DLitVertexGetColor(vert, col)
 | |
| #define RXOBJSPACE3DLITVERTEXSetColor(vert, col) \
 | |
|     RxObjSpace3DLitVertexSetColor(vert, col)
 | |
| #define RXOBJSPACE3DLITVERTEXGetU(vert)          \
 | |
|     RxObjSpace3DLitVertexGetU(vert)
 | |
| #define RXOBJSPACE3DLITVERTEXGetV(vert)          \
 | |
|     RxObjSpace3DLitVertexGetV(vert)
 | |
| #define RXOBJSPACE3DLITVERTEXSetU(vert, imu)     \
 | |
|     RxObjSpace3DLitVertexSetU(vert, imu)
 | |
| #define RXOBJSPACE3DLITVERTEXSetV(vert, imv)     \
 | |
|     RxObjSpace3DLitVertexSetV(vert, imv)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2renderstate.h ---*/
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  *  RxRenderStateFlag 
 | |
|  *  Flags used in the \ref RxRenderStateVector structure */
 | |
| enum RxRenderStateFlag
 | |
| {
 | |
|     rxRENDERSTATEFLAG_TEXTUREPERSPECTIVE   = 0x00000001, /**<Perspective texturing is to be enabled */
 | |
|     rxRENDERSTATEFLAG_ZTESTENABLE          = 0x00000002, /**<Z-Buffer testing is to be performed */
 | |
|     rxRENDERSTATEFLAG_ZWRITEENABLE         = 0x00000004, /**<Z-Buffer writing is to be enabled */
 | |
|     rxRENDERSTATEFLAG_VERTEXALPHAENABLE    = 0x00000008, /**<Vertex alpha is to be enabled */
 | |
|     rxRENDERSTATEFLAG_FOGENABLE            = 0x00000010, /**<Fog is to be enabled */
 | |
|     rxRENDERSTATEFLAG_ALPHAPRIMITIVEBUFFER = 0x00000020, /**<Alpha primitive buffering is to be enabled */
 | |
|     rxRENDERSTATEFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RxRenderStateFlag RxRenderStateFlag;
 | |
| 
 | |
| typedef struct RxRenderStateVector RxRenderStateVector;
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxRenderStateVector
 | |
|  * Structure describing a render-state vector,
 | |
|  * used by the RxClRenderState cluster */
 | |
| struct RxRenderStateVector
 | |
| {
 | |
|     RwUInt32             Flags;         /**< A load of the boolean renderstate options */
 | |
|     RwShadeMode          ShadeMode;     /**< Flat or Gouraud currently */
 | |
|     RwBlendFunction      SrcBlend;      /**< Src  alpha, 1-src  alpha, etc */
 | |
|     RwBlendFunction      DestBlend;     /**< Dest alpha, 1-dest alpha, etc */
 | |
|     RwRaster            *TextureRaster; /**< texture raster */
 | |
|     RwTextureAddressMode AddressModeU;  /**< U addressing mode - WRAP, MIRROR, CLAMP, BORDER */
 | |
|     RwTextureAddressMode AddressModeV;  /**< V addressing mode - WRAP, MIRROR, CLAMP, BORDER */
 | |
|     RwTextureFilterMode  FilterMode;    /**< filtering mode - combos of NEAREST LINEAR MIP */
 | |
|     RwRGBA               BorderColor;   /**< Border color for texturing address mode border */
 | |
|     RwFogType            FogType;       /**< Select the type of fogging to use */
 | |
|     RwRGBA               FogColor;      /**< Color used for fogging */
 | |
|     RwUInt8             *FogTable;      /**< A 256 entry fog table */
 | |
| };
 | |
| 
 | |
| #if (!defined(RxRenderStateVectorAssign))
 | |
| #define RxRenderStateVectorAssign(_target, _source)            \
 | |
|     ( *(_target) = *(_source) )
 | |
| #endif /* (!defined(RxRenderStateVectorAssign)) */
 | |
| 
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern       RxRenderStateVector *RxRenderStateVectorSetDefaultRenderStateVector(RxRenderStateVector *rsvp);
 | |
| extern const RxRenderStateVector *RxRenderStateVectorGetDefaultRenderStateVector(void);
 | |
| extern       RxRenderStateVector *RxRenderStateVectorCreate(RwBool current);
 | |
| extern       void                 RxRenderStateVectorDestroy(RxRenderStateVector *rsvp);
 | |
| extern       RxRenderStateVector *RxRenderStateVectorLoadDriverState(RxRenderStateVector *rsvp);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2clpcom.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeRGBAInterp.h ---*/
 | |
| 
 | |
| struct NodeRGBAInterpData
 | |
| {
 | |
|     RwBool              rgbaInterpOn;
 | |
|     RxRenderStateVector state;
 | |
| };
 | |
| typedef struct NodeRGBAInterpData NodeRGBAInterpData;
 | |
| 
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetRGBAInterp(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/nodeUVInterp.h ---*/
 | |
| 
 | |
| typedef struct RxNodeUVInterpSettings RxNodeUVInterpSettings;
 | |
| struct RxNodeUVInterpSettings
 | |
| {
 | |
|     RwBool              uvInterpOn;
 | |
|     RxRenderStateVector state;
 | |
| };
 | |
| 
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition * RxNodeDefinitionGetUVInterp(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/baimage.h ---*/
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* If this bit is set then the image has been allocated by the user */
 | |
| 
 | |
| enum RwImageFlag
 | |
| {
 | |
|     rwNAIMAGEFLAG = 0x00,
 | |
|     rwIMAGEALLOCATED = 0x1,
 | |
|     rwIMAGEGAMMACORRECTED = 0x2,
 | |
|     rwIMAGEFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwImageFlag RwImageFlag;
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwImage 
 | |
|  * Image containing device-independent pixels. 
 | |
|  * This should be considered an opaque type.
 | |
|  * Use the RwImage API functions to access.
 | |
|  */
 | |
| typedef struct RwImage RwImage;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RwImage
 | |
| {
 | |
|         RwInt32             flags;
 | |
| 
 | |
|         RwInt32             width;  /* Device may have different ideas */
 | |
|         RwInt32             height; /* internally !! */
 | |
| 
 | |
|         RwInt32             depth;  /* Of referenced image */
 | |
|         RwInt32             stride;
 | |
| 
 | |
|         RwUInt8            *cpPixels;
 | |
|         RwRGBA             *palette;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwImageCallBackRead 
 | |
|  * is the function registered with \ref RwImageRegisterImageFormat that is used,
 | |
|  * for example by \ref RwImageRead and \ref RwImageReadMaskedImage,
 | |
|  * to read images of a specific format from a disk file.
 | |
|  * 
 | |
|  * \param  imageName   Pointer to a string containing the file name of the image.
 | |
|  *
 | |
|  * \see RwImageRegisterImageFormat
 | |
|  *
 | |
|  */
 | |
| typedef RwImage *(*RwImageCallBackRead)(const RwChar * imageName);
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwImageCallBackWrite 
 | |
|  * is the function registered with \ref RwImageRegisterImageFormat that is used,
 | |
|  * for example by \ref RwImageWrite, 
 | |
|  * to write images of a specific format to a disk file.
 | |
|  * 
 | |
|  * \param  image   Pointer to the image.
 | |
|  *
 | |
|  * \param  imageName   Pointer to a string containing the file name
 | |
|  * of the image.
 | |
|  *
 | |
|  *
 | |
|  * \return Pointer to the written image.
 | |
|  *
 | |
|  * \see RwImageRegisterImageFormat
 | |
|  *
 | |
|  */
 | |
| typedef RwImage *(*RwImageCallBackWrite)(RwImage *image, const RwChar *imageName);
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
|  */
 | |
| 
 | |
| #define RwImageSetStrideMacro(_image, _stride)      \
 | |
|     (((_image)->stride = (_stride)), (_image))
 | |
| 
 | |
| #define RwImageSetPixelsMacro(_image, _pixels)      \
 | |
|     (((_image)->cpPixels = (_pixels)), (_image))
 | |
| 
 | |
| #define RwImageSetPaletteMacro(_image, _palette)    \
 | |
|     (((_image)->palette = (_palette)), (_image))
 | |
| 
 | |
| #define RwImageGetWidthMacro(_image)                \
 | |
|     ((_image)->width)
 | |
| 
 | |
| #define RwImageGetHeightMacro(_image)               \
 | |
|     ((_image)->height)
 | |
| 
 | |
| #define RwImageGetDepthMacro(_image)                \
 | |
|     ((_image)->depth)
 | |
| 
 | |
| #define RwImageGetStrideMacro(_image)               \
 | |
|     ((_image)->stride)
 | |
| 
 | |
| #define RwImageGetPixelsMacro(_image)               \
 | |
|     ((_image)->cpPixels)
 | |
| 
 | |
| #define RwImageGetPaletteMacro(_image)              \
 | |
|     ((_image)->palette)
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RwImageSetStride(_image, _stride)           \
 | |
|     RwImageSetStrideMacro(_image, _stride)
 | |
| 
 | |
| #define RwImageSetPixels(_image, _pixels)           \
 | |
|     RwImageSetPixelsMacro(_image, _pixels)
 | |
| 
 | |
| #define RwImageSetPalette(_image, _palette)         \
 | |
|     RwImageSetPaletteMacro(_image, _palette)
 | |
| 
 | |
| #define RwImageGetWidth(_image)                     \
 | |
|     RwImageGetWidthMacro(_image)
 | |
| 
 | |
| #define RwImageGetHeight(_image)                    \
 | |
|     RwImageGetHeightMacro(_image)
 | |
| 
 | |
| #define RwImageGetDepth(_image)                     \
 | |
|     RwImageGetDepthMacro(_image)
 | |
| 
 | |
| #define RwImageGetStride(_image)                    \
 | |
|     RwImageGetStrideMacro(_image)
 | |
| 
 | |
| #define RwImageGetPixels(_image)                    \
 | |
|     RwImageGetPixelsMacro(_image)
 | |
| 
 | |
| #define RwImageGetPalette(_image)                   \
 | |
|     RwImageGetPaletteMacro(_image)
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
|     /* Creating and destroying */
 | |
| extern RwImage     *RwImageCreate(RwInt32 width, RwInt32 height,
 | |
|                                   RwInt32 depth);
 | |
| extern RwBool       RwImageDestroy(RwImage * image);
 | |
| 
 | |
|     /* Allocating */
 | |
| extern RwImage     *RwImageAllocatePixels(RwImage * image);
 | |
| extern RwImage     *RwImageFreePixels(RwImage * image);
 | |
| 
 | |
|     /* Converting images */
 | |
| extern RwImage     *RwImageCopy(RwImage * destImage,
 | |
|                                 const RwImage * sourceImage);
 | |
| 
 | |
|     /* Resizing images */
 | |
| extern RwImage     *RwImageResize(RwImage * image, RwInt32 width,
 | |
|                                   RwInt32 height);
 | |
| 
 | |
|     /* Producing masks ! */
 | |
| extern RwImage     *RwImageApplyMask(RwImage * image,
 | |
|                                      const RwImage * mask);
 | |
| extern RwImage     *RwImageMakeMask(RwImage * image);
 | |
| 
 | |
|     /* Helper functions */
 | |
| extern RwImage     *RwImageReadMaskedImage(const RwChar * imageName,
 | |
|                                            const RwChar * maskname);
 | |
| extern RwImage     *RwImageRead(const RwChar * imageName);
 | |
| extern RwImage     *RwImageWrite(RwImage * image,
 | |
|                                  const RwChar * imageName);
 | |
| 
 | |
|     /* Setting and getting the default path for images */
 | |
| extern RwChar      *RwImageGetPath(void);
 | |
| extern const RwChar *RwImageSetPath(const RwChar * path);
 | |
| 
 | |
|     /* Setting */
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| extern RwImage     *RwImageSetStride(RwImage * image, RwInt32 stride);
 | |
| extern RwImage     *RwImageSetPixels(RwImage * image, RwUInt8 * pixels);
 | |
| extern RwImage     *RwImageSetPalette(RwImage * image, RwRGBA * palette);
 | |
| 
 | |
|     /* Getting */
 | |
| extern RwInt32      RwImageGetWidth(const RwImage * image);
 | |
| extern RwInt32      RwImageGetHeight(const RwImage * image);
 | |
| extern RwInt32      RwImageGetDepth(const RwImage * image);
 | |
| extern RwInt32      RwImageGetStride(const RwImage * image);
 | |
| extern RwUInt8     *RwImageGetPixels(const RwImage * image);
 | |
| extern RwRGBA      *RwImageGetPalette(const RwImage * image);
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
|     /* Get device dependent pixel value */
 | |
| extern RwUInt32     RwRGBAToPixel(RwRGBA * rgbIn, RwInt32 rasterFormat);
 | |
| extern RwRGBA      *RwRGBASetFromPixel(RwRGBA * rgbOut,
 | |
|                                        RwUInt32 pixelValue,
 | |
|                                        RwInt32 rasterFormat);
 | |
| 
 | |
|     /* Gamma correction */
 | |
| extern RwBool       RwImageSetGamma(RwReal gammaValue);
 | |
| extern RwReal       RwImageGetGamma(void);
 | |
| extern RwImage     *RwImageGammaCorrect(RwImage * image);
 | |
| 
 | |
|     /* Adding and removing gamma correction */
 | |
| extern RwRGBA      *RwRGBAGammaCorrect(RwRGBA * rgb);
 | |
| 
 | |
|     /* Attaching toolkits */
 | |
| extern RwInt32      RwImageRegisterPlugin(RwInt32 size, RwUInt32 pluginID,
 | |
|                                           RwPluginObjectConstructor
 | |
|                                           constructCB,
 | |
|                                           RwPluginObjectDestructor
 | |
|                                           destructCB,
 | |
|                                           RwPluginObjectCopy copyCB);
 | |
| extern RwInt32      RwImageGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool       RwImageValidatePlugins(const RwImage * image);
 | |
| 
 | |
| extern RwBool       RwImageRegisterImageFormat(const RwChar * extension,
 | |
|                                                RwImageCallBackRead
 | |
|                                                imageRead,
 | |
|                                                RwImageCallBackWrite
 | |
|                                                imageWrite);
 | |
| 
 | |
|     /* Finding an extension for an image to load */
 | |
| extern const RwChar *RwImageFindFileType(const RwChar * imageName);
 | |
| 
 | |
|     /* Reading and writing images to streams */
 | |
| extern RwInt32      RwImageStreamGetSize(const RwImage * image);
 | |
| extern RwImage     *RwImageStreamRead(RwStream * stream);
 | |
| extern const RwImage *RwImageStreamWrite(const RwImage * image,
 | |
|                                          RwStream * stream);
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/batextur.h ---*/
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* Type ID */
 | |
| #define rwTEXDICTIONARY 6
 | |
| 
 | |
| /* Mipmap Name generation - maximum number of RwChar characters which can
 | |
|  * be appended to the root name.
 | |
|  */
 | |
| #define rwTEXTUREMIPMAPNAMECHARS    16
 | |
| 
 | |
| /* We define texture names to be a maximum of 16 ISO chars */
 | |
| #define rwTEXTUREBASENAMELENGTH     32
 | |
| 
 | |
| #define rwTEXTUREFILTERMODEMASK     0x000000FF
 | |
| #define rwTEXTUREADDRESSINGUMASK    0x00000F00
 | |
| #define rwTEXTUREADDRESSINGVMASK    0x0000F000
 | |
| #define rwTEXTUREADDRESSINGMASK     (rwTEXTUREADDRESSINGUMASK |  \
 | |
|                                      rwTEXTUREADDRESSINGVMASK)
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwTexDictionary 
 | |
|  * is a texture dictionary containing textures. 
 | |
|  * This should be considered an opaque type.
 | |
|  * Use the RwTexDictionary API functions to access.
 | |
|  */
 | |
| typedef struct RwTexDictionary RwTexDictionary;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RwTexDictionary
 | |
| {
 | |
|     RwObject            object; /* Homogeneous type */
 | |
|     RwLinkList          texturesInDict; /* List of textures in dictionary */
 | |
|     RwLLLink            lInInstance; /* Link list of all dicts in system */
 | |
| };
 | |
| /* Information is entirely device dependent */
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| 
 | |
| /* Parent is the dictionary */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef  RwTexture 
 | |
|  * is a texture object. 
 | |
|  * This should be considered an opaque type.
 | |
|  * Use the RwTexture API functions to access.
 | |
|  */
 | |
| typedef struct RwTexture RwTexture;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RwTexture
 | |
| {
 | |
|     RwRaster           *raster; /** pointer to RwRaster with data */
 | |
|     RwTexDictionary    *dict;   /* Dictionary this texture is in */
 | |
|     RwLLLink            lInDictionary; /* List of textures in this dictionary */
 | |
| 
 | |
|     RwChar              name[rwTEXTUREBASENAMELENGTH];  /* Name of the texture */
 | |
|     RwChar              mask[rwTEXTUREBASENAMELENGTH];  /* Name of the textures mask */
 | |
| 
 | |
|     /* 31 [xxxxxxxx xxxxxxxx vvvvuuuu ffffffff] 0 */
 | |
|     RwUInt32            filterAddressing; /* Filtering & addressing mode flags */
 | |
| 
 | |
|     RwInt32             refCount; /* Reference count, surprisingly enough */
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwTextureCallBackRead 
 | |
|  * represents the function used by \ref RwTextureRead to read the specified
 | |
|  * texture from a disk file. This function should return a pointer to the
 | |
|  * texture to indicate success.
 | |
|  * 
 | |
|  * \param  name   Pointer to a string containing the name of
 | |
|  * the texture to read.
 | |
|  *
 | |
|  * \param  maskName   Pointer to a string containing the name
 | |
|  * of the mask to read and apply to the texture.
 | |
|  *
 | |
|  * \return Pointer to the texture
 | |
|  *
 | |
|  * \see RwTextureSetReadCallBack
 | |
|  * \see RwTextureGetReadCallBack
 | |
|  */
 | |
| typedef RwTexture *(*RwTextureCallBackRead)(const RwChar *name,
 | |
|                                             const RwChar *maskName);
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwTextureCallBack
 | |
|  * represents the function called from \ref RwTexDictionaryForAllTextures
 | |
|  * for all textures in a given texture dictionary. This function should
 | |
|  * return the current texture to indicate success. The callback may return
 | |
|  * NULL to terminate further callbacks on the texture dictionary.
 | |
|  * 
 | |
|  * \param  texture   Pointer to the current texture.
 | |
|  *
 | |
|  * \param  pData   User-defined data pointer.
 | |
|  *
 | |
|  * \return Pointer to the current texture
 | |
|  *
 | |
|  * \see RwTexDictionaryForAllTextures
 | |
|  */
 | |
| typedef RwTexture *(*RwTextureCallBack)(RwTexture *texture, void *pData);
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwTexDictionaryCallBack
 | |
|  * represents the function called from \ref RwTexDictionaryForAllTexDictionaries
 | |
|  * for all texture dictionaries that currently exist. This function should
 | |
|  * return the current texture dictionary to indicate success. The callback may
 | |
|  * return NULL to terminate further callbacks on the texture dictionary. It may
 | |
|  * safely destroy the current texture dictionary without adversely affecting
 | |
|  * the iteration process.
 | |
|  * 
 | |
|  * \param  dict   Pointer to the current texture dictionary.
 | |
|  *
 | |
|  * \param  pData   User-defined data pointer.
 | |
|  *
 | |
|  * \return Pointer to the current texture dictionary
 | |
|  *
 | |
|  * \see RwTexDictionaryForAllTexdictionaries
 | |
|  */
 | |
| typedef RwTexDictionary *(*RwTexDictionaryCallBack)(RwTexDictionary *dict, void *data);
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwTextureCallBackMipmapGeneration 
 | |
|  * is the callback function supplied to \ref RwTextureSetMipmapGenerationCallBack 
 | |
|  * and returned from \ref RwTextureGetMipmapGenerationCallBack.
 | |
|  *
 | |
|  * The supplied function will be passed a pointer to a raster and an image.
 | |
|  * The raster is the target for the generated mipmap levels and the image 
 | |
|  * provides the base for their generation.
 | |
|  * 
 | |
|  * \param  raster   Pointer to raster, the target for generated mipmap levels
 | |
|  * \param  image    Pointer to image, used to generate mipmap levels.
 | |
|  * 
 | |
|  * \return
 | |
|  * Returns a pointer to the raster if successful or NULL if an error occurred.
 | |
|  * 
 | |
|  * \see RwTextureSetMipmapGenerationCallBack
 | |
|  * \see RwTextureGetMipmapGenerationCallBack
 | |
|  * \see RwTextureSetAutoMipmapping
 | |
|  * \see RwTextureGetAutoMipmapping
 | |
|  */
 | |
| typedef RwRaster *(*RwTextureCallBackMipmapGeneration)(RwRaster * raster,
 | |
|                                                        RwImage * image);
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \ref RwTextureCallBackMipmapName
 | |
|  * is the callback function supplied to \ref RwTextureSetMipmapNameCallBack and
 | |
|  * returned from \ref RwTextureGetMipmapNameCallBack.
 | |
|  *
 | |
|  * The supplied function will be passed a pointer to a root name, a maskName, a mipmap
 | |
|  * level and a format. The function returns TRUE if successful and the root name will have been 
 | |
|  * modified to equal the mipmap name.
 | |
|  * 
 | |
|  * \param  name       Pointer to a string containing the root name of the texture. The 
 | |
|  * mipmap level name is put here.
 | |
|  * \param  maskName   Pointer to a string containing the root mask name of the texture or
 | |
|  * NULL if no mask name is required.
 | |
|  * \param  mipLevel   A value equal to the mipmap level for which the name is required.
 | |
|  * \param  format     A value describing the mipmapping mode. A combination of the bit
 | |
|  * flags rwRASTERFORMATMIPMAP and rwRASTERFORMATAUTOMIPMAP.
 | |
|  * 
 | |
|  * \return
 | |
|  * Returns TRUE if the name is generated successfully or FALSE if an error occurred.
 | |
|  * 
 | |
|  * \see RwTextureGenerateMipmapName
 | |
|  * \see RwTextureSetMipmapNameCallBack
 | |
|  * \see RwTextureGetMipmapNameCallBack
 | |
|  * \see RwTextureSetAutoMipmapping
 | |
|  * \see RwTextureGetAutoMipmapping
 | |
|  */
 | |
| typedef RwBool (*RwTextureCallBackMipmapName)(RwChar *name,
 | |
|                                               RwChar *maskName,
 | |
|                                               RwUInt8 mipLevel,
 | |
|                                               RwInt32 format);
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
|  */
 | |
| 
 | |
| #define RwTextureGetRasterMacro(_tex)                       \
 | |
|     ((_tex)->raster)
 | |
| 
 | |
| #define RwTextureAddRefMacro(_tex)                          \
 | |
|     (((_tex)->refCount++), (_tex))
 | |
| 
 | |
| #define RwTextureAddRefVoidMacro(_tex)                      \
 | |
| MACRO_START                                                 \
 | |
| {                                                           \
 | |
|     (_tex)->refCount++;                                     \
 | |
| }                                                           \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RwTextureGetNameMacro(_tex)                         \
 | |
|     ((_tex)->name)
 | |
| 
 | |
| #define RwTextureGetMaskNameMacro(_tex)                     \
 | |
|     ((_tex)->mask)
 | |
| 
 | |
| #define RwTextureGetDictionaryMacro(_tex)                   \
 | |
|     ((_tex)->dict)
 | |
| 
 | |
| #define RwTextureSetFilterModeMacro(_tex, _filtering)                       \
 | |
|     (((_tex)->filterAddressing =                                            \
 | |
|       ((_tex)->filterAddressing & ~rwTEXTUREFILTERMODEMASK) |               \
 | |
|       (((RwUInt32)(_filtering)) &  rwTEXTUREFILTERMODEMASK)),               \
 | |
|      (_tex))
 | |
| 
 | |
| #define RwTextureGetFilterModeMacro(_tex)                                   \
 | |
|     ((RwTextureFilterMode)((_tex)->filterAddressing &                       \
 | |
|                            rwTEXTUREFILTERMODEMASK))
 | |
| 
 | |
| #define RwTextureSetAddressingMacro(_tex, _addressing)                      \
 | |
|     (((_tex)->filterAddressing =                                            \
 | |
|       ((_tex)->filterAddressing & ~rwTEXTUREADDRESSINGMASK) |               \
 | |
|       (((((RwUInt32)(_addressing)) <<  8) & rwTEXTUREADDRESSINGUMASK) |     \
 | |
|        ((((RwUInt32)(_addressing)) << 12) & rwTEXTUREADDRESSINGVMASK))),    \
 | |
|      (_tex))
 | |
| 
 | |
| #define RwTextureSetAddressingUMacro(_tex, _addressing)                     \
 | |
|     (((_tex)->filterAddressing =                                            \
 | |
|       ((_tex)->filterAddressing & ~rwTEXTUREADDRESSINGUMASK) |              \
 | |
|       (((RwUInt32)(_addressing) << 8) & rwTEXTUREADDRESSINGUMASK)),         \
 | |
|      (_tex))
 | |
| 
 | |
| #define RwTextureSetAddressingVMacro(_tex, _addressing)                     \
 | |
|     (((_tex)->filterAddressing =                                            \
 | |
|       ((_tex)->filterAddressing & ~rwTEXTUREADDRESSINGVMASK) |              \
 | |
|       (((RwUInt32)(_addressing) << 12) & rwTEXTUREADDRESSINGVMASK)),        \
 | |
|      (_tex))
 | |
| 
 | |
| #define RwTextureGetAddressingMacro(_tex)                                   \
 | |
|     (((((_tex)->filterAddressing & rwTEXTUREADDRESSINGUMASK) >>  8) ==      \
 | |
|       (((_tex)->filterAddressing & rwTEXTUREADDRESSINGVMASK) >> 12)) ?      \
 | |
|      ((RwTextureAddressMode)(((_tex)->filterAddressing &                    \
 | |
|                               rwTEXTUREADDRESSINGVMASK) >> 12)) :           \
 | |
|      rwTEXTUREADDRESSNATEXTUREADDRESS)
 | |
| 
 | |
| #define RwTextureGetAddressingUMacro(_tex)                                  \
 | |
|     ((RwTextureAddressMode)(((_tex)->filterAddressing &                     \
 | |
|                              rwTEXTUREADDRESSINGUMASK) >> 8))
 | |
| 
 | |
| #define RwTextureGetAddressingVMacro(_tex)                                  \
 | |
|     ((RwTextureAddressMode)(((_tex)->filterAddressing &                     \
 | |
|                              rwTEXTUREADDRESSINGVMASK) >> 12))
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RwTextureGetRaster(_tex)                            \
 | |
|     RwTextureGetRasterMacro(_tex)
 | |
| 
 | |
| #define RwTextureAddRef(_tex)                               \
 | |
|     RwTextureAddRefMacro(_tex)
 | |
| 
 | |
| #define RwTextureGetName(_tex)                              \
 | |
|     RwTextureGetNameMacro(_tex)
 | |
| 
 | |
| #define RwTextureGetMaskName(_tex)                          \
 | |
|     RwTextureGetMaskNameMacro(_tex)
 | |
| 
 | |
| #define RwTextureGetDictionary(_tex)                        \
 | |
|     RwTextureGetDictionaryMacro(_tex)
 | |
| 
 | |
| #define RwTextureSetFilterMode(_tex, _filtering)            \
 | |
|     RwTextureSetFilterModeMacro(_tex, _filtering)
 | |
| 
 | |
| #define RwTextureGetFilterMode(_tex)                        \
 | |
|     RwTextureGetFilterModeMacro(_tex)
 | |
| 
 | |
| #define RwTextureSetAddressing(_tex, _addressing)           \
 | |
|     RwTextureSetAddressingMacro(_tex, _addressing)
 | |
| 
 | |
| #define RwTextureSetAddressingU(_tex, _addressing)          \
 | |
|     RwTextureSetAddressingUMacro(_tex, _addressing)
 | |
| 
 | |
| #define RwTextureSetAddressingV(_tex, _addressing)          \
 | |
|     RwTextureSetAddressingVMacro(_tex, _addressing)
 | |
| 
 | |
| #define RwTextureGetAddressing(_tex)                        \
 | |
|     RwTextureGetAddressingMacro(_tex)
 | |
| 
 | |
| #define RwTextureGetAddressingU(_tex)                       \
 | |
|     RwTextureGetAddressingUMacro(_tex)
 | |
| 
 | |
| #define RwTextureGetAddressingV(_tex)                       \
 | |
|     RwTextureGetAddressingVMacro(_tex)
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
|     /* Reading mip maps */
 | |
| 
 | |
|     /* Setting mip mapping states */
 | |
| extern RwBool       RwTextureSetMipmapping(RwBool enable);
 | |
| extern RwBool       RwTextureGetMipmapping(void);
 | |
| extern RwBool       RwTextureSetAutoMipmapping(RwBool enable);
 | |
| extern RwBool       RwTextureGetAutoMipmapping(void);
 | |
| 
 | |
|     /* Setting and getting the mipmap generation function */
 | |
| extern              RwBool
 | |
| RwTextureSetMipmapGenerationCallBack(RwTextureCallBackMipmapGeneration
 | |
|                                      callback);
 | |
| extern              RwTextureCallBackMipmapGeneration
 | |
| RwTextureGetMipmapGenerationCallBack(void);
 | |
| 
 | |
|     /* Setting and getting the mipmap file name generation function */
 | |
| extern              RwBool
 | |
| RwTextureSetMipmapNameCallBack(RwTextureCallBackMipmapName callback);
 | |
| extern RwTextureCallBackMipmapName RwTextureGetMipmapNameCallBack(void);
 | |
| 
 | |
|     /* Generating mipmaps for a raster */
 | |
| extern RwBool       RwTextureGenerateMipmapName(RwChar * name,
 | |
|                                                 RwChar * maskName,
 | |
|                                                 RwUInt8 mipLevel,
 | |
|                                                 RwInt32 format);
 | |
| extern RwBool       RwTextureRasterGenerateMipmaps(RwRaster * raster,
 | |
|                                                    RwImage * image);
 | |
| 
 | |
|     /* LEGACY-SUPPORT mip mapping */
 | |
| extern RwBool       _rwTextureSetAutoMipMapState(RwBool enable);
 | |
| extern RwBool       _rwTextureGetAutoMipMapState(void);
 | |
| 
 | |
|     /* Setting and getting the callback function */
 | |
| extern RwTextureCallBackRead RwTextureGetReadCallBack(void);
 | |
| extern RwBool       RwTextureSetReadCallBack(RwTextureCallBackRead
 | |
|                                              fpCallBack);
 | |
| 
 | |
|     /* Texture and mask names */
 | |
| extern RwTexture   *RwTextureSetName(RwTexture * texture,
 | |
|                                      const RwChar * name);
 | |
| extern RwTexture   *RwTextureSetMaskName(RwTexture * texture,
 | |
|                                          const RwChar * maskName);
 | |
| 
 | |
|     /* Creating/destroying dictionaries */
 | |
| extern RwTexDictionary *RwTexDictionaryCreate(void);
 | |
| extern RwBool       RwTexDictionaryDestroy(RwTexDictionary * dict);
 | |
| 
 | |
|     /* Textures */
 | |
| extern RwTexture   *RwTextureCreate(RwRaster * raster);
 | |
| extern RwBool       RwTextureDestroy(RwTexture * texture);
 | |
| 
 | |
|     /* Setting and getting texture map rasters */
 | |
| extern RwTexture   *RwTextureSetRaster(RwTexture * texture,
 | |
|                                        RwRaster * raster);
 | |
| 
 | |
|     /* Dictionary access */
 | |
| extern RwTexture   *RwTexDictionaryAddTexture(RwTexDictionary * dict,
 | |
|                                               RwTexture * texture);
 | |
| extern RwTexture   *RwTexDictionaryRemoveTexture(RwTexture * texture);
 | |
| extern RwTexture   *RwTexDictionaryFindNamedTexture(RwTexDictionary *
 | |
|                                                     dict,
 | |
|                                                     const RwChar * name);
 | |
| 
 | |
|     /* Reading a texture */
 | |
| extern RwTexture   *RwTextureRead(const RwChar * name,
 | |
|                                   const RwChar * maskName);
 | |
| 
 | |
|     /* Setting the current dictionary */
 | |
| extern RwTexDictionary *RwTexDictionaryGetCurrent(void);
 | |
| extern RwTexDictionary *RwTexDictionarySetCurrent(RwTexDictionary * dict);
 | |
| 
 | |
|     /* Enumerating textures */
 | |
| extern const RwTexDictionary *RwTexDictionaryForAllTextures(const
 | |
|                                                             RwTexDictionary
 | |
|                                                             * dict,
 | |
|                                                             RwTextureCallBack
 | |
|                                                             fpCallBack,
 | |
|                                                             void *pData);
 | |
| 
 | |
|     /* Enumerating the texture dictionaries currently in the system */
 | |
| extern RwBool RwTexDictionaryForAllTexDictionaries(
 | |
|     RwTexDictionaryCallBack fpCallBack, void *pData);
 | |
| 
 | |
| 
 | |
|     /* Attaching toolkits */
 | |
| extern RwInt32      RwTextureRegisterPlugin(RwInt32 size,
 | |
|                                             RwUInt32 pluginID,
 | |
|                                             RwPluginObjectConstructor
 | |
|                                             constructCB,
 | |
|                                             RwPluginObjectDestructor
 | |
|                                             destructCB,
 | |
|                                             RwPluginObjectCopy copyCB);
 | |
| extern RwInt32      RwTexDictionaryRegisterPlugin(RwInt32 size,
 | |
|                                                   RwUInt32 pluginID,
 | |
|                                                   RwPluginObjectConstructor
 | |
|                                                   constructCB,
 | |
|                                                   RwPluginObjectDestructor
 | |
|                                                   destructCB,
 | |
|                                                   RwPluginObjectCopy
 | |
|                                                   copyCB);
 | |
| extern RwInt32      RwTextureGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwInt32      RwTexDictionaryGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool       RwTextureValidatePlugins(const RwTexture * texture);
 | |
| extern RwBool       RwTexDictionaryValidatePlugins(const RwTexDictionary *
 | |
|                                                    dict);
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| /* Textures */
 | |
| extern RwRaster *RwTextureGetRaster(const RwTexture *texture);
 | |
| extern RwTexture *RwTextureAddRef(RwTexture *texture);
 | |
| 
 | |
| /* Texture and mask names */
 | |
| extern RwChar *RwTextureGetName(RwTexture *texture);
 | |
| extern RwChar *RwTextureGetMaskName(RwTexture *texture);
 | |
| 
 | |
| /* Get owner dictionary */
 | |
| extern RwTexDictionary *RwTextureGetDictionary(RwTexture *texture);
 | |
| 
 | |
| /* Filtering */
 | |
| extern RwTexture *RwTextureSetFilterMode(RwTexture *texture,
 | |
|                                          RwTextureFilterMode filtering);
 | |
| 
 | |
| extern RwTextureFilterMode RwTextureGetFilterMode(const RwTexture *texture);
 | |
| 
 | |
| /* Addressing */
 | |
| extern RwTexture *RwTextureSetAddressing(RwTexture *texture,
 | |
|                                          RwTextureAddressMode addressing);
 | |
| extern RwTexture *RwTextureSetAddressingU(RwTexture *texture,
 | |
|                                           RwTextureAddressMode addressing);
 | |
| extern RwTexture *RwTextureSetAddressingV(RwTexture *texture,
 | |
|                                           RwTextureAddressMode addressing);
 | |
| 
 | |
| extern RwTextureAddressMode RwTextureGetAddressing(const RwTexture *texture);
 | |
| extern RwTextureAddressMode RwTextureGetAddressingU(const RwTexture *texture);
 | |
| extern RwTextureAddressMode RwTextureGetAddressingV(const RwTexture *texture);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RwTextureSetAutoMipMapState(_enable) \
 | |
|     _rwTextureSetAutoMipMapState(_enable)
 | |
| 
 | |
| #define RwTextureGetAutoMipMapState() \
 | |
|     _rwTextureGetAutoMipMapState()
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/p2stdcls.h ---*/
 | |
| 
 | |
| /*
 | |
|  * Current:
 | |
|  *
 | |
|  * wait on Simon for instructions to do cluster renaming thing,
 | |
|  * or go thru and  change all cluster type names and cluster
 | |
|  * names (add CSL?)
 | |
|  *
 | |
|  */
 | |
| 
 | |
| /* CamVerts.csl */
 | |
| 
 | |
| /* clip flags */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \ref RwClipFlag
 | |
|  * Flags specifying the clipping status of a vertex
 | |
|  */
 | |
| enum RwClipFlag
 | |
| {
 | |
|     rwXLOCLIP   = 0x01, /**<The vertex is outside the low X clip-plane */
 | |
|     rwXHICLIP   = 0x02, /**<The vertex is outside the high X clip-plane */
 | |
|     rwXCLIP     = 0x03, /**<The vertex is outside an X clip-plane */
 | |
| 
 | |
|     rwYLOCLIP   = 0x04, /**<The vertex is outside the low Y clip-plane */
 | |
|     rwYHICLIP   = 0x08, /**<The vertex is outside the high Z clip-plane */
 | |
|     rwYCLIP     = 0x0C, /**<The vertex is outside a Y clip-plane */
 | |
| 
 | |
|     rwZLOCLIP   = 0x10, /**<The vertex is outside the low Z clip-plane */
 | |
|     rwZHICLIP   = 0x20, /**<The vertex is outside the high Z clip-plane */
 | |
|     rwZCLIP     = 0x30, /**<The vertex is outside a Z clip-plane */
 | |
| 
 | |
|     rwCLIPMASK  = 0x3F, /**<Mask covering all used bits in the clip flags
 | |
|                          * in case a plugin  wants free ones to use (e.g RpGloss) */
 | |
| 
 | |
|     rwCLIPFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwClipFlag RwClipFlag;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RwClipFlag
 | |
|  * Typedef for RwClipFlag enumeration specifying the clipping status of a vertex
 | |
|  */
 | |
| 
 | |
| 
 | |
| typedef struct RxCamSpace3DVertex RxCamSpace3DVertex;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxCamSpace3DVertex
 | |
|  * Structure describing a camera-space 3D vertex.
 | |
|  */
 | |
| struct RxCamSpace3DVertex
 | |
| {
 | |
|     /* Position in sheared camera-space (pre-projection) */
 | |
|     RwV3d           cameraVertex; /**< \ref RwV3d camera-space position of the vertex */
 | |
|     /* Clip flags on this vertex */
 | |
|     RwUInt8         clipFlags;    /**< Clip flags for the vertex generated during transformation into camera-space, see \ref RwClipFlag */
 | |
|     RwUInt8         pad[3];       /**< Alignment padding */
 | |
|     /* Lit colour */
 | |
|     RwRGBAReal      col;          /**< Accumulated \ref RwReal light values (initialized to zero or prelight colours) */
 | |
|     /* Only used by the clipper */
 | |
|     RwReal          u;            /**< Texture U coordinate */
 | |
|     RwReal          v;            /**< Texture V coordinate */
 | |
| };
 | |
| 
 | |
| /* Supports pipeline1 apps: */
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwCameraVertex
 | |
|  * typedef for a structure describing a camera-space 3D vertex.
 | |
|  */
 | |
| typedef RxCamSpace3DVertex RwCameraVertex;
 | |
| 
 | |
| /* (used during lighting) Doesn't use alpha yet, but it will */
 | |
| #define RxCamSpace3DVertexSetRGBA(camvert, r, g, b, a)  \
 | |
| MACRO_START                                             \
 | |
| {                                                       \
 | |
|     ((camvert)->col.red = (r));                         \
 | |
|     ((camvert)->col.green = (g));                       \
 | |
|     ((camvert)->col.blue = (b));                        \
 | |
|     ((camvert)->col.alpha = (a));                       \
 | |
| }                                                       \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RxCamSpace3DVertexAddRGBA(camvert, r, g, b, a)  \
 | |
| MACRO_START                                             \
 | |
| {                                                       \
 | |
|     ((camvert)->col.red += (r));                        \
 | |
|     ((camvert)->col.green += (g));                      \
 | |
|     ((camvert)->col.blue += (b));                       \
 | |
|     ((camvert)->col.alpha += (a));                      \
 | |
| }                                                       \
 | |
| MACRO_STOP
 | |
| 
 | |
| /* LEGACY-SUPPORT macros */
 | |
| #define RXCAMSPACE3DVERTEXSetRGBA(camvert, r, g, b, a)  \
 | |
|     RxCamSpace3DVertexSetRGBA(camvert, r, g, b, a)
 | |
| #define RXCAMSPACE3DVERTEXAddRGBA(camvert, r, g, b, a)  \
 | |
|     RxCamSpace3DVertexAddRGBA(camvert, r, g, b, a)
 | |
| 
 | |
| /* MeshState.csl */
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \ref RxGeometryFlag
 | |
|  * Flags describing geometry properties
 | |
|  */
 | |
| enum RxGeometryFlag
 | |
| {
 | |
|     rxGEOMETRY_TRISTRIP      = 0x01,  /**<This geometry's meshes can be rendered as tri-strips */
 | |
|     rxGEOMETRY_POSITIONS     = 0x02,  /**<This geometry has positions */
 | |
|     rxGEOMETRY_TEXTURED      = 0x04,  /**<This geometry has textures applied */
 | |
|     rxGEOMETRY_PRELIT        = 0x08,  /**<This geometry has luminance values */
 | |
|     rxGEOMETRY_NORMALS       = 0x10,  /**<This geometry has normals */
 | |
|     rxGEOMETRY_LIGHT         = 0x20,  /**<This geometry will be lit */
 | |
|     rxGEOMETRY_MODULATE      = 0x40,  /**<This geometry will modulate the material color with the vertex colors (prelit + lit) */
 | |
|     rxGEOMETRY_TEXTURED2     = 0x80,  /**<This geometry has 2 set of texture coordinates */
 | |
| 
 | |
|     rxGEOMETRY_COLORED       = 0x100, /**<This mesh specifies per-vertex colors. NB: ONLY USED IN IM3D */
 | |
| 
 | |
|     rxGEOMETRYFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxGeometryFlag
 | |
|  * Typedef for RxGeometryFlag enumeration describing geometry properties
 | |
|  */
 | |
| typedef enum RxGeometryFlag RxGeometryFlag;
 | |
| 
 | |
| typedef struct RxMeshStateVector RxMeshStateVector;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxMeshStateVector
 | |
|  * Structure describing a mesh-state vector,
 | |
|  * used by the RxClMeshState cluster
 | |
|  */
 | |
| struct RxMeshStateVector
 | |
| {
 | |
|     RwInt32             Flags;              /**< \ref RxGeometryFlag Flags from the source geometry */
 | |
|     void               *SourceObject;       /**< A void pointer. In immediate mode it points to an
 | |
|                                              * internal structure and in atomic/world-sector object
 | |
|                                              * or material pipelines it points to an \ref RpMaterial. */
 | |
|     RwMatrix            Obj2World;          /**< \ref RwMatrix to transform from object-space to world-space */
 | |
|     RwMatrix            Obj2Cam;            /**< \ref RwMatrix to transform from object-space to camera-space */
 | |
|     RwSurfaceProperties SurfaceProperties;  /**< \ref RwSurfaceProperties */
 | |
|     /* We can't necessarily reference an RpMaterial in here (i.e with Im3D),
 | |
|      * because RpMaterials are defined in RpWorld not RwCore */
 | |
|     RwTexture          *Texture;            /**< A pointer to a \ref RwTexture */
 | |
|     RwRGBA              MatCol;             /**< \ref RwRGBA material colour */
 | |
|     RxPipeline         *Pipeline;           /**< A pointer to the material pipeline where appropriate */
 | |
|     /* rwPRIMTYPETRILIST/TRIFAN/TRISTRIP/LINELIST/POLYLINE */
 | |
|     RwPrimitiveType     PrimType;           /**< \ref RwPrimitiveType primitive type */
 | |
|     /* Interpretation based on PrimType */
 | |
|     RwUInt32            NumElements;        /**< \ref RwUInt32 number of elements (triangles, lines...) */
 | |
|     RwUInt32            NumVertices;        /**< \ref RwUInt32 number of vertices */
 | |
|     RwInt32             ClipFlagsOr;        /**< Boolean OR of the \ref RwClipFlag clip flags of all vertices in the mesh */
 | |
|     RwInt32             ClipFlagsAnd;       /**< Boolean AND of the \ref RwClipFlag clip flags of all vertices in the mesh */
 | |
|     void               *SourceMesh;         /**< A void pointer to the source \ref RpMesh */
 | |
|     void               *DataObject;         /**< Mirrors the void data pointer of \ref RxPipelineExecute */
 | |
| };
 | |
| 
 | |
| /* RxScatter.csl */
 | |
| typedef struct RxScatter RxScatter;
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxScatter
 | |
|  * Structure used by the RxClScatter cluster
 | |
|  */
 | |
| struct RxScatter
 | |
| {
 | |
|     RxPipeline    *pipeline; /**< \ref RxPipeline pointer, causes Scatter.csl
 | |
|                               * to spit the packet out to the specified pipeline */
 | |
|     RxPipelineNode *node;    /**< \ref RxPipelineNode pointer, causes Scatter.csl
 | |
|                               * to send the packet to the specified PipelineNode
 | |
|                               * (as long as it is actually one of its outputs!) */
 | |
| };
 | |
| 
 | |
| /* RxInterpolants.csl */
 | |
| typedef struct RxInterp RxInterp;
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxInterp
 | |
|  * Structure used by the RxClInterp cluster
 | |
|  */
 | |
| struct RxInterp
 | |
| {
 | |
|     RxVertexIndex originalVert; /**< \ref RxVertexIndex index to the new vertex generated on the clipped edge */
 | |
|     RxVertexIndex parentVert1;  /**< \ref RxVertexIndex index to the first vertex of the clipped edge */
 | |
|     RxVertexIndex parentVert2;  /**< \ref RxVertexIndex index to the second vertex of the clipped edge */
 | |
|     RwReal        interp;       /**< \ref RwReal interpolant along the clipped edge */
 | |
| };
 | |
| 
 | |
| /* RxUVs.csl */
 | |
| typedef struct RxUV RxUV;
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxUV
 | |
|  * Structure used by the RxClUV cluster
 | |
|  */
 | |
| struct RxUV
 | |
| {
 | |
|     RwReal u; /**< \ref RwReal U texture coordinate */
 | |
|     RwReal v; /**< \ref RwReal V texture coordinate */
 | |
| };
 | |
| 
 | |
| /* RxTriPlanes.csl */
 | |
| typedef struct RxTriPlane RxTriPlane;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxTriPlane
 | |
|  * for the packed plane structure used in RpWorlds and by the RxClTriPlane cluster
 | |
|  * NOTE: this is currently not used in any nodes that ship with the SDK
 | |
|  */
 | |
| struct RxTriPlane
 | |
| {
 | |
|     /* Packed plane format used in RpWorlds */
 | |
|     RwUInt32 N; /**< \ref RwUInt32 Packed normal */
 | |
|     RwReal   w; /**< \ref RwReal distance from origin */
 | |
| };
 | |
| 
 | |
| /* RxVSteps.csl */
 | |
| 
 | |
| #if (defined(_MSC_VER))
 | |
| #  if (_MSC_VER>=1000)
 | |
| #    pragma pack(push, 1)
 | |
| #  endif /* (_MSC_VER>=1000) */
 | |
| #endif /* (defined(_MSC_VER)) */
 | |
| 
 | |
| typedef struct RxVStep RxVStep;
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \struct RxVStep
 | |
|  * Structure used by the RxClVStep cluster.
 | |
|  * To use the step values in the RxClVStep cluster, start at the beginning
 | |
|  * of the RxVStep and vertex arrays and proceed as follows: (a) Process one
 | |
|  * vertex, (b) Skip 'step' vertices, (c) Increment the cursor of the RxClVStep
 | |
|  * cluster. Repeat (a)-(c) until the entire vertex array has been processed.
 | |
|  * If the RxVStep array contains valid data, you should not have to bounds-check
 | |
|  * its cursor.
 | |
|  */
 | |
| struct RxVStep
 | |
| {
 | |
|     RwUInt8 step; /**< \ref RwUInt8 The number of vertices after the current one
 | |
|                    * which can be skipped in lighting and other calculations because,
 | |
|                    * for example, they belong only to back-facing triangles */
 | |
| };
 | |
| 
 | |
| #if (defined(_MSC_VER))
 | |
| #  if (_MSC_VER>=1000)
 | |
| #    pragma pack(pop)
 | |
| #  endif /* (_MSC_VER>=1000) */
 | |
| #endif /* (defined(_MSC_VER)) */
 | |
| 
 | |
| /* CamNorms.csl */
 | |
| /**
 | |
|  * \ingroup rwcoregeneric
 | |
|  * \typedef RxCamNorm
 | |
|  * typedef for \ref RwV3d used by the RxClVStep cluster */
 | |
| typedef RwV3d RxCamNorm;
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Uses the RxObjSpace3DVertex type (see pipmodel.h) */
 | |
| extern RxClusterDefinition RxClObjSpace3DVertices;
 | |
| /* Uses the RxCamSpace3DVertex type */
 | |
| extern RxClusterDefinition RxClCamSpace3DVertices;
 | |
| /* Uses the RxScrSpace2DVertex type (see pipmodel.h) */
 | |
| extern RxClusterDefinition RxClScrSpace2DVertices;
 | |
| /* Uses the RxInterp type */
 | |
| extern RxClusterDefinition RxClInterpolants;
 | |
| /* Uses the RxMeshStateVector type */
 | |
| extern RxClusterDefinition RxClMeshState;
 | |
| /* Uses the RxRenderStateVector type (p2renderstate.c/h) */
 | |
| extern RxClusterDefinition RxClRenderState;
 | |
| /* Uses the RxVertexIndex type */
 | |
| extern RxClusterDefinition RxClIndices;
 | |
| /* Uses the RxScatter type */
 | |
| extern RxClusterDefinition RxClScatter;
 | |
| /* Uses the RxUV type */
 | |
| extern RxClusterDefinition RxClUVs;
 | |
| /* Uses the RxVStep type */
 | |
| extern RxClusterDefinition RxClVSteps;
 | |
| /* Uses the RwRGBAReal type */
 | |
| extern RxClusterDefinition RxClRGBAs;
 | |
| /* Uses the RxCamNorm type */
 | |
| extern RxClusterDefinition RxClCamNorms;
 | |
| 
 | |
| /* Uses the RxTriPlane type.
 | |
|  * NOTE: this is currently not used in any nodes that ship with the SDK */
 | |
| extern RxClusterDefinition RxClTriPlanes;
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/baim3d.h ---*/
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * RwIm3DTransformFlags
 | |
|  *  The bit-field type  RwIm3DTransformFlags
 | |
|  * specifies options available for controlling execution of the 3D immediate
 | |
|  * mode pipeline (see API function \ref RwIm3DTransform):*/
 | |
| enum RwIm3DTransformFlags
 | |
| {
 | |
|     rwIM3D_VERTEXUV      = 1,   /**<Texture coordinates in source vertices should be used */
 | |
|     rwIM3D_ALLOPAQUE     = 2,   /**<All source vertices are opaque (alpha is 255) */
 | |
|     rwIM3D_NOCLIP        = 4,   /**<No clipping should be performed on the geometry (the
 | |
|                                  * app may know it is all onscreen or within the guard band clipping
 | |
|                                  * region for the current hardware, so clipping can be skipped) */
 | |
|     rwIM3D_VERTEXXYZ     = 8,   /**<Vertex positions */
 | |
|     rwIM3D_VERTEXRGBA    = 16,  /**<Vertex color */
 | |
| 
 | |
|     rwIM3DTRANSFORMFLAGSFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwIm3DTransformFlags RwIm3DTransformFlags;
 | |
| 
 | |
| 
 | |
| 
 | |
| typedef struct rwIm3DPool            rwIm3DPool;
 | |
| typedef struct rwImmediGlobals       rwImmediGlobals;
 | |
| typedef struct rwIm3DRenderPipelines rwIm3DRenderPipelines;
 | |
| typedef struct _rwIm3DPoolStash       _rwIm3DPoolStash;
 | |
| 
 | |
| #if (0 && defined(SKY2))
 | |
| typedef struct rwIm3DVertexCache     RwIm3DVertexCache;
 | |
| #endif /* (0&& defined(SKY2)) */
 | |
| 
 | |
| /* complete information to reconstruct post-transform Im3D "mesh" packet */
 | |
| struct _rwIm3DPoolStash
 | |
| {
 | |
|     RwUInt32                 flags;    /* rwIM3D_VERTEXUV, rwIM3D_ALLOPAQUE, rwIM3D_NOCLIP etc */
 | |
|     RwMatrix                *ltm;      /* world-space frame of the vertices, if they have one */
 | |
|     RwUInt32                 numVerts;
 | |
|     RxObjSpace3DVertex      *objVerts;
 | |
|     RxCamSpace3DVertex      *camVerts;
 | |
|     RxScrSpace2DVertex      *devVerts;
 | |
|     RxMeshStateVector       *meshState;
 | |
|     RxRenderStateVector     *renderState;
 | |
|     RxPipeline              *pipeline;
 | |
|     RwPrimitiveType          primType;
 | |
|     RxVertexIndex           *indices;
 | |
|     RwUInt32                 numIndices;
 | |
| };
 | |
| 
 | |
| /* Used as a cache of transformed vertices */
 | |
| struct rwIm3DPool
 | |
| {
 | |
|     RwUInt16         numElements; /* could become RwUInt32 nowadays */
 | |
|     RwUInt16         pad;         /* alignment padding */
 | |
|     void            *elements;    /* the original array of verts (or whatever...) - referenced not copied */
 | |
|     RwInt32          stride;      /* the stride of the element */
 | |
|     _rwIm3DPoolStash  stash;
 | |
| };
 | |
| 
 | |
| struct rwIm3DRenderPipelines
 | |
| {
 | |
|     /* One Im3D render pipeline pointer per rwPRIMTYPE
 | |
|      * (several pointers may point to the same pipeline though) */
 | |
|     RxPipeline *triList;
 | |
|     RxPipeline *triFan;
 | |
|     RxPipeline *triStrip;
 | |
|     RxPipeline *lineList;
 | |
|     RxPipeline *polyLine;
 | |
|     RxPipeline *pointList;
 | |
| };
 | |
| 
 | |
| struct rwImmediGlobals
 | |
| {
 | |
|     RxPipeline           *genericIm3DTransformPipeline;
 | |
|     rwIm3DRenderPipelines genericIm3DRenderPipelines;
 | |
| 
 | |
|     RxPipeline           *im3DTransformPipeline;
 | |
|     rwIm3DRenderPipelines im3DRenderPipelines;
 | |
| 
 | |
|     /* Platforms that have their own non-generic pipelines
 | |
|      * (OPENGL, D3D7, SKY2, KAMUI2, DOLPHIN) put them here: */
 | |
|     RxPipeline           *platformIm3DTransformPipeline;
 | |
|     rwIm3DRenderPipelines platformIm3DRenderPipelines;
 | |
| 
 | |
| #if (defined(SKY2_DRVMODEL_H))
 | |
|     /* The triangle PS2All render pipe automatically
 | |
|      * calls this PS2AllMat pipeline: */
 | |
|     RxPipeline           *ps2AllMatIm3DTrianglePipeline;
 | |
|     /* The line PS2All render pipe automatically
 | |
|      * calls this PS2AllMat pipeline: */
 | |
|     RxPipeline           *ps2AllMatIm3DLinePipeline;
 | |
|     /* PS2Manager pipelines */
 | |
|     RxPipeline           *ps2ManagerIm3DRenderPipeline;
 | |
| #endif /* (defined(SKY2_DRVMODEL_H)) */
 | |
| 
 | |
|     rwIm3DPool   curPool;              /* The current cache of transformed vertices */
 | |
| };
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern rwIm3DPool *_rwIm3DGetPool( void );
 | |
| 
 | |
| extern void  *RwIm3DTransform(RwIm3DVertex *pVerts, RwUInt32 numVerts,
 | |
|                               RwMatrix *ltm, RwUInt32 flags);
 | |
| extern RwBool RwIm3DEnd(void);
 | |
| 
 | |
| extern RwBool RwIm3DRenderLine(RwInt32 vert1, RwInt32 vert2);
 | |
| extern RwBool RwIm3DRenderTriangle(RwInt32 vert1, RwInt32 vert2,
 | |
|                                    RwInt32 vert3);
 | |
| extern RwBool RwIm3DRenderIndexedPrimitive(RwPrimitiveType primType,
 | |
|                                            RwImVertexIndex *indices,
 | |
|                                            RwInt32 numIndices);
 | |
| extern RwBool RwIm3DRenderPrimitive(RwPrimitiveType primType);
 | |
| 
 | |
| extern RxPipeline *RwIm3DGetGenericTransformPipeline(void);
 | |
| extern RxPipeline *RwIm3DGetGenericRenderPipeline(RwPrimitiveType primType);
 | |
| 
 | |
| extern RxPipeline *RwIm3DGetTransformPipeline(void);
 | |
| extern RxPipeline *RwIm3DGetRenderPipeline(   RwPrimitiveType  primType);
 | |
| extern RxPipeline *RwIm3DSetTransformPipeline(RxPipeline *pipeline);
 | |
| extern RxPipeline *RwIm3DSetRenderPipeline(   RxPipeline *pipeline,
 | |
|                                               RwPrimitiveType primType);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/d3d8/im3dpipe.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/d3d8dxttex.h ---*/
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RwTexture *RwD3D8DDSTextureRead(const RwChar *name, const RwChar *maskname);
 | |
| 
 | |
| extern RwBool RwD3D8RasterIsCompressed(const RwRaster *raster);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/d3d8/drvfns.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| /*******/
 | |
| /* API */
 | |
| /*******/
 | |
| 
 | |
| /* Reports on whether D3D8 can render S3TC textures */
 | |
| extern RwBool 
 | |
| RwD3D8DeviceSupportsDXTTexture(void);
 | |
| 
 | |
| /* Get handle to D3D8 device - useful for setting D3D8 renderstate*/
 | |
| extern void *
 | |
| RwD3D8GetCurrentD3DDevice(void);
 | |
| 
 | |
| /* Get maximun number of multisampling levels */
 | |
| extern RwUInt32
 | |
| RwD3D8EngineGetMaxMultiSamplingLevels(void);
 | |
| 
 | |
| /* Set number of multisampling levels */
 | |
| extern void
 | |
| RwD3D8EngineSetMultiSamplingLevels(RwUInt32 numLevels);
 | |
| 
 | |
| /* Set maximun full screen refresh rate */
 | |
| extern void
 | |
| RwD3D8EngineSetRefreshRate(RwUInt32 refreshRate);
 | |
| 
 | |
| /* Get handle to D3D8 rendering surface - useful for advanced blit ops */
 | |
| extern void *
 | |
| RwD3D8GetCurrentD3DRenderTarget(void);
 | |
| 
 | |
| /* Atach a window to a camera */
 | |
| extern RwBool
 | |
| RwD3D8CameraAttachWindow(void *camera, void *hwnd);
 | |
| 
 | |
| /* Immediate mode rendering */
 | |
| extern RwBool       RwD3D8SetVertexShader(RwUInt32 handle);
 | |
| extern RwBool       RwD3D8SetPixelShader(RwUInt32 handle);
 | |
| extern RwBool       RwD3D8SetStreamSource(RwUInt32 streamNumber, void *streamData, RwUInt32 stride);
 | |
| extern RwBool       RwD3D8SetIndices(void *indexData, RwUInt32 baseVertexIndex);
 | |
| 
 | |
| extern RwBool       RwD3D8DrawIndexedPrimitiveUP(RwUInt32 primitiveType,
 | |
|                                                   RwUInt32 minIndex,
 | |
|                                                   RwUInt32 numVertices,
 | |
|                                                   RwUInt32 numIndices,
 | |
|                                                   const void* indexData,
 | |
|                                                   const void* vertexStreamZeroData,
 | |
|                                                   RwUInt32 VertexStreamZeroStride);
 | |
| 
 | |
| extern RwBool       RwD3D8DrawPrimitiveUP(RwUInt32 primitiveType,
 | |
|                                                   RwUInt32 numVertices,
 | |
|                                                   const void* vertexStreamZeroData,
 | |
|                                                   RwUInt32 VertexStreamZeroStride);
 | |
| 
 | |
| extern RwBool       RwD3D8DrawIndexedPrimitive(RwUInt32 primitiveType,
 | |
|                                                   RwUInt32 minIndex,
 | |
|                                                   RwUInt32 numVertices,
 | |
|                                                   RwUInt32 startIndex,
 | |
|                                                   RwUInt32 numIndices);
 | |
| 
 | |
| extern RwBool       RwD3D8DrawPrimitive(RwUInt32 primitiveType,
 | |
|                                                   RwUInt32 startVertex,
 | |
|                                                   RwUInt32 numVertices);
 | |
| 
 | |
| extern RwBool       RwD3D8SetTexture(RwTexture *texture, RwUInt32 stage);
 | |
| 
 | |
| extern RwBool       RwD3D8SetRenderState(RwUInt32 state, RwUInt32 value);
 | |
| extern RwBool       RwD3D8SetTextureStageState(RwUInt32 stage, RwUInt32 type, RwUInt32 value);
 | |
| extern RwBool       RwD3D8SetTransform(RwUInt32 state, const void *matrix);
 | |
| extern RwBool       RwD3D8SetMaterial(const void *material);
 | |
| extern void         RwD3D8SetStencilClear(RwUInt32 stencilClear);
 | |
| 
 | |
| 
 | |
| extern void         RwD3D8GetRenderState(RwUInt32 state, void *value);
 | |
| extern void         RwD3D8GetTextureStageState(RwUInt32 stage, RwUInt32 type, void *value);
 | |
| extern void         RwD3D8GetTransform(RwUInt32 state, void *matrix);
 | |
| extern RwUInt32     RwD3D8GetStencilClear(void);
 | |
| 
 | |
| /*
 | |
|  * To convert between RwMatrix to D3DMATRIX when setting the
 | |
|  * world matrix
 | |
|  */
 | |
| extern RwBool       RwD3D8SetTransformWorld(const RwMatrix *matrix);
 | |
| 
 | |
| /*
 | |
|  * To convert between RpMaterial to D3DMATERIAL8
 | |
|  */
 | |
| extern RwBool       RwD3D8SetSurfaceProperties(const RwRGBA *color,
 | |
|                                                 const RwSurfaceProperties *surfaceProps,
 | |
|                                                 RwBool modulate);
 | |
| 
 | |
| /*
 | |
|  * To set on that index the light from the descriptor
 | |
|  */
 | |
| extern RwBool       RwD3D8SetLight(RwInt32 index, const void *light);
 | |
| extern void         RwD3D8GetLight(RwInt32 index, void *light);
 | |
| 
 | |
| extern RwBool       RwD3D8EnableLight(RwInt32 index, RwBool enable);
 | |
| 
 | |
| /*
 | |
|  * To get a pointer to a Dynamic vertex buffer
 | |
|  * Use both functions, Create and Destroy, not only Create
 | |
|  */
 | |
| extern RwBool RwD3D8DynamicVertexBufferCreate(RwUInt32 fvf, RwUInt32 size,
 | |
|                                                void **vertexBuffer);
 | |
| 
 | |
| extern void RwD3D8DynamicVertexBufferDestroy(void *vertexBuffer);
 | |
| 
 | |
| /*
 | |
|  * To get a temporary pointer to a Dynamic vertex buffer memory
 | |
|  * Don't use with the previous functions because
 | |
|  * it mantains an internal list of dinamic vertex buffers
 | |
|  */
 | |
| extern RwBool RwD3D8DynamicVertexBufferLock(RwUInt32 vertexSize,
 | |
|                                             RwUInt32 numVertex,
 | |
|                                             void **vertexBufferOut,
 | |
|                                             void **vertexDataOut,
 | |
|                                             RwUInt32 *baseIndexOut);
 | |
| 
 | |
| extern RwBool RwD3D8DynamicVertexBufferUnlock(void *vertexBuffer);
 | |
| 
 | |
| /*
 | |
|  * To get a pointer to an Index vertex buffer
 | |
|  * It's created as WRITEONLY, MANAGED and D3DFMT_INDEX16
 | |
|  */
 | |
| extern RwBool RwD3D8IndexBufferCreate(RwUInt32 numIndices,
 | |
|                                        void **indexBuffer);
 | |
| 
 | |
| /*
 | |
|  * To create a vertex shader from the declaration, also the function
 | |
|  * for deleting it.
 | |
|  */
 | |
| extern RwBool RwD3D8CreateVertexShader(const RwUInt32 *declaration,
 | |
|                                       const RwUInt32 *function,
 | |
|                                       RwUInt32 *handle,
 | |
|                                       RwUInt32 usage);
 | |
| 
 | |
| extern void RwD3D8DeleteVertexShader(RwUInt32 handle);
 | |
| 
 | |
| extern RwBool RwD3D8SetVertexShaderConstant(RwUInt32 registerAddress,
 | |
|                                           const void *constantData,
 | |
|                                           RwUInt32  constantCount);
 | |
| 
 | |
| /*
 | |
|  * To create a pixel shader from the function, also the function
 | |
|  * for deleting it.
 | |
|  */
 | |
| extern RwBool RwD3D8CreatePixelShader(const RwUInt32 *function, RwUInt32 *handle);
 | |
| 
 | |
| extern void RwD3D8DeletePixelShader(RwUInt32 handle);
 | |
| 
 | |
| extern RwBool RwD3D8SetPixelShaderConstant(RwUInt32 registerAddress,
 | |
|                                           const void *constantData,
 | |
|                                           RwUInt32  constantCount);
 | |
| 
 | |
| /*
 | |
|  * Get a const pointer to the D3DCAPS8 struct, (you need to do the cast)
 | |
|  */
 | |
| extern const void *RwD3D8GetCaps(void);
 | |
| 
 | |
| /*
 | |
|  * Check if the sphere is fully inside of the frustum
 | |
|  */
 | |
| extern RwBool RwD3D8CameraIsSphereFullyInsideFrustum(const void *camera, const void *sphere);
 | |
| 
 | |
| /*
 | |
|  * Check if the Bounding Box is fully inside of the frustum
 | |
|  */
 | |
| extern RwBool RwD3D8CameraIsBBoxFullyInsideFrustum(const void *camera, const void *boundingBox);
 | |
| 
 | |
| /*
 | |
|  * Cheking the CPU capabilities
 | |
|  */
 | |
| 
 | |
| extern RwBool _rwIntelSSEsupported(void);
 | |
| extern RwBool _rwIntelMMXsupported(void);
 | |
| 
 | |
| /*
 | |
|  * Enabling texture format conversions when loading textures from a texture
 | |
|  * dictionary. FALSE by default.
 | |
|  */
 | |
| extern void
 | |
| _rwD3D8TexDictionaryEnableRasterFormatConversion(RwBool enable);
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /* LEGACY-MACRO */
 | |
| /**
 | |
|  * \ingroup rwcoredriverd3d8
 | |
|  * \ref RwD3DLoadNativeTexture is a legacy macro for compatability with
 | |
|  * RWD3D7 applications that can be used to read a compressed texture from
 | |
|  * the specified DDS file on disk.
 | |
|  *
 | |
|  * It is recommended that applications for RWD3D8 should use the RWD3D8
 | |
|  * function \ref RwD3D8DDSTextureRead instead.
 | |
|  *
 | |
|  * \param name Pointer to a string containing the name of the texture to be read.
 | |
|  * \param maskname  Pointer to a string containing the name of the mask or
 | |
|  * NULL if not required.
 | |
|  *
 | |
|  * \return Returns pointer to the new texture if successful or NULL if there
 | |
|  * is an error.
 | |
|  *
 | |
|  * \see RwD3D8DDSTextureRead
 | |
|  * \see RwD3D8DeviceSupportsDXTTexture
 | |
|  * \see RwImageSetPath
 | |
|  * \see RwTextureSetReadCallBack
 | |
|  * \see RwTextureSetMipmapping
 | |
|  * \see RwTextureSetAutoMipmapping
 | |
|  * \see RwTextureDestroy
 | |
|  *
 | |
|  */
 | |
| #define RwD3DLoadNativeTexture RwD3D8DDSTextureRead
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/baresamp.h ---*/
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RwImage *RwImageResample(RwImage *dstImage, const RwImage *srcImage);
 | |
| extern RwImage *RwImageCreateResample(const RwImage *srcImage, RwInt32 width,
 | |
|                                                                RwInt32 height);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/baimras.h ---*/
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Images from rasters */
 | |
| extern RwImage *RwImageSetFromRaster(RwImage *image, RwRaster *raster);
 | |
| 
 | |
| /* Rasters from images */
 | |
| extern RwRaster *RwRasterSetFromImage(RwRaster *raster, RwImage *image);
 | |
| 
 | |
| /* Finding raster formats */
 | |
| extern RwRGBA *RwRGBAGetRasterPixel(RwRGBA *rgbOut, RwRaster *raster,
 | |
|                                    RwInt32 x, RwInt32 y);
 | |
| 
 | |
| /* Read a raster */
 | |
| extern RwRaster *RwRasterRead(const RwChar *filename);
 | |
| extern RwRaster *RwRasterReadMaskedRaster(const RwChar *filename, const RwChar *maskname);
 | |
| 
 | |
| /* Finding appropriate raster formats */
 | |
| extern RwImage *RwImageFindRasterFormat(RwImage *ipImage,RwInt32 nRasterType,
 | |
|                                         RwInt32 *npWidth,RwInt32 *npHeight,
 | |
|                                         RwInt32 *npDepth,RwInt32 *npFormat);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/baframe.h ---*/
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| #if (!defined(RWFRAMESTATICPLUGINSSIZE))
 | |
| #define RWFRAMESTATICPLUGINSSIZE 0
 | |
| #endif
 | |
| 
 | |
| #define RWFRAMEALIGNMENT(_frame) \
 | |
|    (! (((rwFRAMEALIGNMENT)-1) & ((RwUInt32)(_frame))))
 | |
| 
 | |
| /* Type ID */
 | |
| #define rwFRAME 0
 | |
| 
 | |
| /* dirty flag bits */
 | |
| #define rwFRAMEPRIVATEHIERARCHYSYNCLTM  0x01
 | |
| #define rwFRAMEPRIVATEHIERARCHYSYNCOBJ  0x02
 | |
| #define rwFRAMEPRIVATESUBTREESYNCLTM    0x04
 | |
| #define rwFRAMEPRIVATESUBTREESYNCOBJ    0x08
 | |
| #define rwFRAMEPRIVATESTATIC            0x10
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RwFrame
 | |
| {
 | |
|     RwObject            object;
 | |
| 
 | |
|     RwLLLink            inDirtyListLink;
 | |
| 
 | |
|     /* Put embedded matrices here to ensure they remain 16-byte aligned */
 | |
|     RwMatrix            modelling;
 | |
|     RwMatrix            ltm;
 | |
| 
 | |
|     RwLinkList          objectList; /* List of objects connected to a frame */
 | |
| 
 | |
|     struct RwFrame      *child;
 | |
|     struct RwFrame      *next;
 | |
|     struct RwFrame      *root;   /* Root of the tree */
 | |
| 
 | |
| #if (RWFRAMESTATICPLUGINSSIZE)
 | |
|     RWALIGN(RwUInt8             pluginData[RWFRAMESTATICPLUGINSSIZE], rwFRAMEALIGNMENT);
 | |
| #endif /* defined(RWFRAMESTATICPLUGINSIZE)) */
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwFrame 
 | |
|    Frame for defining object position and orientation. 
 | |
|  * This should be considered an opaque type.
 | |
|  * Use the RwFrame API functions to access.
 | |
|  */
 | |
| typedef struct RwFrame RWALIGN(RwFrame, rwFRAMEALIGNMENT);
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwFrameCallBack
 | |
|  * \ref RwFrameCallBack type represents the function 
 | |
|  * called from \ref RwFrameForAllChildren for all child frames linked to a given frame.  
 | |
|  * This function should return a pointer to the current frame to indicate success.  
 | |
|  * The callback may return NULL to terminate further callbacks on the child frames.
 | |
|  * 
 | |
|  * \param  frame   Pointer to the current frame, supplied by
 | |
|  * iterator.
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  *
 | |
|  * \see RwFrameForAllChildren
 | |
|  *
 | |
|  */
 | |
| typedef RwFrame *(*RwFrameCallBack)(RwFrame *frame, void *data);
 | |
| 
 | |
| 
 | |
| #define RwFrameGetParentMacro(_f)   ((RwFrame *)rwObjectGetParent(_f))
 | |
| #if (! ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) ))
 | |
| #define RwFrameGetParent(_f)    RwFrameGetParentMacro(_f)
 | |
| #endif
 | |
| 
 | |
| #define RwFrameGetMatrixMacro(_f)   (&(_f)->modelling)
 | |
| #if (! ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) ))
 | |
| #define RwFrameGetMatrix(_f)    RwFrameGetMatrixMacro(_f)
 | |
| #endif
 | |
| 
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Finding what is attached to a frame */
 | |
| extern RwFrame *
 | |
| RwFrameForAllObjects(RwFrame * frame,
 | |
|                      RwObjectCallBack callBack,
 | |
|                      void *data);
 | |
| 
 | |
| /* Matrix operations */
 | |
| extern RwFrame *
 | |
| RwFrameTranslate(RwFrame * frame,
 | |
|                  const RwV3d * v,
 | |
|                  RwOpCombineType combine);
 | |
| 
 | |
| extern RwFrame *
 | |
| RwFrameRotate(RwFrame * frame,
 | |
|               const RwV3d * axis,
 | |
|               RwReal angle,
 | |
|               RwOpCombineType combine);
 | |
| 
 | |
| extern RwFrame *
 | |
| RwFrameScale(RwFrame * frame,
 | |
|              const RwV3d * v,
 | |
|              RwOpCombineType combine);
 | |
| 
 | |
| extern RwFrame *
 | |
| RwFrameTransform(RwFrame * frame,
 | |
|                  const RwMatrix * m,
 | |
|                  RwOpCombineType combine);
 | |
| 
 | |
| extern RwFrame *
 | |
| RwFrameOrthoNormalize(RwFrame * frame);
 | |
| 
 | |
| extern RwFrame *
 | |
| RwFrameSetIdentity(RwFrame * frame);
 | |
| 
 | |
| /* Cloning */
 | |
| extern RwFrame *
 | |
| RwFrameCloneHierarchy(RwFrame * root);
 | |
| 
 | |
| /* Destruction */
 | |
| extern RwBool
 | |
| RwFrameDestroyHierarchy(RwFrame * frame);
 | |
| 
 | |
| /* Building a frame */
 | |
| extern RwFrame *
 | |
| RwFrameForAllChildren(RwFrame * frame,
 | |
|                       RwFrameCallBack callBack,
 | |
|                       void *data);
 | |
| 
 | |
| extern RwFrame *
 | |
| RwFrameRemoveChild(RwFrame * child);
 | |
| 
 | |
| extern RwFrame *
 | |
| RwFrameAddChild(RwFrame * parent,
 | |
|                 RwFrame * child);
 | |
| 
 | |
| #if ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) )
 | |
| extern RwFrame *
 | |
| RwFrameGetParent(const RwFrame * frame);
 | |
| #endif
 | |
| 
 | |
| /* Getting the root */
 | |
| extern RwFrame *
 | |
| RwFrameGetRoot(const RwFrame * frame);
 | |
| 
 | |
| /* Getting Matrices */
 | |
| extern RwMatrix *
 | |
| RwFrameGetLTM(RwFrame * frame);
 | |
| 
 | |
| #if ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) )
 | |
| extern RwMatrix *
 | |
| RwFrameGetMatrix(RwFrame * frame);
 | |
| #endif
 | |
| 
 | |
| /* Elements */
 | |
| extern RwFrame *
 | |
| RwFrameUpdateObjects(RwFrame * frame);
 | |
| 
 | |
| /* Creating destroying frames */
 | |
| extern RwFrame *
 | |
| RwFrameCreate(void);
 | |
| 
 | |
| extern RwBool
 | |
| RwFrameInit(RwFrame *frame);
 | |
| 
 | |
| extern RwBool
 | |
| RwFrameDeInit(RwFrame *frame);
 | |
| 
 | |
| extern RwBool
 | |
| RwFrameDestroy(RwFrame * frame);
 | |
| 
 | |
| /* internal function used by Create and Init */
 | |
| extern void
 | |
| _rwFrameInit(RwFrame *frame);
 | |
| 
 | |
| /* internal function used by Destroy and DeInit */
 | |
| extern void
 | |
| _rwFrameDeInit(RwFrame *frame);
 | |
| 
 | |
| /* Finding a frames state */
 | |
| extern RwBool
 | |
| RwFrameDirty(const RwFrame * frame);
 | |
| 
 | |
| /* Find the amount of frames in a hierarchy */
 | |
| extern RwInt32
 | |
| RwFrameCount(RwFrame * frame);
 | |
| 
 | |
| /* Plugins */
 | |
| extern RwBool
 | |
| RwFrameSetStaticPluginsSize(RwInt32 size);
 | |
| 
 | |
| extern RwInt32
 | |
| RwFrameRegisterPlugin(RwInt32 size,
 | |
|                       RwUInt32 pluginID,
 | |
|                       RwPluginObjectConstructor constructCB,
 | |
|                       RwPluginObjectDestructor destructCB,
 | |
|                       RwPluginObjectCopy copyCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RwFrameGetPluginOffset(RwUInt32 pluginID);
 | |
| 
 | |
| extern RwBool
 | |
| RwFrameValidatePlugins(const RwFrame * frame);
 | |
| 
 | |
| /* Cloning */
 | |
| extern RwFrame *
 | |
| _rwFrameCloneAndLinkClones(RwFrame * root);
 | |
| 
 | |
| extern
 | |
| RwFrame *
 | |
| _rwFramePurgeClone(RwFrame *root);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Compatibility macros */
 | |
| 
 | |
| #define rwFrameGetParent(frame) \
 | |
|        _rwFrameGetParent(frame)
 | |
| 
 | |
| #define rwFrameInit(frame) \
 | |
|        _rwFrameInit(frame)
 | |
| 
 | |
| #define rwFrameDeInit(frame) \
 | |
|        _rwFrameDeInit(frame)
 | |
| 
 | |
| #define rwFrameCloneAndLinkClones(root) \
 | |
|        _rwFrameCloneAndLinkClones(root)
 | |
| 
 | |
| #define rwFramePurgeClone(root) \
 | |
|        _rwFramePurgeClone(root)
 | |
| 
 | |
| #define rwFrameClose(instance, offset, size) \
 | |
|        _rwFrameClose(instance, offset, size)
 | |
| 
 | |
| #define rwFrameOpen(instance, offset, size) \
 | |
|        _rwFrameOpen(instance, offset, size)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/batypehf.h ---*/
 | |
| 
 | |
| typedef struct RwObjectHasFrame RwObjectHasFrame;
 | |
| typedef RwObjectHasFrame * (*RwObjectHasFrameSyncFunction)(RwObjectHasFrame *object);
 | |
| struct RwObjectHasFrame
 | |
| {
 | |
|     RwObject                     object;
 | |
|     RwLLLink                     lFrame;
 | |
|     RwObjectHasFrameSyncFunction sync;
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Frames */
 | |
| extern void _rwObjectHasFrameSetFrame(void *object, RwFrame *frame);
 | |
| extern void _rwObjectHasFrameReleaseFrame(void *object);
 | |
| 
 | |
| /* ObjectHASFRAME METHODS */
 | |
| #define rwObjectHasFrameInitialize(o, type, subtype, syncFunc)  \
 | |
| MACRO_START                                                     \
 | |
| {                                                               \
 | |
|     rwObjectInitialize(o, type, subtype);                       \
 | |
|     ((RwObjectHasFrame *)o)->sync = syncFunc;                   \
 | |
| }                                                               \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define rwObjectHasFrameSync(o) \
 | |
|     ((RwObjectHasFrame *)(o))->sync(o)
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Compatibility macros */
 | |
| 
 | |
| #define rwObjectHasFrameSetFrame(object, frame) \
 | |
|         _rwObjectHasFrameSetFrame(object, frame)
 | |
| #define rwObjectHasFrameReleaseFrame(object) \
 | |
|         _rwObjectHasFrameReleaseFrame(object)
 | |
| 
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/basync.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/babintex.h ---*/
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| typedef struct rpTextureChunkInfo RwTextureChunkInfo;
 | |
| struct rpTextureChunkInfo
 | |
| {
 | |
|     RwTextureFilterMode filtering;
 | |
|     RwTextureAddressMode addressingU;
 | |
|     RwTextureAddressMode addressingV;
 | |
| };
 | |
| 
 | |
| /* Bit flags defining properties of textures when stream */
 | |
| enum RwTextureStreamFlags
 | |
| {
 | |
|     rwNATEXTURESTREAMFLAG = 0x00,
 | |
|     rwTEXTURESTREAMFLAGSUSERMIPMAPS = 0x01,
 | |
|     rwTEXTURESTREAMFLAGSFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwTextureStreamFlags RwTextureStreamFlags;
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Texture binary format */
 | |
| extern RwInt32
 | |
| RwTextureRegisterPluginStream(RwUInt32 pluginID,
 | |
|                               RwPluginDataChunkReadCallBack readCB,
 | |
|                               RwPluginDataChunkWriteCallBack writeCB,
 | |
|                               RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RwTextureSetStreamAlwaysCallBack(RwUInt32 pluginID,
 | |
|                                  RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| 
 | |
| extern RwUInt32
 | |
| RwTextureStreamGetSize(const RwTexture *texture);
 | |
| 
 | |
| extern RwTexture *
 | |
| RwTextureStreamRead(RwStream *stream);
 | |
| 
 | |
| extern const RwTexture *
 | |
| RwTextureStreamWrite(const RwTexture *texture,
 | |
|                      RwStream *stream);
 | |
| 
 | |
| /* Texture dictionary binary format */
 | |
| extern RwInt32
 | |
| RwTexDictionaryRegisterPluginStream(RwUInt32 pluginID,
 | |
|                                     RwPluginDataChunkReadCallBack readCB,
 | |
|                                     RwPluginDataChunkWriteCallBack writeCB,
 | |
|                                     RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RwTexDictionarySetStreamAlwaysCallBack(RwUInt32 pluginID,
 | |
|                                        RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| 
 | |
| extern RwUInt32
 | |
| RwTexDictionaryStreamGetSize(const RwTexDictionary *texDict);
 | |
| 
 | |
| extern RwTexDictionary
 | |
| *RwTexDictionaryStreamRead(RwStream *stream);
 | |
| 
 | |
| extern const RwTexDictionary *
 | |
| RwTexDictionaryStreamWrite(const RwTexDictionary *texDict,
 | |
|                            RwStream *stream);
 | |
| 
 | |
| extern RwTextureChunkInfo *
 | |
| _rwTextureChunkInfoRead(RwStream *stream,
 | |
|                         RwTextureChunkInfo *textureChunkInfo,
 | |
|                         RwInt32 *bytesRead);
 | |
| 
 | |
| /* Compatibility macro */
 | |
| 
 | |
| #define  RwTextureChunkInfoRead(_stream, _textureChunkInfo, _bytesRead) \
 | |
|         _rwTextureChunkInfoRead(_stream, _textureChunkInfo, _bytesRead) 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/babinfrm.h ---*/
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| typedef struct rwFrameList rwFrameList;
 | |
| struct rwFrameList
 | |
| {
 | |
|     RwFrame **frames;
 | |
|     RwInt32 numFrames;
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Variables 
 | |
|  */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Frame binary format */
 | |
| 
 | |
| extern RwInt32 
 | |
| RwFrameRegisterPluginStream(RwUInt32 pluginID,
 | |
|                             RwPluginDataChunkReadCallBack readCB,
 | |
|                             RwPluginDataChunkWriteCallBack writeCB,
 | |
|                             RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| 
 | |
| extern RwInt32 
 | |
| RwFrameSetStreamAlwaysCallBack(RwUInt32 pluginID,
 | |
|                                RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| 
 | |
| 
 | |
| extern rwFrameList *
 | |
| _rwFrameListInitialize(rwFrameList *frameList,
 | |
|                       RwFrame *frame);
 | |
| 
 | |
| extern RwBool 
 | |
| _rwFrameListFindFrame(const rwFrameList *frameList,
 | |
|                      const RwFrame *frame,
 | |
|                      RwInt32 *npIndex);
 | |
| 
 | |
| extern rwFrameList *
 | |
| _rwFrameListDeinitialize(rwFrameList *frameList);
 | |
| 
 | |
| extern RwUInt32 
 | |
| _rwFrameListStreamGetSize(const rwFrameList *frameList);
 | |
| 
 | |
| extern rwFrameList *
 | |
| _rwFrameListStreamRead(RwStream *stream,
 | |
|                       rwFrameList *fl);
 | |
| 
 | |
| extern const rwFrameList *
 | |
| _rwFrameListStreamWrite(const rwFrameList *frameList,
 | |
|                        RwStream *stream);
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Comparibility macros */
 | |
| 
 | |
| #define rwFrameListInitialize(frameList,frame) \
 | |
|        _rwFrameListInitialize(frameList,frame)
 | |
| 
 | |
| #define rwFrameListFindFrame(frameList, frame, index) \
 | |
|        _rwFrameListFindFrame(frameList, frame, index)
 | |
| 
 | |
| #define rwFrameListDeinitialize(frameList) \
 | |
|        _rwFrameListDeinitialize(frameList)
 | |
| 
 | |
| #define rwFrameListStreamGetSize(frameList) \
 | |
|        _rwFrameListStreamGetSize(frameList)
 | |
| 
 | |
| #define rwFrameListStreamRead(stream, fl) \
 | |
|        _rwFrameListStreamRead(stream, fl)
 | |
| 
 | |
| #define rwFrameListStreamWrite(frameList, stream) \
 | |
|        _rwFrameListStreamWrite(frameList, stream)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/babbox.h ---*/
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| typedef struct RwBBox RwBBox;
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \struct RwBBox
 | |
|  * This type represents a 3D axis-aligned bounding-box
 | |
|  * specified by the positions of two corners which lie on a diagonal.
 | |
|  * Typically used to specify a world bounding-box when the world is created
 | |
|  * 
 | |
|  * \param sup Supremum vertex (contains largest values)
 | |
|  * \param inf Infimum vertex (contains smallest values)
 | |
|  * 
 | |
|  * \see RpWorldCreate
 | |
|  */
 | |
| struct RwBBox
 | |
| {
 | |
|     /* Must be in this order */
 | |
|     RwV3d sup;   /**< Supremum vertex. */
 | |
|     RwV3d inf;   /**< Infimum vertex. */
 | |
| };
 | |
| 
 | |
| #if (!defined(RwBBoxAssign))
 | |
| #define RwBBoxAssign(_target, _source)            \
 | |
|     ( *(_target) = *(_source) )
 | |
| #endif /* (!defined(RwBBoxAssign)) */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| extern RwBBox *RwBBoxCalculate(RwBBox *boundBox,
 | |
|                                const RwV3d *verts,
 | |
|                                RwInt32 numVerts);
 | |
| extern RwBBox *RwBBoxInitialize(RwBBox *boundBox,
 | |
|                                 const RwV3d *vertex);
 | |
| extern RwBBox *RwBBoxAddPoint(RwBBox *boundBox,
 | |
|                               const RwV3d *vertex);
 | |
| extern RwBool RwBBoxContainsPoint(const RwBBox *boundBox,
 | |
|                                   const RwV3d *vertex);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/bacamera.h ---*/
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* Type ID */
 | |
| #define rwCAMERA 4
 | |
| 
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
|  */
 | |
| 
 | |
| #define RwCameraGetViewOffsetMacro(_camera)                     \
 | |
|     (&((_camera)->viewOffset))
 | |
| 
 | |
| #define RwCameraSetRasterMacro(_camera, _raster)                \
 | |
|     (((_camera)->frameBuffer = (_raster)), (_camera))
 | |
| 
 | |
| #define RwCameraSetRasterVoidMacro(_camera, _raster)            \
 | |
| MACRO_START                                                     \
 | |
| {                                                               \
 | |
|     (_camera)->frameBuffer = (_raster);                         \
 | |
| }                                                               \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RwCameraGetRasterMacro(_camera)                         \
 | |
|     ((_camera)->frameBuffer)
 | |
| 
 | |
| #define RwCameraSetZRasterMacro(_camera, _raster)               \
 | |
|     (((_camera)->zBuffer = (_raster)), (_camera))
 | |
| 
 | |
| #define RwCameraSetZRasterVoidMacro(_camera, _raster)           \
 | |
| MACRO_START                                                     \
 | |
| {                                                               \
 | |
|     (_camera)->zBuffer = (_raster);                             \
 | |
| }                                                               \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RwCameraGetZRasterMacro(_camera)                        \
 | |
|     ((_camera)->zBuffer)
 | |
| 
 | |
| #define RwCameraGetNearClipPlaneMacro(_camera)                  \
 | |
|     ((_camera)->nearPlane)
 | |
| 
 | |
| #define RwCameraGetFarClipPlaneMacro(_camera)                   \
 | |
|     ((_camera)->farPlane)
 | |
| 
 | |
| #define RwCameraSetFogDistanceMacro(_camera, _distance)         \
 | |
|     (((_camera)->fogPlane = (_distance)), (_camera))
 | |
| 
 | |
| #define RwCameraGetFogDistanceMacro(_camera)                    \
 | |
|     ((_camera)->fogPlane)
 | |
| 
 | |
| #define RwCameraGetCurrentCameraMacro()                         \
 | |
|     ((RwCamera *)RWSRCGLOBAL(curCamera))
 | |
| 
 | |
| #define RwCameraGetProjectionMacro(_camera)                     \
 | |
|     ((_camera)->projectionType)
 | |
| 
 | |
| #define RwCameraGetViewWindowMacro(_camera)                     \
 | |
|     (&((_camera)->viewWindow))
 | |
| 
 | |
| #define RwCameraGetViewMatrixMacro(_camera)                     \
 | |
|     (&((_camera)->viewMatrix))
 | |
| 
 | |
| #define RwCameraSetFrameMacro(_camera, _frame)                  \
 | |
|     (_rwObjectHasFrameSetFrame((_camera), (_frame)), (_camera))
 | |
| 
 | |
| #define RwCameraSetFrameVoidMacro(_camera, _frame)      \
 | |
| MACRO_START                                             \
 | |
| {                                                       \
 | |
|     _rwObjectHasFrameSetFrame((_camera), (_frame));     \
 | |
| }                                                       \
 | |
| MACRO_STOP
 | |
| 
 | |
| 
 | |
| #define RwCameraGetFrameMacro(_camera)                          \
 | |
|     ((RwFrame *)rwObjectGetParent((_camera)))
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RwCameraGetViewOffset(_camera)                          \
 | |
|     RwCameraGetViewOffsetMacro(_camera)
 | |
| 
 | |
| #define RwCameraSetRaster(_camera, _raster)                     \
 | |
|     RwCameraSetRasterMacro(_camera, _raster)
 | |
| 
 | |
| #define RwCameraGetRaster(_camera)                              \
 | |
|     RwCameraGetRasterMacro(_camera)
 | |
| 
 | |
| #define RwCameraSetZRaster(_camera, _raster)                    \
 | |
|     RwCameraSetZRasterMacro(_camera, _raster)
 | |
| 
 | |
| #define RwCameraGetZRaster(_camera)                             \
 | |
|     RwCameraGetZRasterMacro(_camera)
 | |
| 
 | |
| #define RwCameraGetNearClipPlane(_camera)                       \
 | |
|     RwCameraGetNearClipPlaneMacro(_camera)
 | |
| 
 | |
| #define RwCameraGetFarClipPlane(_camera)                        \
 | |
|     RwCameraGetFarClipPlaneMacro(_camera)
 | |
| 
 | |
| #define RwCameraSetFogDistance(_camera, _distance)              \
 | |
|     RwCameraSetFogDistanceMacro(_camera, _distance)
 | |
| 
 | |
| #define RwCameraGetFogDistance(_camera)                         \
 | |
|     RwCameraGetFogDistanceMacro(_camera)
 | |
| 
 | |
| #define RwCameraGetCurrentCamera()                              \
 | |
|     RwCameraGetCurrentCameraMacro()
 | |
| 
 | |
| #define RwCameraGetProjection(_camera)                          \
 | |
|     RwCameraGetProjectionMacro(_camera)
 | |
| 
 | |
| #define RwCameraGetViewWindow(_camera)                          \
 | |
|     RwCameraGetViewWindowMacro(_camera)
 | |
| 
 | |
| #define RwCameraGetViewMatrix(_camera)                          \
 | |
|     RwCameraGetViewMatrixMacro(_camera)
 | |
| 
 | |
| #define RwCameraSetFrame(_camera, _frame)                       \
 | |
|     RwCameraSetFrameMacro(_camera, _frame)
 | |
| 
 | |
| #define RwCameraGetFrame(_camera)                               \
 | |
|     RwCameraGetFrameMacro(_camera)
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * RwCameraClearMode 
 | |
|  * Camera clear flags */
 | |
| enum RwCameraClearMode
 | |
| {
 | |
|     rwCAMERACLEARIMAGE = 0x1,   /**<Clear the frame buffer */
 | |
|     rwCAMERACLEARZ = 0x2,       /**<Clear the Z buffer */
 | |
|     rwCAMERACLEARSTENCIL = 0x4, /**<\if xbox   Clear the stencil buffer \endif
 | |
|                                   * \if d3d8   Clear the stencil buffer \endif
 | |
|                                   * \if opengl Clear the stencil buffer \endif
 | |
|                                   */
 | |
|     rwCAMERACLEARMODEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwCameraClearMode RwCameraClearMode;
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * RwCameraProjection 
 | |
|  * This type represents the options available for 
 | |
|  * setting the camera projection model, either perspective projection or 
 | |
| * parallel projection (see API function \ref RwCameraSetProjection)*/
 | |
| enum RwCameraProjection
 | |
| {
 | |
|     rwNACAMERAPROJECTION = 0,   /**<Invalid projection */
 | |
|     rwPERSPECTIVE = 1,          /**<Perspective projection */
 | |
|     rwPARALLEL = 2,             /**<Parallel projection */
 | |
|     rwCAMERAPROJECTIONFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwCameraProjection RwCameraProjection;
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * RwFrustumTestResult 
 | |
|  * This type represents the results from a 
 | |
|  * camera frustum test on a given sphere (see API function 
 | |
|  * \ref RwCameraFrustumTestSphere)*/
 | |
| enum RwFrustumTestResult
 | |
| {
 | |
|     rwSPHEREOUTSIDE = 0,    /**<Outside the frustum */
 | |
|     rwSPHEREBOUNDARY = 1,   /**<On the boundary of the frustum */
 | |
|     rwSPHEREINSIDE = 2,     /**<Inside the frustum */
 | |
|     rwFRUSTUMTESTRESULTFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RwFrustumTestResult RwFrustumTestResult;
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwCamera
 | |
|  * Camera object for rendering a view. 
 | |
|  * This should be considered an opaque type.
 | |
|  * Use the RwCamera API functions to access.
 | |
|  */
 | |
| typedef struct RwCamera RWALIGN(RwCamera, rwMATRIXALIGNMENT);
 | |
| 
 | |
| /* This allows a world to overload functionality */
 | |
| typedef RwCamera   *(*RwCameraBeginUpdateFunc) (RwCamera * camera);
 | |
| typedef RwCamera   *(*RwCameraEndUpdateFunc) (RwCamera * camera);
 | |
| 
 | |
| typedef struct RwFrustumPlane RwFrustumPlane;
 | |
| /*
 | |
|  * Structure describing a frustrum plane.
 | |
|  */
 | |
| struct RwFrustumPlane
 | |
| {
 | |
|         RwPlane             plane;
 | |
|         RwUInt8             closestX;
 | |
|         RwUInt8             closestY;
 | |
|         RwUInt8             closestZ;
 | |
|         RwUInt8             pad;
 | |
| };
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RwCamera
 | |
| {
 | |
|         RwObjectHasFrame    object;
 | |
| 
 | |
|         /* Parallel or perspective projection */
 | |
|         RwCameraProjection  projectionType;
 | |
| 
 | |
|         /* Start/end update functions */
 | |
|         RwCameraBeginUpdateFunc beginUpdate;
 | |
|         RwCameraEndUpdateFunc endUpdate;
 | |
| 
 | |
|         /* The view matrix */
 | |
|         RwMatrix            viewMatrix;
 | |
| 
 | |
|         /* The cameras image buffer */
 | |
|         RwRaster           *frameBuffer;
 | |
| 
 | |
|         /* The Z buffer */
 | |
|         RwRaster           *zBuffer;
 | |
| 
 | |
|         /* Cameras mathmatical characteristics */
 | |
|         RwV2d               viewWindow;
 | |
|         RwV2d               recipViewWindow;
 | |
|         RwV2d               viewOffset;
 | |
|         RwReal              nearPlane;
 | |
|         RwReal              farPlane;
 | |
|         RwReal              fogPlane;
 | |
| 
 | |
|         /* Transformation to turn camera z or 1/z into a Z buffer z */
 | |
|         RwReal              zScale, zShift;
 | |
| 
 | |
|         /* Render frame counter -> used for the frustum callback stuff */
 | |
|         RwUInt16            renderFrame;
 | |
|         RwUInt16            pad;
 | |
| 
 | |
|         /* The clip-planes making up the viewing frustum */
 | |
|         RwFrustumPlane      frustumPlanes[6];
 | |
|         RwBBox              frustumBoundBox;
 | |
| 
 | |
|         /* Points on the tips of the view frustum */
 | |
|         RwV3d               frustumCorners[8];
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwCameraCallBack
 | |
|  * \ref RwCameraCallBack type represents a function called from any camera
 | |
|  * iterator that may be implemented in plugins. This function should return a
 | |
|  * pointer to the current camera to indicate success. The callback may return
 | |
|  * NULL to terminate further callbacks on other cameras.
 | |
|  * 
 | |
|  * \param  camera   Pointer to the current camera, supplied by iterator.
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  */
 | |
| typedef RwCamera *(*RwCameraCallBack)(RwCamera *camera, void *data);
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
|     /* Rendering */
 | |
| extern RwCamera    *RwCameraBeginUpdate(RwCamera * camera);
 | |
| extern RwCamera    *RwCameraEndUpdate(RwCamera * camera);
 | |
| 
 | |
| extern RwCamera    *RwCameraClear(RwCamera * camera, RwRGBA * colour,
 | |
|                                   RwInt32 clearMode);
 | |
| 
 | |
| /* Displaying results */
 | |
| extern RwCamera    *RwCameraShowRaster(RwCamera * camera, void *pDev,
 | |
|                                        RwUInt32 flags);
 | |
| 
 | |
| /* Creation and destruction */
 | |
| extern RwBool       RwCameraDestroy(RwCamera * camera);
 | |
| extern RwCamera    *RwCameraCreate(void);
 | |
| extern RwCamera    *RwCameraClone(RwCamera * camera);
 | |
| 
 | |
| /* Offset */
 | |
| extern RwCamera    *RwCameraSetViewOffset(RwCamera *camera,
 | |
|                                           const RwV2d *offset);
 | |
| 
 | |
| /* View window */
 | |
| extern RwCamera    *RwCameraSetViewWindow(RwCamera *camera,
 | |
|                                           const RwV2d *viewWindow);
 | |
| 
 | |
| /* Projection */
 | |
| extern RwCamera    *RwCameraSetProjection(RwCamera *camera,
 | |
|                                           RwCameraProjection projection);
 | |
| 
 | |
| /* Clip planes */
 | |
| extern RwCamera    *RwCameraSetNearClipPlane(RwCamera *camera, RwReal nearClip);
 | |
| extern RwCamera    *RwCameraSetFarClipPlane(RwCamera *camera, RwReal farClip);
 | |
| 
 | |
| /* Attaching toolkits */
 | |
| extern RwInt32      RwCameraRegisterPlugin(RwInt32 size,
 | |
|                                            RwUInt32 pluginID,
 | |
|                                            RwPluginObjectConstructor
 | |
|                                            constructCB,
 | |
|                                            RwPluginObjectDestructor
 | |
|                                            destructCB,
 | |
|                                            RwPluginObjectCopy copyCB);
 | |
| extern RwInt32      RwCameraGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool       RwCameraValidatePlugins(const RwCamera * camera);
 | |
| 
 | |
| /* Frustum testing */
 | |
| extern RwFrustumTestResult RwCameraFrustumTestSphere(const RwCamera *
 | |
|                                                      camera,
 | |
|                                                      const RwSphere *
 | |
|                                                      sphere);
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| /* Offset */
 | |
| extern const RwV2d *RwCameraGetViewOffset(const RwCamera *camera);
 | |
| 
 | |
| /* Rasters */
 | |
| extern RwCamera    *RwCameraSetRaster(RwCamera *camera, RwRaster *raster);
 | |
| extern RwRaster    *RwCameraGetRaster(const RwCamera *camera);
 | |
| extern RwCamera    *RwCameraSetZRaster(RwCamera *camera, RwRaster *zRaster);
 | |
| extern RwRaster    *RwCameraGetZRaster(const RwCamera *camera);
 | |
| 
 | |
| /* Clip planes */
 | |
| extern RwReal       RwCameraGetNearClipPlane(const RwCamera *camera);
 | |
| extern RwReal       RwCameraGetFarClipPlane(const RwCamera *camera);
 | |
| extern RwCamera    *RwCameraSetFogDistance(RwCamera *camera, RwReal fogDistance);
 | |
| extern RwReal       RwCameraGetFogDistance(const RwCamera *camera);
 | |
| 
 | |
| extern RwCamera    *RwCameraGetCurrentCamera(void);
 | |
| 
 | |
| /* Projection */
 | |
| extern RwCameraProjection RwCameraGetProjection(const RwCamera *camera);
 | |
| 
 | |
| /* View window */
 | |
| extern const RwV2d *RwCameraGetViewWindow(const RwCamera *camera);
 | |
| 
 | |
| extern RwMatrix    *RwCameraGetViewMatrix(RwCamera *camera);
 | |
| 
 | |
| /* Frames */
 | |
| extern RwCamera    *RwCameraSetFrame(RwCamera *camera, RwFrame *frame);
 | |
| extern RwFrame     *RwCameraGetFrame(const RwCamera *camera);
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/common/barwtyp.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/bacamval.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/pipe/p2/bapipe.h ---*/
 | |
| 
 | |
| struct rwPipeGlobals
 | |
| {
 | |
|     RwFreeList          *pipesFreeList;   /* Save mallocs, use a freelist */
 | |
|     RxRenderStateVector  defaultRenderState;
 | |
|     RwLinkList           allPipelines;    /* Unused as of yet, meant to be used to keep track of all
 | |
|                                            * created pipelines (for CBs and maybe cleanup) */
 | |
|     RwUInt32             maxNodesPerPipe; /* Initialised from _rxPipelineMaxNodes at startup. Used to
 | |
|                                            * allow conservative, single allocations during pipelock */
 | |
| 
 | |
|     /* NOTE: Rw and RpWorld PowerPipe globals kept together for simplicity */
 | |
| 
 | |
|     /* The current default pipelines (used if pipe == NULL for an object) */
 | |
|     RxPipeline          *currentAtomicPipeline;
 | |
|     RxPipeline          *currentWorldSectorPipeline;
 | |
|     RxPipeline          *currentMaterialPipeline;
 | |
|     /* Generic C-based pipes that run on all platforms
 | |
|      * - these are set as the current pipes at startup unless
 | |
|      *   platform-specific pipes (below) are created */
 | |
|     RxPipeline          *genericAtomicPipeline;
 | |
|     RxPipeline          *genericWorldSectorPipeline;
 | |
|     RxPipeline          *genericMaterialPipeline;
 | |
|     /* Platforms that have their own non-generic pipelines
 | |
|      * (OPENGL, D3D7, SKY2, KAMUI2, DOLPHIN) put them here: */
 | |
|     RxPipeline          *platformAtomicPipeline;
 | |
|     RxPipeline          *platformWorldSectorPipeline;
 | |
|     RxPipeline          *platformMaterialPipeline;
 | |
| #if (defined(SKY2_DRVMODEL_H))
 | |
|     /* We have extra flavours of pipe under SKY2.
 | |
|      * PS2All and PS2AllMat are the defaults.
 | |
|      *  - see RpWorldSectorSkyGetPS2AllPipeline, etc */
 | |
|     RxPipeline          *ps2ManagerAtomicPipeline;
 | |
|     RxPipeline          *allInOneAtomicPipeline;
 | |
|     RxPipeline          *vanillaAtomicPipeline;
 | |
|     RxPipeline          *ps2ManagerWorldSectorPipeline;
 | |
|     RxPipeline          *allInOneWorldSectorPipeline;
 | |
|     RxPipeline          *vanillaWorldSectorPipeline;
 | |
|     RxPipeline          *vanillaMaterialPipeline;
 | |
| #endif /* (SKY2_DRVMODEL_H) */
 | |
|     
 | |
| };
 | |
| 
 | |
| typedef struct rwPipeGlobals rwPipeGlobals;
 | |
| 
 | |
| #define RXPIPELINEGLOBAL(var) (RWPLUGINOFFSET(rwPipeGlobals, RwEngineInstance, _rxPipelineGlobalsOffset)->var)
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RwInt32      _rxPipelineGlobalsOffset;
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/driver/common/imrascnv.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/src/babincam.h ---*/
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| /* Camera stream format */
 | |
| 
 | |
| /**
 | |
|  * \ingroup datatypes
 | |
|  * \typedef RwCameraChunkInfo
 | |
|  * 
 | |
|  * \ref RwCameraChunkInfo is typedef'd to a structure that holds camera
 | |
|  * data. This should be considered an opaque type. Use the RwCamera
 | |
|  * API functions to access it.
 | |
|  */
 | |
| 
 | |
| typedef struct rwStreamCamera RwCameraChunkInfo;
 | |
| typedef struct rwStreamCamera rwStreamCamera;
 | |
| struct rwStreamCamera
 | |
| {
 | |
|     RwV2d viewWindow;
 | |
|     RwV2d viewOffset;
 | |
|     RwReal nearPlane, farPlane;
 | |
|     RwReal fogPlane;
 | |
|     RwUInt32 projection;
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Camera binary format */
 | |
| extern RwInt32 RwCameraRegisterPluginStream(RwUInt32 pluginID,
 | |
|                                             RwPluginDataChunkReadCallBack readCB,
 | |
|                                             RwPluginDataChunkWriteCallBack writeCB,
 | |
|                                             RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| extern RwInt32 RwCameraSetStreamAlwaysCallBack(
 | |
|                    RwUInt32 pluginID,
 | |
|                    RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| extern RwUInt32 RwCameraStreamGetSize(const RwCamera *camera);
 | |
| extern RwCamera *RwCameraStreamRead(RwStream *stream);
 | |
| extern const RwCamera *RwCameraStreamWrite(const RwCamera *camera,
 | |
|                                            RwStream *stream);
 | |
| extern RwCameraChunkInfo * RwCameraChunkInfoRead(RwStream *stream,
 | |
|                                                  RwCameraChunkInfo *cameraChunkInfo,
 | |
|                                                  RwInt32 *bytesRead);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #endif /* RWCORE_H */
 |