aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFabrice Bellard <fabrice@bellard.org>2003-06-13 14:22:23 +0000
committerFabrice Bellard <fabrice@bellard.org>2003-06-13 14:22:23 +0000
commit39f472c3b6dd8405b33ad3c59f0b52046a393938 (patch)
treec173fc0b8904e494ba60783c6f2f588c9b99601d
parent124ba5836fb896e580de0ed5d2f2b0b2daee4a27 (diff)
downloadffmpeg-39f472c3b6dd8405b33ad3c59f0b52046a393938.tar.gz
dynamic array functions
Originally committed as revision 1955 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--libavformat/avformat.h10
-rw-r--r--libavformat/cutils.c21
2 files changed, 31 insertions, 0 deletions
diff --git a/libavformat/avformat.h b/libavformat/avformat.h
index 3267cba7b1..e7dab88671 100644
--- a/libavformat/avformat.h
+++ b/libavformat/avformat.h
@@ -428,6 +428,16 @@ int stristart(const char *str, const char *val, const char **ptr);
void pstrcpy(char *buf, int buf_size, const char *str);
char *pstrcat(char *buf, int buf_size, const char *s);
+void __dynarray_add(unsigned long **tab_ptr, int *nb_ptr, unsigned long elem);
+
+#define dynarray_add(tab, nb_ptr, elem)\
+do {\
+ typeof(tab) _tab = (tab);\
+ typeof(elem) _elem = (elem);\
+ (void)sizeof(**_tab == _elem); /* check that types are compatible */\
+ __dynarray_add((unsigned long **)_tab, nb_ptr, (unsigned long)_elem);\
+} while(0)
+
struct in_addr;
int resolve_host(struct in_addr *sin_addr, const char *hostname);
diff --git a/libavformat/cutils.c b/libavformat/cutils.c
index 3e46533c6b..28f40b0e2f 100644
--- a/libavformat/cutils.c
+++ b/libavformat/cutils.c
@@ -108,3 +108,24 @@ char *pstrcat(char *buf, int buf_size, const char *s)
}
#endif
+
+/* add one element to a dynamic array */
+void __dynarray_add(unsigned long **tab_ptr, int *nb_ptr, unsigned long elem)
+{
+ int nb, nb_alloc;
+ unsigned long *tab;
+
+ nb = *nb_ptr;
+ tab = *tab_ptr;
+ if ((nb & (nb - 1)) == 0) {
+ if (nb == 0)
+ nb_alloc = 1;
+ else
+ nb_alloc = nb * 2;
+ tab = av_realloc(tab, nb_alloc * sizeof(unsigned long));
+ *tab_ptr = tab;
+ }
+ tab[nb++] = elem;
+ *nb_ptr = nb;
+}
+