(file) Return to packing.h CVS log (file) (dir) Up to [OMI] / omi / base

File: [OMI] / omi / base / packing.h (download)
Revision: 1.3, Mon Apr 20 17:19:50 2015 UTC (9 years ago) by krisbash
Branch: MAIN
CVS Tags: OMI_1_0_8_2, OMI_1_0_8_1, HEAD
Changes since 1.2: +2 -2 lines
OMI 1.0.8-1

/*
**==============================================================================
**
** Open Management Infrastructure (OMI)
**
** Copyright (c) Microsoft Corporation
** 
** Licensed under the Apache License, Version 2.0 (the "License"); you may not 
** use this file except in compliance with the License. You may obtain a copy 
** of the License at 
**
**     http://www.apache.org/licenses/LICENSE-2.0 
**
** THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
** KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED 
** WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, 
** MERCHANTABLITY OR NON-INFRINGEMENT. 
**
** See the Apache 2 License for the specific language governing permissions 
** and limitations under the License.
**
**==============================================================================
*/

#ifndef _base_packing_h
#define _base_packing_h

#include "instance.h"

BEGIN_EXTERNC

/*
**==============================================================================
**
** Instance_Pack()
**
**     Serializes an instance into a buffer.
**
** Parameters:
**     self - the instance to be serialized.
**     keysOnly - pack only KEY properties.
**     buf - the buffer to put instance into.
**
** Returns:
**     MI_RESULT_OK on success.
**
**==============================================================================
*/
MI_Result Instance_Pack(
    const MI_Instance* self,
    MI_Boolean keysOnly,
    MI_Boolean (*filterProperty)(const ZChar* name, void* data),
    void* filterPropertyData,
    Buf* buf);

/*
**==============================================================================
**
** Instance_Unpack()
**
**     Unpacks an instance from a buffer.
**
** Parameters:
**     self - shall point to a newly allocated instance.
**     buf - buffer form whicn instance will be unpacked.
**     batch - if non-null, use this batch to allocate all elements.
**     copy - if false, use pointers into batch (otherwise make copy).
**
** Returns:
**     MI_RESULT_OK on success.
**
**==============================================================================
*/
MI_Result Instance_Unpack(
    MI_Instance** self,
    Buf* buf,
    Batch* batch,
    MI_Boolean copy);

/*
**==============================================================================
**
** InstanceToBatch()
**
**     Serializes an instance into a batch.
**
** Parameters:
**     instance - the instance to be serialized.
**     batch - the batch to put instance into.
**     ptrOut - pointer to the packed instance in the batch
**     sizeOut - size of the packed instance
**
** Returns:
**     MI_RESULT_OK on success.
**
**==============================================================================
*/
MI_Result InstanceToBatch(
    const MI_Instance* instance,
    MI_Boolean (*filterProperty)(const ZChar* name, void* data),
    void* filterPropertyData,
    Batch* batch,
    void** ptrOut,
    MI_Uint32* sizeOut);

END_EXTERNC

#endif /* _base_packing_h */

ViewCVS 0.9.2