handle illegal offsets earlier
[platform/upstream/libexif.git] / libexif / exif-utils.h
index 3e5e15c..dac701a 100644 (file)
@@ -16,8 +16,8 @@
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA  02110-1301  USA.
  */
 
 #ifndef __EXIF_UTILS_H__
@@ -35,31 +35,86 @@ extern "C" {
 /* If these definitions don't work for you, please let us fix the 
  * macro generating _stdint.h */
        
+/*! EXIF Unsigned Byte data type */
 typedef unsigned char  ExifByte;          /* 1 byte  */
+       
+/*! EXIF Signed Byte data type */
 typedef signed char    ExifSByte;         /* 1 byte  */
+       
+/*! EXIF Text String data type */
 typedef char *         ExifAscii;
+       
+/*! EXIF Unsigned Short data type */
 typedef uint16_t       ExifShort;         /* 2 bytes */
+       
+/*! EXIF Signed Short data type */
 typedef int16_t         ExifSShort;        /* 2 bytes */
+       
+/*! EXIF Unsigned Long data type */
 typedef uint32_t       ExifLong;          /* 4 bytes */
+       
+/*! EXIF Signed Long data type */
+typedef int32_t                ExifSLong;         /* 4 bytes */
 
-/*! EXIF Unsigned Rational */
+/*! EXIF Unsigned Rational data type */
 typedef struct {ExifLong numerator; ExifLong denominator;} ExifRational;
 
 typedef char           ExifUndefined;     /* 1 byte  */
-typedef int32_t                ExifSLong;         /* 4 bytes */
 
-/*! EXIF Signed Rational. */
+/*! EXIF Signed Rational data type */
 typedef struct {ExifSLong numerator; ExifSLong denominator;} ExifSRational;
 
 
+/*! Retrieve an #ExifShort value from memory.
+ *
+ * \param[in] b pointer to raw EXIF value in memory
+ * \param[in] order byte order of raw value
+ * \return value
+ */
 ExifShort     exif_get_short     (const unsigned char *b, ExifByteOrder order);
+
+/*! Retrieve an #ExifSShort value from memory.
+ *
+ * \param[in] b pointer to raw EXIF value in memory
+ * \param[in] order byte order of raw value
+ * \return value
+ */
 ExifSShort    exif_get_sshort    (const unsigned char *b, ExifByteOrder order);
+
+/*! Retrieve an #ExifLong value from memory.
+ *
+ * \param[in] b pointer to raw EXIF value in memory
+ * \param[in] order byte order of raw value
+ * \return value
+ */
 ExifLong      exif_get_long      (const unsigned char *b, ExifByteOrder order);
+
+/*! Retrieve an #ExifSLong value from memory.
+ *
+ * \param[in] b pointer to raw EXIF value in memory
+ * \param[in] order byte order of raw value
+ * \return value
+ */
 ExifSLong     exif_get_slong     (const unsigned char *b, ExifByteOrder order);
+
+/*! Retrieve an #ExifRational value from memory.
+ *
+ * \param[in] b pointer to raw EXIF value in memory
+ * \param[in] order byte order of raw value
+ * \return value
+ */
 ExifRational  exif_get_rational  (const unsigned char *b, ExifByteOrder order);
+
+/*! Retrieve an #ExifSRational value from memory.
+ *
+ * \param[in] b pointer to raw EXIF value in memory
+ * \param[in] order byte order of raw value
+ * \return value
+ */
 ExifSRational exif_get_srational (const unsigned char *b, ExifByteOrder order);
 
-/*! Store an ExifShort value into memory in EXIF format
+/*! Store an ExifShort value into memory in EXIF format.
+ *
  * \param[out] b buffer in which to write raw value
  * \param[in] order byte order to use
  * \param[in] value data value to store
@@ -67,7 +122,8 @@ ExifSRational exif_get_srational (const unsigned char *b, ExifByteOrder order);
 void exif_set_short     (unsigned char *b, ExifByteOrder order,
                         ExifShort value);
 
-/*! Store an ExifSShort value into memory in EXIF format
+/*! Store an ExifSShort value into memory in EXIF format.
+ *
  * \param[out] b buffer in which to write raw value
  * \param[in] order byte order to use
  * \param[in] value data value to store
@@ -75,7 +131,8 @@ void exif_set_short     (unsigned char *b, ExifByteOrder order,
 void exif_set_sshort    (unsigned char *b, ExifByteOrder order,
                         ExifSShort value);
 
-/*! Store an ExifLong value into memory in EXIF format
+/*! Store an ExifLong value into memory in EXIF format.
+ *
  * \param[out] b buffer in which to write raw value
  * \param[in] order byte order to use
  * \param[in] value data value to store
@@ -83,7 +140,8 @@ void exif_set_sshort    (unsigned char *b, ExifByteOrder order,
 void exif_set_long      (unsigned char *b, ExifByteOrder order,
                         ExifLong value);
 
-/*! Store an ExifSLong value into memory in EXIF format
+/*! Store an ExifSLong value into memory in EXIF format.
+ *
  * \param[out] b buffer in which to write raw value
  * \param[in] order byte order to use
  * \param[in] value data value to store
@@ -91,7 +149,8 @@ void exif_set_long      (unsigned char *b, ExifByteOrder order,
 void exif_set_slong     (unsigned char *b, ExifByteOrder order,
                         ExifSLong value);
 
-/*! Store an ExifRational value into memory in EXIF format
+/*! Store an ExifRational value into memory in EXIF format.
+ *
  * \param[out] b buffer in which to write raw value
  * \param[in] order byte order to use
  * \param[in] value data value to store
@@ -99,7 +158,8 @@ void exif_set_slong     (unsigned char *b, ExifByteOrder order,
 void exif_set_rational  (unsigned char *b, ExifByteOrder order,
                         ExifRational value);
 
-/*! Store an ExifSRational value into memory in EXIF format
+/*! Store an ExifSRational value into memory in EXIF format.
+ *
  * \param[out] b buffer in which to write raw value
  * \param[in] order byte order to use
  * \param[in] value data value to store
@@ -107,9 +167,12 @@ void exif_set_rational  (unsigned char *b, ExifByteOrder order,
 void exif_set_srational (unsigned char *b, ExifByteOrder order,
                         ExifSRational value);
 
-void exif_convert_utf16_to_utf8 (char *out, const unsigned short *in, int maxlen);
+/*! \internal */
+void exif_convert_utf16_to_utf8 (char *out, const unsigned char *in, int maxlen);
 
 /* Please do not use this function outside of the library. */
+
+/*! \internal */
 void exif_array_set_byte_order (ExifFormat, unsigned char *, unsigned int,
                ExifByteOrder o_orig, ExifByteOrder o_new);
 
@@ -120,6 +183,8 @@ void exif_array_set_byte_order (ExifFormat, unsigned char *, unsigned int,
 #define MAX(a, b)  (((a) > (b)) ? (a) : (b))
 
 /* For compatibility with older versions */
+
+/*! \deprecated Use EXIF_TAG_SUB_SEC_TIME instead. */
 #define EXIF_TAG_SUBSEC_TIME EXIF_TAG_SUB_SEC_TIME
 
 #ifdef __cplusplus