19 #include "qgis_core.h" 
   22 #include <QExplicitlySharedDataPointer> 
   35 class QgsFeaturePrivate;
 
   58 #if (SIP_VERSION >= 0x040900 && SIP_VERSION < 0x040c01) 
   59 #define sipType_QVariant ((sipWrapperType *) sipTypeAsPyTypeObject (sipType_QVariant)) 
   65     Q_PROPERTY( 
QgsAttributes attributes READ attributes WRITE setAttributes )
 
   66     Q_PROPERTY( 
QgsFields fields READ fields WRITE setFields )
 
   67     Q_PROPERTY( 
QgsGeometry geometry READ geometry WRITE setGeometry )
 
   72     SIP_PYOBJECT __iter__();
 
   75     PyObject *attrs = sipConvertFromType( &attributes, sipType_QgsAttributes, Py_None );
 
   76     sipRes = PyObject_GetIter( attrs );
 
   79     SIP_PYOBJECT __getitem__( 
int key );
 
   82     if ( a0 < 0 || a0 >= attrs.count() )
 
   84       PyErr_SetString( PyExc_KeyError, QByteArray::number( a0 ) );
 
   89       QVariant *v = 
new QVariant( attrs.at( a0 ) );
 
   90       sipRes = sipConvertFromNewType( v, sipType_QVariant, Py_None );
 
   94     SIP_PYOBJECT __getitem__( 
const QString &name );
 
   96     int fieldIdx = sipCpp->fieldNameIndex( *a0 );
 
   99       PyErr_SetString( PyExc_KeyError, a0->toLatin1() );
 
  104       QVariant *v = 
new QVariant( sipCpp->attribute( fieldIdx ) );
 
  105       sipRes = sipConvertFromNewType( v, sipType_QVariant, Py_None );
 
  109     void __setitem__( 
int key, QVariant value / GetWrapper / );
 
  113     if ( a1Wrapper == Py_None )
 
  115       rv = sipCpp->setAttribute( a0, QVariant( QVariant::Int ) );
 
  119       rv = sipCpp->setAttribute( a0, *a1 );
 
  124       PyErr_SetString( PyExc_KeyError, QByteArray::number( a0 ) );
 
  129     void __setitem__( 
const QString &key, QVariant value / GetWrapper / );
 
  131     int fieldIdx = sipCpp->fieldNameIndex( *a0 );
 
  132     if ( fieldIdx == -1 )
 
  134       PyErr_SetString( PyExc_KeyError, a0->toLatin1() );
 
  139       if ( a1Wrapper == Py_None )
 
  141         sipCpp->setAttribute( *a0, QVariant( QVariant::Int ) );
 
  145         sipCpp->setAttribute( fieldIdx, *a1 );
 
  150     void __delitem__( 
int key );
 
  152     if ( a0 >= 0 && a0 < sipCpp->attributes().count() )
 
  153       sipCpp->deleteAttribute( a0 );
 
  156       PyErr_SetString( PyExc_KeyError, QByteArray::number( a0 ) );
 
  161     void __delitem__( 
const QString &name );
 
  163     int fieldIdx = sipCpp->fieldNameIndex( *a0 );
 
  164     if ( fieldIdx == -1 )
 
  166       PyErr_SetString( PyExc_KeyError, a0->toLatin1() );
 
  170       sipCpp->deleteAttribute( fieldIdx );
 
  263     QVariantMap attributeMap() 
const;
 
  277     SIP_PYOBJECT attributeMap() const 
SIP_TYPEHINT( Dict[
str, Optional[
object]] );
 
  279     const 
int fieldSize = sipCpp->fields().size();
 
  280     const 
int attributeSize = sipCpp->attributes().size();
 
  281     if ( fieldSize == 0 && attributeSize != 0 )
 
  283       PyErr_SetString( PyExc_ValueError, QStringLiteral( 
"Field definition has not been set for feature" ).toUtf8().constData() );
 
  286     else if ( fieldSize != attributeSize )
 
  288       PyErr_SetString( PyExc_ValueError, QStringLiteral( 
"Feature attribute size (%1) does not match number of fields (%2)" ).arg( attributeSize ).arg( fieldSize ).toUtf8().constData() );
 
  293       QVariantMap *v = 
new QVariantMap( sipCpp->attributeMap() );
 
  294       sipRes = sipConvertFromNewType( v, sipType_QVariantMap, Py_None );
 
  303     int attributeCount() 
const;
 
  335     bool setAttribute( 
int field, 
const QVariant &attr );
 
  362     bool setAttribute( 
int field, 
const QVariant &attr / GetWrapper / );
 
  366     if ( a1Wrapper == Py_None )
 
  368       rv = sipCpp->setAttribute( a0, QVariant( QVariant::Int ) );
 
  372       rv = sipCpp->setAttribute( a0, *a1 );
 
  377       PyErr_SetString( PyExc_KeyError, QByteArray::number( a0 ) );
 
  394     void initAttributes( 
int fieldCount );
 
  409     void resizeAttributes( 
int fieldCount );
 
  417     void padAttributes( 
int count );
 
  428     void deleteAttribute( 
int field );
 
  455     void deleteAttribute( 
int field );
 
  457     if ( a0 >= 0 && a0 < sipCpp->attributes().count() )
 
  458       sipCpp->deleteAttribute( a0 );
 
  461       PyErr_SetString( PyExc_KeyError, QByteArray::number( a0 ) );
 
  475     bool isValid() 
const;
 
  484     void setValid( 
bool validity );
 
  491     bool hasGeometry() 
const;
 
  543     void setGeometry( std::unique_ptr< QgsAbstractGeometry > geometry );
 
  547     sipCpp->setGeometry( std::unique_ptr< QgsAbstractGeometry>( a0 ) );
 
  557     void clearGeometry();
 
  590     bool setAttribute( 
const QString &name, 
const QVariant &value );
 
  621     void setAttribute( 
const QString &name, 
const QVariant &value / GetWrapper / );
 
  623     int fieldIdx = sipCpp->fieldNameIndex( *a0 );
 
  624     if ( fieldIdx == -1 )
 
  626       PyErr_SetString( PyExc_KeyError, a0->toLatin1() );
 
  631       if ( a1Wrapper == Py_None )
 
  633         sipCpp->setAttribute( *a0, QVariant( QVariant::Int ) );
 
  637         sipCpp->setAttribute( fieldIdx, *a1 );
 
  654     bool deleteAttribute( 
const QString &name );
 
  686     bool deleteAttribute( 
const QString &name );
 
  688     int fieldIdx = sipCpp->fieldNameIndex( *a0 );
 
  689     if ( fieldIdx == -1 )
 
  691       PyErr_SetString( PyExc_KeyError, a0->toLatin1() );
 
  697       sipCpp->deleteAttribute( fieldIdx );
 
  714     QVariant attribute( 
const QString &name ) 
const;
 
  742     SIP_PYOBJECT attribute( 
const QString &name ) 
const;
 
  744     int fieldIdx = sipCpp->fieldNameIndex( *a0 );
 
  745     if ( fieldIdx == -1 )
 
  747       PyErr_SetString( PyExc_KeyError, a0->toLatin1() );
 
  752       QVariant *v = 
new QVariant( sipCpp->attribute( fieldIdx ) );
 
  753       sipRes = sipConvertFromNewType( v, sipType_QVariant, Py_None );
 
  767     QVariant attribute( 
int fieldIdx ) 
const;
 
  794     SIP_PYOBJECT attribute( 
int fieldIdx ) 
const;
 
  797       if ( a0 < 0 || a0 >= sipCpp->attributes().count() )
 
  799         PyErr_SetString( PyExc_KeyError, QByteArray::number( a0 ) );
 
  804         QVariant *v = 
new QVariant( sipCpp->attribute( a0 ) );
 
  805         sipRes = sipConvertFromNewType( v, sipType_QVariant, Py_None );
 
  836     int fieldNameIndex( 
const QString &fieldName ) 
const;
 
  847     int approximateMemoryUsage() 
const;
 
  850     operator QVariant()
 const 
  852       return QVariant::fromValue( *
this );
 
  857     QExplicitlySharedDataPointer<QgsFeaturePrivate> d;
 
Abstract base class for all geometries.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Encapsulate a field in an attribute table or data source.
Container of fields for a vector layer.
A geometry is the spatial representation of a feature.
A rectangle specified with double values.
Abstract base class for all rendered symbols.
#define SIP_TYPEHINT(type)
#define SIP_PYARGDEFAULT(value)
QMap< QgsFeatureId, QgsGeometry > QgsGeometryMap
CORE_EXPORT QDataStream & operator>>(QDataStream &in, QgsFeature &feature)
Reads a feature from stream in into feature. QGIS version compatibility is not guaranteed.
QMap< QgsFeatureId, QgsAttributeMap > QgsChangedAttributesMap
CORE_EXPORT QDataStream & operator<<(QDataStream &out, const QgsFeature &feature)
Writes the feature to stream out. QGIS version compatibility is not guaranteed.
uint qHash(const QgsFeature &key, uint seed=0)
QList< QgsFeature > QgsFeatureList
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features
bool operator==(const QgsFeatureIterator &fi1, const QgsFeatureIterator &fi2)
bool operator!=(const QgsFeatureIterator &fi1, const QgsFeatureIterator &fi2)
Q_DECLARE_METATYPE(QgsMeshTimeSettings)