#include "qgsproject.h"
#include <deque>
#include <memory>
#include "qgsdatasourceuri.h"
#include "qgsexception.h"
#include "qgslayertree.h"
#include "qgslayertreeutils.h"
#include "qgslayertreeregistrybridge.h"
#include "qgslogger.h"
#include "qgsmaplayerregistry.h"
#include "qgspluginlayer.h"
#include "qgspluginlayerregistry.h"
#include "qgsprojectfiletransform.h"
#include "qgsprojectproperty.h"
#include "qgsprojectversion.h"
#include "qgsrasterlayer.h"
#include "qgsrectangle.h"
#include "qgsrelationmanager.h"
#include "qgsvectorlayer.h"
#include <QApplication>
#include <QFileInfo>
#include <QDomNode>
#include <QObject>
#include <QTextStream>
Go to the source code of this file.
Functions |
static void | _getProperties (QDomDocument const &doc, QgsPropertyKey &project_properties) |
| Restore any optional properties found in "doc" to "properties".
|
static void | _getTitle (QDomDocument const &doc, QString &title) |
| Get the project title.
|
static QgsProjectVersion | _getVersion (QDomDocument const &doc) |
| return the version string found in the given Dom document
|
static QgsProperty * | addKey_ (QString const &scope, QString const &key, QgsPropertyKey *rootProperty, QVariant value) |
| add the given key and value
|
static void | dump_ (QgsPropertyKey const &topQgsPropertyKey) |
static QgsProperty * | findKey_ (QString const &scope, QString const &key, QgsPropertyKey &rootProperty) |
| return the property that matches the given key sequence, if any
|
static QStringList | makeKeyTokens_ (QString const &scope, QString const &key) |
| Take the given scope and key and convert them to a string list of key tokens that will be used to navigate through a Property hierarchy.
|
static void | removeKey_ (QString const &scope, QString const &key, QgsPropertyKey &rootProperty) |
Function Documentation
static void _getProperties |
( |
QDomDocument const & |
doc, |
|
|
QgsPropertyKey & |
project_properties |
|
) |
| |
|
static |
Restore any optional properties found in "doc" to "properties".
properties tags for all optional properties. Within that there will be scope tags. In the following example there exist one property in the "fsplugin" scope. "layers" is a list containing three string values.
<properties>
<fsplugin>
<foo type="int" >42</foo>
<baz type="int" >1</baz>
<layers type="QStringList" >
<value>railroad</value>
<value>airport</value>
</layers>
<xyqzzy type="int" >1</xyqzzy>
<bar type="double" >123.456</bar>
<feature_types type="QStringList" >
<value>type</value>
</feature_types>
</fsplugin>
</properties>
- Parameters
-
doc | xml document |
project_properties | should be the top QgsPropertyKey node. |
Definition at line 468 of file qgsproject.cpp.
static void _getTitle |
( |
QDomDocument const & |
doc, |
|
|
QString & |
title |
|
) |
| |
|
static |
Get the project title.
XML in file has this form:
<qgis projectname="default project">
<title>a project title</title>
- Todo:
- XXX we should go with the attribute xor title, not both.
Definition at line 513 of file qgsproject.cpp.
return the version string found in the given Dom document
- Returns
- the version string or an empty string if none found
Definition at line 552 of file qgsproject.cpp.
add the given key and value
- Parameters
-
scope | scope of key |
key | key name |
rootProperty | is the property from which to start adding |
value | the value associated with the key |
Definition at line 158 of file qgsproject.cpp.
return the property that matches the given key sequence, if any
- Parameters
-
scope | scope of key |
key | keyname |
rootProperty | is likely to be the top level QgsPropertyKey in QgsProject:e:Imp. |
- Returns
- null if not found, otherwise located Property
Definition at line 82 of file qgsproject.cpp.
static QStringList makeKeyTokens_ |
( |
QString const & |
scope, |
|
|
QString const & |
key |
|
) |
| |
|
static |
Take the given scope and key and convert them to a string list of key tokens that will be used to navigate through a Property hierarchy.
E.g., scope "someplugin" and key "/foo/bar/baz" will become a string list of { "properties", "someplugin", "foo", "bar", "baz" }. "properties" is always first because that's the permanent ``root'' Property node.
Definition at line 58 of file qgsproject.cpp.
static void removeKey_ |
( |
QString const & |
scope, |
|
|
QString const & |
key, |
|
|
QgsPropertyKey & |
rootProperty |
|
) |
| |
|
static |