]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
Move metadata API from avcodec to avformat.
authormichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Sun, 4 Jan 2009 18:58:49 +0000 (18:58 +0000)
committermichael <michael@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Sun, 4 Jan 2009 18:58:49 +0000 (18:58 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@16425 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavcodec/Makefile
libavcodec/avcodec.h
libavformat/Makefile
libavformat/avformat.h
libavformat/metadata.c [moved from libavcodec/metadata.c with 100% similarity]
libavformat/metadata.h [moved from libavcodec/metadata.h with 86% similarity]

index d7a1b4ba8ee0d340552ed897b595e0c183ed25d7..e4217d6af4b71223b8720add5aaf2356497e7376 100644 (file)
@@ -14,7 +14,6 @@ OBJS = allcodecs.o                                                      \
        faanidct.o                                                       \
        imgconvert.o                                                     \
        jrevdct.o                                                        \
-       metadata.o                                                       \
        opt.o                                                            \
        parser.o                                                         \
        raw.o                                                            \
index 7038d2d2c414bd4208ba88bd64ad9b53dc4bc52a..7c68a926f6ddf422f809877302d7071ca9ced603 100644 (file)
@@ -401,50 +401,6 @@ enum SampleFormat {
 #define FF_MIN_BUFFER_SIZE 16384
 
 
-/*
- * public Metadata API.
- * Important concepts, to keep in mind
- * 1. keys are unique, there are never 2 tags with equal keys, this is also
- *    meant semantically that is a demuxer should not knowingly produce
- *    several keys that are litterally different but semantically identical,
- *    like key=Author5, key=Author6.
- *    All authors have to be placed in the same tag for the case of Authors.
- * 2. Metadata is flat, there are no subtags, if you for whatever obscene
- *    reason want to store the email address of the child of producer alice
- *    and actor bob, that could have key=alice_and_bobs_childs_email_address.
- * 3. A tag whichs value is translated has the ISO 639 3-letter language code
- *    with a '-' between appended. So for example Author-ger=Michael, Author-eng=Mike
- *    the original/default language is in the unqualified "Author"
- *    A demuxer should set a default if it sets any translated tag.
- */
-
-#define AV_METADATA_IGNORE_CASE     1
-#define AV_METADATA_IGNORE_SUFFIX   2
-
-typedef struct {
-    char *key;
-    char *value;
-}AVMetaDataTag;
-
-struct AVMetaData;
-
-/**
- * gets a metadata element with matching key.
- * @param prev set to the previous matching element to find the next.
- * @param flags allows case as well as suffix insensitive comparissions.
- * @return found tag or NULL, changing key or value leads to undefined behavior.
- */
-AVMetaDataTag *
-av_metadata_get(struct AVMetaData *m, const char *key, const AVMetaDataTag *prev, int flags);
-
-/**
- * sets the given tag in m, overwriting an existing tag.
- * @param tag tag to add to m, key and value will be av_strduped.
- * @return >= 0 if success otherwise error code that is <0.
- */
-int av_metadata_set(struct AVMetaData **m, AVMetaDataTag tag);
-
-
 /**
  * motion estimation type.
  */
index f6ef3a71b42937470a4f75c4dc141dc36f6578a6..303242d96273bc66c3e8b8457ecec8740a99f983 100644 (file)
@@ -5,7 +5,7 @@ FFLIBS = avcodec avutil
 
 HEADERS = avformat.h avio.h rtsp.h rtspcodes.h
 
-OBJS = allformats.o cutils.o os_support.o sdp.o utils.o
+OBJS = allformats.o cutils.o metadata.o os_support.o sdp.o utils.o
 
 # muxers/demuxers
 OBJS-$(CONFIG_AAC_DEMUXER)               += raw.o
index 46e692452edab4f0888c8e8476019b8be2dd90df..39dc4765a83fc2d70e47a2b524da6110a0e197ff 100644 (file)
@@ -46,6 +46,51 @@ unsigned avformat_version(void);
 
 #include "avio.h"
 
+
+/*
+ * public Metadata API.
+ * Important concepts, to keep in mind
+ * 1. keys are unique, there are never 2 tags with equal keys, this is also
+ *    meant semantically that is a demuxer should not knowingly produce
+ *    several keys that are litterally different but semantically identical,
+ *    like key=Author5, key=Author6.
+ *    All authors have to be placed in the same tag for the case of Authors.
+ * 2. Metadata is flat, there are no subtags, if you for whatever obscene
+ *    reason want to store the email address of the child of producer alice
+ *    and actor bob, that could have key=alice_and_bobs_childs_email_address.
+ * 3. A tag whichs value is translated has the ISO 639 3-letter language code
+ *    with a '-' between appended. So for example Author-ger=Michael, Author-eng=Mike
+ *    the original/default language is in the unqualified "Author"
+ *    A demuxer should set a default if it sets any translated tag.
+ */
+
+#define AV_METADATA_IGNORE_CASE     1
+#define AV_METADATA_IGNORE_SUFFIX   2
+
+typedef struct {
+    char *key;
+    char *value;
+}AVMetaDataTag;
+
+struct AVMetaData;
+
+/**
+ * gets a metadata element with matching key.
+ * @param prev set to the previous matching element to find the next.
+ * @param flags allows case as well as suffix insensitive comparissions.
+ * @return found tag or NULL, changing key or value leads to undefined behavior.
+ */
+AVMetaDataTag *
+av_metadata_get(struct AVMetaData *m, const char *key, const AVMetaDataTag *prev, int flags);
+
+/**
+ * sets the given tag in m, overwriting an existing tag.
+ * @param tag tag to add to m, key and value will be av_strduped.
+ * @return >= 0 if success otherwise error code that is <0.
+ */
+int av_metadata_set(struct AVMetaData **m, AVMetaDataTag tag);
+
+
 /* packet functions */
 
 typedef struct AVPacket {
similarity index 100%
rename from libavcodec/metadata.c
rename to libavformat/metadata.c
similarity index 86%
rename from libavcodec/metadata.h
rename to libavformat/metadata.h
index 0ab39cba26716162121f1b33d7079353b5354af4..e9ada571a1e257c45f340c18d8caab611f11bcba 100644 (file)
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  */
 
-#ifndef AVCODEC_METADATA_H
-#define AVCODEC_METADATA_H
+#ifndef AVFORMAT_METADATA_H
+#define AVFORMAT_METADATA_H
 
 /**
  * @file metadata.h
  * internal metadata API header
- * see avcodec.h or the public API!
+ * see avformat.h or the public API!
  */
 
 
-#include "avcodec.h"
+#include "avformat.h"
 
 struct AVMetaData{
     int count;
     AVMetaDataTag *elems;
 };
 
-#endif /* AVCODEC_METADATA_H */
+#endif /* AVFORMAT_METADATA_H */