⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 emanag.c

📁 基于h323协议的软phone
💻 C
字号:
#ifdef __cplusplus
extern "C" {
#endif



/*

NOTICE:
This document contains information that is proprietary to RADVISION LTD..
No part of this publication may be reproduced in any form whatsoever without
written prior approval by RADVISION LTD..

RADVISION LTD. reserves the right to revise this publication and make changes
without obligation to notify any person of such revisions or changes.

*/

#include <stdio.h>
#include <emanag.h>

#define MAX_E_SYSTEMS 3
static emTypeOfEncoding eSystems[MAX_E_SYSTEMS];


int emSetEncoding(
    IN  int                 privateTag,
    IN  emTypeOfEncoding*   encoding)
{
    eSystems[privateTag]=*encoding;
    return 0;
}


int emEncode(
    IN  HPVT    valH,
    IN  int     vNodeId,
    IN  RvUint8*buffer,
    IN  int     length,
    OUT int*    encoded)
{
    int eSystem;
    int nodeId,tag;
    pstTagClass tagClass;
    HPST synH=pvtGetSynTree(valH, vNodeId);
    pvtGet(valH,vNodeId,NULL,&nodeId,NULL,NULL);
    tag=pstGetTag(synH,nodeId, &tagClass);
    eSystem=(int)(tagClass==pstTagPrivate)?tag:0;
    if (eSystems[eSystem].Encode)
        return eSystems[eSystem].Encode(valH,vNodeId,buffer,length,encoded);
    return 0;
}

int emEncodeExt(
    IN  HPVT    valH,
    IN  int     vNodeId,
    IN  RvUint8*buffer,
    IN  int     length,
    OUT int*    encoded)
{
    return emEncode(valH,vNodeId,buffer,length,encoded);
}

int emDecode(
    IN  HPVT    valH,
    IN  int     vNodeId,
    OUT RvUint8*buffer,
    IN  int     length,
    OUT int*    decoded)
{
    int ret;
    if ((ret=emDecodeExt(valH,vNodeId,-1,buffer,length,decoded))<0)
        return ret;
    return RV_TRUE;
}

int emDecodeExt(
    IN  HPVT    valH,
    IN  int     vNodeId,
    IN  RvInt32 fieldId,
    IN  RvUint8*buffer,
    IN  int     length,
    OUT int*    decoded)
{
    int eSystem;
    int nodeId,tag;
    pstTagClass tagClass;
    HPST synH=pvtGetSynTree(valH, vNodeId);

    if (synH == NULL)
    {
        /* No syntax information in the given node id! */
        return RV_ERROR_UNKNOWN;
    }

    /* Find out which decoding system we have to use */
    pvtGet(valH,vNodeId,NULL,&nodeId,NULL,NULL);
    tag=pstGetTag(synH,nodeId, &tagClass);
    eSystem=(int)(tagClass==pstTagPrivate)?tag:0;

    if (eSystems[eSystem].Decode)
    {
        /* Decode it */
        return eSystems[eSystem].Decode(valH,vNodeId,fieldId,buffer,length,decoded);
    }
    return RV_ERROR_NOTSUPPORTED;
}

#ifdef __cplusplus
}
#endif



⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -