/* 
 * This file is part of the KDE project
 * 
 * Copyright (c) 2005 Boudewijn Rempt <boud@valdyas.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 */

#ifndef _KIS_ANNOTATION_H_
#define _KIS_ANNOTATION_H_

#include <ksharedptr.h>
#include "kis_shared_ptr_vector.h"

#include <tqstring.h>
#include <tqcstring.h>
#include <tqmemarray.h>

/**
 * An data extension mechanism for Chalk.
 * 
 * An annotation can be of something like a TQByteArray or a TQString op a more specific
 * datatype that can be attached to an image (or maybe later, if needed, to a layer)
 * and contains data that must be associated with an image for purposes of import/export.
 * 
 * Annotations will be saved to chalk images and may be exported in filetypes that support
 * them.
 *
 * Examples of annotations are EXIF data and ICC profiles.
 */
class KisAnnotation : public KShared {


public:

    /**
     * Creates a new annotation object. The annotation object cannot be changed later
     *
     * @param type a non-localized string identifying the type of the annotation
     * @param description a localized string describing the annotation
     * @param data a binary blob containing the annotation data
     */
    KisAnnotation(const TQString & type, const TQString & description, const TQByteArray & data)
        : m_type(type),
          m_description(description),
          m_annotation(data) {};

    /**
     * @return a non-localized string identifiying the type of the annotation
     */
    TQString & type() {return m_type;};

    /**
     * @return a localized string describing the type of the annotations
     *         for user interface purposes.
     */
    TQString & description() {return m_description;};

    /**
     * @return a binary blob representation of this annotation
     */
    TQByteArray & annotation() { return m_annotation;};

private:

    TQString m_type;
    TQString m_description;
    TQByteArray m_annotation;

};

typedef KSharedPtr<KisAnnotation> KisAnnotationSP;
typedef KisSharedPtrVector<KisAnnotation> vKisAnnotationSP;
typedef vKisAnnotationSP::iterator vKisAnnotationSP_it;
typedef vKisAnnotationSP::const_iterator vKisAnnotationSP_cit;

#endif // _KIS_ANNOTATION_H_