|
|
//========= Copyright � 1996-2005, Valve Corporation, All rights reserved. ============//
//
// Purpose: Player for HL1.
//
// $NoKeywords: $
//=============================================================================//
#ifndef DT_UTLVECTOR_SEND_H
#define DT_UTLVECTOR_SEND_H
#pragma once
#include "dt_send.h"
#include "dt_utlvector_common.h"
#define SENDINFO_UTLVECTOR( varName ) #varName, \
offsetof(currentSendDTClass, varName), \ sizeof(((currentSendDTClass*)0)->varName[0]), \ GetEnsureCapacityTemplate( ((currentSendDTClass*)0)->varName )
#define SendPropUtlVectorDataTable( varName, nMaxElements, dataTableName ) \
SendPropUtlVector( \ SENDINFO_UTLVECTOR( varName ), \ nMaxElements, \ SendPropDataTable( NULL, 0, &REFERENCE_SEND_TABLE( dataTableName ) ) \ )
//
// Set it up to transmit a CUtlVector of basic types or of structures.
//
// pArrayProp doesn't need a name, offset, or size. You can pass 0 for all those.
// Example usage:
//
// SendPropUtlVectorDataTable( m_StructArray, 11, DT_TestStruct )
//
// SendPropUtlVector(
// SENDINFO_UTLVECTOR( m_FloatArray ),
// 16, // max elements
// SendPropFloat( NULL, 0, 0, 0, SPROP_NOSCALE )
// )
//
SendProp SendPropUtlVector( char *pVarName, // Use SENDINFO_UTLVECTOR to generate these first 4 parameters.
int offset, int sizeofVar, EnsureCapacityFn ensureFn,
int nMaxElements, // Max # of elements in the array. Keep this as low as possible.
SendProp pArrayProp, // Describe the data inside of each element in the array.
SendTableProxyFn varProxy=SendProxy_DataTableToDataTable // This can be overridden to control who the array is sent to.
);
#endif // DT_UTLVECTOR_SEND_H
|