/usr/include/kmime/boolflags.h is in kdepimlibs5-dev 4:4.14.10-7+b2.
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 | /*
Copyright (c) 1999-2001 the KMime authors.
See file AUTHORS for details
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
/**
@file
This file is part of the API for handling @ref MIME data and
defines the BoolFlags class.
@brief
Defines the BoolFlags class.
*/
#ifndef __KMIME_BOOLFLAGS_H__
#define __KMIME_BOOLFLAGS_H__
#include "kmime_export.h"
namespace KMime {
/**
@brief
Provides a class for storing boolean values in single bytes.
This class provides functionality similar to QBitArray but requires
much less memory. Only 16-bits (or 2-bytes) can be stored.
*/
// TODO: KDE5: BIC: Remove this class, it is unused.
class KMIME_EXPORT BoolFlags {
public:
/**
Constructs an empty 2-byte flag storage.
*/
BoolFlags() { clear(); }
/**
Destroys the flag storage.
*/
~BoolFlags() {}
/**
Sets bit number @p i to the value @p b.
@param i is the bit number. Valid values are 0 through 15.
Higher values will be silently ignored.
@param b is the value to set for bit @p i.
*/
void set( unsigned int i, bool b=true );
/**
Get bit number @p i.
@param i is the bit number. Valid values are 0 through 15.
Higher values all return @c false.
@return Value of the single bit @p i.
Invalid bit numbers return @c false.
*/
bool get( unsigned int i );
/**
Sets all bits to false.
*/
void clear() { mBits[0]=0; mBits[1]=0; }
/**
Returns a pointer to the data structure used to store the bits.
*/
unsigned char *data() { return mBits; }
private:
/**
Two bytes (at least) of storage for the bits.
*/
unsigned char mBits[2]; //space for 16 flags
};
} //namespace KMime
#endif // __KMIME_BOOLFLAGS_H__
|