aboutsummaryrefslogtreecommitdiffstats
path: root/test/ffmpeg_structs/find_avtypes
diff options
context:
space:
mode:
authorlotanrm <lotanrm@b956fd51-792f-4845-bead-9b4dfca2ff2c>2013-07-11 08:49:22 +0000
committerlotanrm <lotanrm@b956fd51-792f-4845-bead-9b4dfca2ff2c>2013-07-11 08:49:22 +0000
commit2596ea5ea76e3a6bb46ce1c7c5da3ea33bcda031 (patch)
tree047d0e7e28195c110f7ea38f84cc7df3ffc49db3 /test/ffmpeg_structs/find_avtypes
parentcc0b72e5e5e1c620b654ecf14d89ac9c4706e4e6 (diff)
downloadusdx-2596ea5ea76e3a6bb46ce1c7c5da3ea33bcda031.tar.gz
usdx-2596ea5ea76e3a6bb46ce1c7c5da3ea33bcda031.tar.xz
usdx-2596ea5ea76e3a6bb46ce1c7c5da3ea33bcda031.zip
Added test to compare ffmpeg type sizes between pascal and c.
git-svn-id: svn://svn.code.sf.net/p/ultrastardx/svn/trunk@2997 b956fd51-792f-4845-bead-9b4dfca2ff2c
Diffstat (limited to '')
-rwxr-xr-xtest/ffmpeg_structs/find_avtypes57
1 files changed, 57 insertions, 0 deletions
diff --git a/test/ffmpeg_structs/find_avtypes b/test/ffmpeg_structs/find_avtypes
new file mode 100755
index 00000000..c13672f5
--- /dev/null
+++ b/test/ffmpeg_structs/find_avtypes
@@ -0,0 +1,57 @@
+#!/bin/sh
+
+SRC_DIR='../../src'
+PAS='ffmpeg_pas.pas'
+C='ffmpeg_c.c'
+
+types=$(find $SRC_DIR -path "$SRC_DIR/lib" -prune -o -name "*.pas" -print0|xargs -0 grep --files-with-match '\bavcodec\b'|xargs grep --no-filename --only-matching '\b[PT]AV\w\+'|sed 's/^P/T/'|sort|uniq)
+
+# swscale doesn't seem to contain noteworthy types, thus it's not considered
+
+cat >$PAS <<EOL
+program ffmpeg_pas;
+
+uses
+ avcodec in '$SRC_DIR/lib/ffmpeg-$FFMPEG_VERSION/avcodec.pas',
+ avformat in '$SRC_DIR/lib/ffmpeg-$FFMPEG_VERSION/avformat.pas',
+ avutil in '$SRC_DIR/lib/ffmpeg-$FFMPEG_VERSION/avutil.pas',
+ rational in '$SRC_DIR/lib/ffmpeg-$FFMPEG_VERSION/rational.pas',
+ avio in '$SRC_DIR/lib/ffmpeg-$FFMPEG_VERSION/avio.pas',
+ UConfig in '$SRC_DIR/base/UConfig',
+ SysUtils;
+
+begin
+EOL
+
+for t in $types
+do
+ echo " WriteLn('$t: ' + IntToStr(SizeOf($t)));" >>$PAS
+done
+
+cat >>$PAS <<EOL
+end.
+EOL
+
+cat >$C <<EOL
+#include "libavcodec/avcodec.h"
+#include "libavformat/avformat.h"
+#include "libavutil/samplefmt.h"
+#include "libavutil/avutil.h"
+#include "libavformat/avio.h"
+
+// workaround for enum
+typedef enum AVSampleFormat AVSampleFormat;
+
+int main(int argc, char *argv[]) {
+EOL
+
+for t in $types
+do
+ tt=$(echo $t|sed 's/^T//')
+ echo " printf(\"$t: %ld\\n\", sizeof($tt));" >>$C
+done
+
+cat >>$C <<EOL
+ return 0;
+}
+EOL