QGIS API Documentation  3.8.0-Zanzibar (11aff65)
qgsreadwritecontext.h
Go to the documentation of this file.
1 /***************************************************************************
2  qgsreadwritecontext.h
3  ----------------------
4  begin : May 2017
5  copyright : (C) 2017 by Martin Dobias
6  email : wonder dot sk at gmail dot com
7  ***************************************************************************/
8 
9 /***************************************************************************
10  * *
11  * This program is free software; you can redistribute it and/or modify *
12  * it under the terms of the GNU General Public License as published by *
13  * the Free Software Foundation; either version 2 of the License, or *
14  * (at your option) any later version. *
15  * *
16  ***************************************************************************/
17 
18 #ifndef QGSREADWRITECONTEXT_H
19 #define QGSREADWRITECONTEXT_H
20 
21 #include "qgspathresolver.h"
22 #include "qgis.h"
23 #include "qgsprojecttranslator.h"
25 
27 
34 class CORE_EXPORT QgsReadWriteContext
35 {
36  public:
37 
43  {
45  ReadWriteMessage( const QString &message, Qgis::MessageLevel level = Qgis::Warning, const QStringList &categories = QStringList() )
46  : mMessage( message )
47  , mLevel( level )
48  , mCategories( categories )
49  {}
50 
52  QString message() const {return mMessage;}
53 
55  Qgis::MessageLevel level() const {return mLevel;}
56 
58  QStringList categories() const {return mCategories;}
59 
60  private:
61  QString mMessage;
62  Qgis::MessageLevel mLevel;
63  QStringList mCategories;
64  };
65 
70 
72 
74  const QgsPathResolver &pathResolver() const;
75 
77  void setPathResolver( const QgsPathResolver &resolver );
78 
83  void pushMessage( const QString &message, Qgis::MessageLevel level = Qgis::Warning );
84 
96  MAYBE_UNUSED NODISCARD QgsReadWriteContextCategoryPopper enterCategory( const QString &category, const QString &details = QString() ) SIP_PYNAME( _enterCategory );
97 
102  QList<QgsReadWriteContext::ReadWriteMessage> takeMessages();
103 
108  const QgsProjectTranslator *projectTranslator( ) const { return mProjectTranslator; }
109 
116  void setProjectTranslator( QgsProjectTranslator *projectTranslator );
117 
125  QgsCoordinateTransformContext transformContext() const;
126 
134  void setTransformContext( const QgsCoordinateTransformContext &transformContext );
135 
136  private:
137 
138  class DefaultTranslator : public QgsProjectTranslator
139  {
140  // QgsProjectTranslator interface
141  public:
142  QString translate( const QString &context, const QString &sourceText, const char *disambiguation, int n ) const;
143  };
144 
146  void leaveCategory();
147 
148  QgsPathResolver mPathResolver;
149  QList<ReadWriteMessage> mMessages;
150  QStringList mCategories = QStringList();
151  QgsProjectTranslator *mProjectTranslator = nullptr;
153  DefaultTranslator mDefaultTranslator;
154  QgsCoordinateTransformContext mCoordinateTransformContext = QgsCoordinateTransformContext();
155 };
156 
157 
167 {
168  public:
170  QgsReadWriteContextCategoryPopper( QgsReadWriteContext &context ) : mContext( context ) {}
171  ~QgsReadWriteContextCategoryPopper() {mContext.leaveCategory();}
172  private:
173  QgsReadWriteContext &mContext;
174 };
175 
176 #endif // QGSREADWRITECONTEXT_H
The class is used as a container of context for various read/write operations on other objects...
QString message() const
Returns the message string.
#define NODISCARD
Definition: qgis.h:675
QStringList categories() const
Returns the stack of categories of the message.
ReadWriteMessage(const QString &message, Qgis::MessageLevel level=Qgis::Warning, const QStringList &categories=QStringList())
Construct a container for QgsReadWriteContext error or warning messages.
Allows entering a context category and takes care of leaving this category on deletion of the class...
MessageLevel
Level for messages This will be used both for message log and message bar in application.
Definition: qgis.h:66
const QgsProjectTranslator * projectTranslator() const
Returns the project translator.
Struct for QgsReadWriteContext error or warning messages.
Contains information about the context in which a coordinate transform is executed.
Wherever an object of this class is available, the derived translate function can be called from...
QgsReadWriteContextCategoryPopper(QgsReadWriteContext &context)
Creates a popper.
Qgis::MessageLevel level() const
Returns the message level.
#define MAYBE_UNUSED
Definition: qgis.h:691
Resolves relative paths into absolute paths and vice versa.
#define SIP_PYNAME(name)
Definition: qgis_sip.h:74