/usr/include/kasten/okteta/charsetconversiontool.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 | /*
This file is part of the Okteta Kasten module, made within the KDE community.
Copyright 2011 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 CHARSETCONVERSIONTOOL_H
#define CHARSETCONVERSIONTOOL_H
// lib
#include <kasten/okteta/oktetakastencontrollers_export.h>
// Kasten core
#include <kasten/abstracttool.h>
// Okteta core
#include <okteta/byte.h>
// Qt
#include <QList>
namespace Okteta {
class AbstractByteArrayModel;
class CharCodec;
}
template <class Key, class T> class QMap;
namespace Kasten
{
class ByteArrayView;
/**
*/
class OKTETAKASTENCONTROLLERS_EXPORT CharsetConversionTool : public AbstractTool
{
Q_OBJECT
public:
enum ConversionDirection { ConvertFrom, ConvertTo };
public:
CharsetConversionTool();
~CharsetConversionTool() override;
public: // AbstractTool API
// virtual AbstractModel* targetModel() const;
QString title() const override;
void setTargetModel( AbstractModel* model ) override;
public: // status
bool isApplyable() const; // candidate for AbstractTool API
QString otherCharCodecName() const;
ConversionDirection conversionDirection() const;
bool isSubstitutingMissingChars() const;
Okteta::Byte substituteByte() const;
public Q_SLOTS: // settings
void setConversionDirection( int conversionDirection );
void setOtherCharCodecName( const QString& codecName );
void setSubstitutingMissingChars( bool isSubstitutingMissingChars );
void setSubstituteByte( int byte );
public Q_SLOTS: // actions
void convertChars();
Q_SIGNALS:
void isApplyableChanged( bool isApplyable ); // candidate for AbstractTool API
void conversionDone( bool success, int convertedBytesCount,
const QMap<Okteta::Byte, int>& failedPerByteCount );
private Q_SLOTS:
void onViewChanged();
private: // settings
QString mOtherCharCodecName;
ConversionDirection mConversionDirection;
bool mSubstitutingMissingChars;
Okteta::Byte mSubstituteByte;
private: // sources
ByteArrayView* mByteArrayView;
Okteta::AbstractByteArrayModel* mByteArrayModel;
};
}
#endif
|