/usr/include/vmime/parserHelpers.hpp is in libvmime-dev 0.9.2-5build2.
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 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | //
// VMime library (http://www.vmime.org)
// Copyright (C) 2002-2013 Vincent Richard <vincent@vmime.org>
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
// published by the Free Software Foundation; either version 3 of
// the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
//
// Linking this library statically or dynamically with other modules is making
// a combined work based on this library. Thus, the terms and conditions of
// the GNU General Public License cover the whole combination.
//
#ifndef VMIME_PARSERHELPERS_HPP_INCLUDED
#define VMIME_PARSERHELPERS_HPP_INCLUDED
#include "vmime/types.hpp"
#include "vmime/utility/stringUtils.hpp"
#include <algorithm>
namespace vmime
{
class parserHelpers
{
public:
static bool isSpace(const char_t c)
{
return (c == ' ' || c == '\t' || c == '\n' || c == '\r');
}
static bool isSpaceOrTab(const char_t c)
{
return (c == ' ' || c == '\t');
}
static bool isDigit(const char_t c)
{
return (c >= '0' && c <= '9');
}
static bool isAlpha(const char_t c)
{
return ((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'));
}
static char_t toLower(const char_t c)
{
if (c >= 'A' && c <= 'Z')
return ('a' + (c - 'A'));
else
return c;
}
// Checks whether a character is in the 7-bit US-ASCII charset
static bool isAscii(const char_t c)
{
const unsigned int x = static_cast <unsigned int>(c);
return (x <= 127);
}
// Checks whether a character has a visual representation
static bool isPrint(const char_t c)
{
const unsigned int x = static_cast <unsigned int>(c);
return (x >= 0x20 && x <= 0x7E);
}
/** Finds the next EOL sequence in the specified buffer.
* An EOL sequence may be a CR+LF sequence, or a LF sequence.
*
* @param buffer search buffer
* @param currentPos start searching from this position
* @param end stop searching at this position
* @param eol will receive the position after the EOL sequence
* @return true if an EOL sequence has been found, or false if
* no EOL sequence was found before the end of the buffer
*/
static bool findEOL(const string& buffer, const size_t currentPos, const size_t end, size_t* eol)
{
size_t pos = currentPos;
if (pos == end)
return false;
while (pos < end)
{
if (buffer[pos] == '\r' && pos + 1 < end && buffer[pos + 1] == '\n')
{
*eol = pos + 2;
return true;
}
else if (buffer[pos] == '\n')
{
*eol = pos + 1;
return true;
}
++pos;
}
*eol = end;
return true;
}
};
} // vmime
#endif // VMIME_PARSERHELPERS_HPP_INCLUDED
|