/************************************************************************
 * This file has been generated automatically from                      *
 *                                                                      *
 * src/core/qgsfield.h                                                  *
 *                                                                      *
 * Do not edit manually ! Edit header and run scripts/sipify.pl again   *
 ************************************************************************/







class QgsField
{
%Docstring
 Encapsulate a field in an attribute table or data source.
 QgsField stores metadata about an attribute field, including name, type
 length, and if applicable, precision.
.. note::

   QgsField objects are implicitly shared.
%End

%TypeHeaderCode
#include "qgsfield.h"
%End
  public:

    QgsField( const QString &name = QString(),
              QVariant::Type type = QVariant::Invalid,
              const QString &typeName = QString(),
              int len = 0,
              int prec = 0,
              const QString &comment = QString(),
              QVariant::Type subType = QVariant::Invalid );
%Docstring
 Constructor. Constructs a new QgsField object.
 \param name Field name
 \param type Field variant type, currently supported: String / Int / Double
 \param typeName Field type (e.g., char, varchar, text, int, serial, double).
 Field types are usually unique to the source and are stored exactly
 as returned from the data store.
 \param len Field length
 \param prec Field precision. Usually decimal places but may also be
 used in conjunction with other fields types (e.g., variable character fields)
 \param comment Comment for the field
 \param subType If the field is a collection, its element's type. When
                all the elements don't need to have the same type, leave
                this to QVariant.Invalid.
%End

    QgsField( const QgsField &other );
%Docstring
 Copy constructor
%End


    virtual ~QgsField();

    bool operator==( const QgsField &other ) const;
    bool operator!=( const QgsField &other ) const;
%Docstring
 :rtype: bool
%End

    QString name() const;
%Docstring
 Returns the name of the field.
.. seealso:: setName()
.. seealso:: displayName()
 :rtype: str
%End

    QString displayName() const;
%Docstring
 Returns the name to use when displaying this field. This will be the
 field alias if set, otherwise the field name.
.. seealso:: name()
.. seealso:: alias()
.. versionadded:: 3.0
 :rtype: str
%End

    QVariant::Type type() const;
%Docstring
Gets variant type of the field as it will be retrieved from data source
 :rtype: QVariant.Type
%End

    QVariant::Type subType() const;
%Docstring
 If the field is a collection, gets its element's type.
 When all the elements don't need to have the same type, this returns
 QVariant.Invalid.
.. versionadded:: 3.0
 :rtype: QVariant.Type
%End

    QString typeName() const;
%Docstring
 Gets the field type. Field types vary depending on the data source. Examples
 are char, int, double, blob, geometry, etc. The type is stored exactly as
 the data store reports it, with no attempt to standardize the value.
 :return: QString containing the field type
 :rtype: str
%End

    int length() const;
%Docstring
 Gets the length of the field.
 :return: int containing the length of the field
 :rtype: int
%End

    int precision() const;
%Docstring
 Gets the precision of the field. Not all field types have a related precision.
 :return: int containing the precision or zero if not applicable to the field type.
 :rtype: int
%End

    QString comment() const;
%Docstring
 Returns the field comment
 :rtype: str
%End

    bool isNumeric() const;
%Docstring
 Returns if this field is numeric. Any integer or floating point type
 will return true for this.

.. versionadded:: 2.18
 :rtype: bool
%End

    void setName( const QString &name );
%Docstring
 Set the field name.
 \param name Name of the field
%End

    void setType( QVariant::Type type );
%Docstring
 Set variant type.
%End

    void setSubType( QVariant::Type subType );
%Docstring
 If the field is a collection, set its element's type.
 When all the elements don't need to have the same type, set this to
 QVariant.Invalid.
.. versionadded:: 3.0
%End

    void setTypeName( const QString &typeName );
%Docstring
 Set the field type.
 \param typeName Field type
%End

    void setLength( int len );
%Docstring
 Set the field length.
 \param len Length of the field
%End

    void setPrecision( int precision );
%Docstring
 Set the field precision.
 \param precision Precision of the field
%End

    void setComment( const QString &comment );
%Docstring
 Set the field comment
%End

    QgsDefaultValue defaultValueDefinition() const;
%Docstring
 Returns the expression used when calculating the default value for the field.
 :return: expression evaluated when calculating default values for field, or an
 empty string if no default is set
.. versionadded:: 3.0
.. seealso:: setDefaultValueDefinition()
 :rtype: QgsDefaultValue
%End

    void setDefaultValueDefinition( const QgsDefaultValue &defaultValueDefinition );
%Docstring
 Sets an expression to use when calculating the default value for the field.
 \param defaultValueDefinition expression to evaluate when calculating default values for field. Pass
 a default constructed QgsDefaultValue() to reset.
.. versionadded:: 3.0
.. seealso:: defaultValueDefinition()
%End

    const QgsFieldConstraints &constraints() const;
%Docstring
 Returns constraints which are present for the field.
.. versionadded:: 3.0
.. seealso:: setConstraints()
 :rtype: QgsFieldConstraints
%End

    void setConstraints( const QgsFieldConstraints &constraints );
%Docstring
 Sets constraints which are present for the field.
.. versionadded:: 3.0
.. seealso:: constraints()
%End

    QString alias() const;
%Docstring
 Returns the alias for the field (the friendly displayed name of the field ),
 or an empty string if there is no alias.
.. seealso:: setAlias()
.. versionadded:: 3.0
 :rtype: str
%End

    void setAlias( const QString &alias );
%Docstring
 Sets the alias for the field (the friendly displayed name of the field ).
 \param alias field alias, or empty string to remove an existing alias
.. seealso:: alias()
.. versionadded:: 3.0
%End

    QString displayString( const QVariant &v ) const;
%Docstring
Formats string for display
 :rtype: str
%End

    bool convertCompatible( QVariant &v ) const;
%Docstring
 Converts the provided variant to a compatible format

 \param v  The value to convert

 :return:   True if the conversion was successful
 :rtype: bool
%End
%MethodCode
    PyObject *sipParseErr = NULL;

    {
      QVariant *a0;
      int a0State = 0;
      const QgsField *sipCpp;

      if ( sipParseArgs( &sipParseErr, sipArgs, "BJ1", &sipSelf, sipType_QgsField, &sipCpp, sipType_QVariant, &a0, &a0State ) )
      {
        bool sipRes;

        Py_BEGIN_ALLOW_THREADS
        try
        {
          QgsDebugMsg( a0->toString() );
          sipRes = sipCpp->convertCompatible( *a0 );
          QgsDebugMsg( a0->toString() );
        }
        catch ( ... )
        {
          Py_BLOCK_THREADS

          sipReleaseType( a0, sipType_QVariant, a0State );
          sipRaiseUnknownException();
          return NULL;
        }

        Py_END_ALLOW_THREADS

        PyObject *res = sipConvertFromType( a0, sipType_QVariant, NULL );
        sipReleaseType( a0, sipType_QVariant, a0State );

        if ( !sipRes )
        {
          PyErr_SetString( PyExc_ValueError,
                           QString( "Value %1 (%2) could not be converted to field type %3." ).arg( a0->toString(), a0->typeName() ).arg( sipCpp->type() ).toUtf8().constData() );
          sipError = sipErrorFail;
        }

        return res;
      }
    }

    // Raise an exception if the arguments couldn't be parsed.
    sipNoMethod( sipParseErr, sipName_QgsField, sipName_convertCompatible, doc_QgsField_convertCompatible );

    return nullptr;
%End

    operator QVariant() const;
%Docstring
Allows direct construction of QVariants from fields.
%End

    void setEditorWidgetSetup( const QgsEditorWidgetSetup &v );
%Docstring
 Set the editor widget setup for the field.

 \param v  The value to set
%End

    QgsEditorWidgetSetup editorWidgetSetup() const;
%Docstring
 Get the editor widget setup for the field.

 Defaults may be set by the provider and can be overridden
 by manual field configuration.

 :return: the value
 :rtype: QgsEditorWidgetSetup
%End

}; // class QgsField




/************************************************************************
 * This file has been generated automatically from                      *
 *                                                                      *
 * src/core/qgsfield.h                                                  *
 *                                                                      *
 * Do not edit manually ! Edit header and run scripts/sipify.pl again   *
 ************************************************************************/