Home | History | Annotate | Download | only in canon
      1 /* exif-mnote-data-canon.h
      2  *
      3  * Copyright (c) 2002, 2003 Lutz Mueller <lutz (at) users.sourceforge.net>
      4  *
      5  * This library is free software; you can redistribute it and/or
      6  * modify it under the terms of the GNU Lesser General Public
      7  * License as published by the Free Software Foundation; either
      8  * version 2 of the License, or (at your option) any later version.
      9  *
     10  * This library is distributed in the hope that it will be useful,
     11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
     12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     13  * Lesser General Public License for more details.
     14  *
     15  * You should have received a copy of the GNU Lesser General Public
     16  * License along with this library; if not, write to the
     17  * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
     18  * Boston, MA  02110-1301  USA.
     19  */
     20 
     21 #ifndef __EXIF_MNOTE_DATA_CANON_H__
     22 #define __EXIF_MNOTE_DATA_CANON_H__
     23 
     24 #include <libexif/exif-byte-order.h>
     25 #include <libexif/exif-mnote-data.h>
     26 #include <libexif/exif-mnote-data-priv.h>
     27 #include <libexif/exif-mem.h>
     28 #include <libexif/exif-data.h>
     29 
     30 typedef struct _ExifMnoteDataCanon ExifMnoteDataCanon;
     31 
     32 #include <libexif/canon/mnote-canon-entry.h>
     33 
     34 struct _ExifMnoteDataCanon {
     35 	ExifMnoteData parent;
     36 
     37 	MnoteCanonEntry *entries;
     38 	unsigned int count;
     39 
     40 	ExifByteOrder order;
     41 	unsigned int offset;
     42 
     43 	ExifDataOption options;
     44 };
     45 
     46 /*! Detect if MakerNote is recognized as one handled by the Canon module.
     47  *
     48  * \param[in] ed image #ExifData to identify as as a Canon type
     49  * \param[in] e #ExifEntry for EXIF_TAG_MAKER_NOTE, from within ed but
     50  *   duplicated here for convenience
     51  * \return 0 if not recognized, nonzero if recognized. The specific nonzero
     52  *   value returned may identify a subtype unique within this module.
     53  */
     54 int exif_mnote_data_canon_identify (const ExifData *ed, const ExifEntry *e);
     55 
     56 ExifMnoteData *exif_mnote_data_canon_new (ExifMem *mem, ExifDataOption o);
     57 
     58 #endif /* __EXIF_MNOTE_DATA_CANON_H__ */
     59