C++程序  |  112行  |  3.63 KB

/**
 * Copyright(c) 2011 Trusted Logic.   All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *  * Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *  * Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *  * Neither the name Trusted Logic nor the names of its
 *    contributors may be used to endorse or promote products derived
 *    from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

/*
 * This API allows parsing manifest files. A manifest is a text file that contains
 * a property set. A property is a name-value pair.
 *
 * The BNF syntax of a manifest file is :
 *
 * See Spec of Client Authentication
 *
 * Note: for each property, trailing spaces and tabs between the ':' separator
 * and the first character of the property value are discarded.
 */


#ifndef __LIB_MANIFEST2_H__
#define __LIB_MANIFEST2_H__

#include "s_error.h"
#include "s_type.h"

#ifdef __cplusplus
extern "C" {
#endif
#if 0
}  /* balance curly quotes */
#endif

/* The input file is a compiled manifest */
#define LIB_MANIFEST2_TYPE_COMPILED 1
/* The input file is a source manifest */
#define LIB_MANIFEST2_TYPE_SOURCE 2
/* The input file is a source manifest with sections */
#define LIB_MANIFEST2_TYPE_SOURCE_WITH_SECTIONS 3

typedef struct
{
   char* pManifestName;
   uint32_t nType;
   uint8_t* pManifestContent;
   uint32_t nManifestLength;
   uint32_t nOffset;
   uint32_t nLine;
   uint32_t nSectionStartOffset;
}
LIB_MANIFEST2_CONTEXT;

/* Must be used before libManifest2GetNextItem.
   The fields nType, pManifestContent, nManifestLength, and pManifestName (if applicable)
   must be filled-in before.
*/
void libManifest2InitContext(
   LIB_MANIFEST2_CONTEXT* pContext);

/**
 * Returns S_ITEM_NOT_FOUND for the last itel
 *
 * If type is LIB_MANIFEST2_TYPE_SOURCE, supports comments, multiple newlines, and leading BOM,
 * and checks that properties are not duplicated
 *
 * If type is LIB_MANIFEST2_TYPE_SOURCE_WITH_SECTIONS, returns *pValue == NULL for a section
 * Check that the section name contains only ASCII characters and that there is no duplicate
 * sections (same name, case insensitive)
 **/
S_RESULT libManifest2GetNextItem(
   LIB_MANIFEST2_CONTEXT* pContext,
   OUT uint8_t** ppName,
   OUT uint32_t* pNameLength,
   OUT uint8_t** ppValue,
   OUT uint32_t* pValueLength);

S_RESULT libManifest2CheckFormat(
   LIB_MANIFEST2_CONTEXT* pContext,
   uint32_t* pnItemCount);

#if 0
{  /* balance curly quotes */
#endif
#ifdef __cplusplus
}  /* closes extern "C" */
#endif

#endif  /* !defined(__LIB_MANIFEST_H__) */