/usr/include/sipxtapi/utl/UtlNameValueTokenizer.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 | //
// Copyright (C) 2007 SIPez LLC.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// Copyright (C) 2004-2007 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _UtlNameValueTokenizer_h_
#define _UtlNameValueTokenizer_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "utl/UtlString.h"
// DEFINES
#define NEWLINE '\n'
#define CARRIAGE_RETURN '\r'
#define CARRIAGE_RETURN_NEWLINE "\r\n"
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
/// Parses name value pairs from multiple lines of text.
class UtlNameValueTokenizer
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
/* ============================ CREATORS ================================== */
/// Constructor.
UtlNameValueTokenizer(const char* multiLineText, int textLength = -1);
/// Destructor.
virtual
~UtlNameValueTokenizer();
/* ============================ MANIPULATORS ============================== */
/// Finds the index to the next line terminator.
static
int findNextLineTerminator(const char* text, int length,
int* nextLineIndex);
/**<
* @param[in] text - The char array in which to search for the
* terminator.
* @param[in] length - The length of the text array.
* @param[in] nextLineIndex - The index to the beginning of the next
* line. This may be -1 if the end of the string is encountered.
*
* @note The line terminator may be 1 or 2 characters.
*
* @returns Index into the text char array to the line terminator.
*/
static
UtlBoolean getSubField(const char* textField,
int subfieldIndex,
const char* subfieldSeparator,
UtlString* subfieldText,
int* lastCharIndex = NULL);
static
UtlBoolean getSubField(const char* textField,
int textFieldLength,
int subfieldIndex,
const char* subfieldSeparators,
const char*& subfieldPtr,
int& subFieldLength,
int* lastCharIndex);
UtlBoolean getNextPair(char separator, UtlString* name, UtlString* value);
/* ============================ ACCESSORS ================================= */
/* ============================ INQUIRY =================================== */
UtlBoolean isAtEnd();
int getProcessedIndex();
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
const char* textPtr;
int textLen;
int bytesConsumed;
/// Disabled Copy constructor
UtlNameValueTokenizer(const UtlNameValueTokenizer& rNameValueTokenizer);
/// Disabled Assignment operator
UtlNameValueTokenizer& operator=(const UtlNameValueTokenizer& rhs);
};
/* ============================ INLINE METHODS ============================ */
#endif // _UtlNameValueTokenizer_h_
|