/usr/include/okteta/bytearraymodel.h is in okteta-dev 4:17.12.3-0ubuntu1.
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 | /*
This file is part of the Okteta Core library, made within the KDE community.
Copyright 2003,2007 Friedrich W. H. Kossebau <kossebau@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) version 3, or any
later version accepted by the membership of KDE e.V. (or its
successor approved by the membership of KDE e.V.), which shall
act as a proxy defined in Section 6 of version 3 of the license.
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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef OKTETA_BYTEARRAYMODEL_H
#define OKTETA_BYTEARRAYMODEL_H
// lib
#include <okteta/abstractbytearraymodel.h>
#include <okteta/bookmarkable.h>
#include <okteta/bookmarksconstiterator.h>
namespace Okteta
{
class ByteArrayModelPrivate;
/**
*@author Friedrich W. H. Kossebau
*/
class OKTETACORE_EXPORT ByteArrayModel : public AbstractByteArrayModel,
public Bookmarkable
{
Q_OBJECT
Q_INTERFACES(
Okteta::Bookmarkable
)
friend class ByteArrayModelPrivate;
public:
ByteArrayModel( Byte* data, int size, int rawSize = -1, bool keepsMemory = true, QObject* parent = nullptr );
ByteArrayModel( const Byte* data, int size, QObject* parent = nullptr );
explicit ByteArrayModel( int size = 0, int maxSize = -1, QObject* parent = nullptr );
~ByteArrayModel() override;
public: // AbstractByteArrayModel API
Byte byte( Address offset ) const override;
Size size() const override;
bool isReadOnly() const override;
bool isModified() const override;
Size insert( Address offset, const Byte* insertData, int insertLength ) override;
Size remove( const AddressRange& removeRange ) override;
Size replace( const AddressRange& removeRange, const Byte* insertData, int insertLength ) override;
bool swap( Address firstStart, const AddressRange& secondRange ) override;
Size fill( Byte fillByte, Address offset = 0, Size fillLength = -1 ) override;
void setByte( Address offset, Byte byte ) override;
void setModified( bool modified = true ) override;
void setReadOnly( bool isReadOnly = true ) override;
public: // Okteta::Bookmarkable API
void addBookmarks( const QList<Okteta::Bookmark> &bookmarks ) override;
void removeBookmarks( const QList<Okteta::Bookmark> &bookmarks ) override;
void removeAllBookmarks() override;
void setBookmark( unsigned int index, const Okteta::Bookmark& bookmark ) override;
Okteta::BookmarksConstIterator createBookmarksConstIterator() const override;
const Okteta::Bookmark& bookmarkAt( unsigned int index ) const override;
const Okteta::Bookmark& bookmarkFor( int offset ) const override;
bool containsBookmarkFor( int offset ) const override;
unsigned int bookmarksCount() const override;
Q_SIGNALS: // Okteta::Bookmarkable API
void bookmarksAdded( const QList<Okteta::Bookmark> &bookmarks ) override;
void bookmarksRemoved( const QList<Okteta::Bookmark> &bookmarks ) override;
void bookmarksModified( bool modified ) override;
void bookmarksModified( const QList<int>& indizes ) override;
public:
void setMaxSize( int maxSize );
/** sets whether the memory given by setData or in the constructor should be kept on resize
*/
void setKeepsMemory( bool keepsMemory = true );
/** sets whether the memory given by setData or in the constructor gets deleted in destructor
* or when new data is set. The data MUST have been allocated using new[] otherwise behaviour
* is undefined */
void setAutoDelete( bool autoDelete = true );
void setData( Byte* data, int size, int rawSize = -1, bool keepsMemory = true );
void signalContentsChanged( int i1, int i2 );
public:
Byte* data() const;
int maxSize() const;
/** returns whether the memory of the byte array is kept on resize */
bool keepsMemory() const;
bool autoDelete() const;
protected:
ByteArrayModelPrivate* const d;
};
}
#endif
|