@drutech/react-native-audio-analyzer 1.1.1-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (223) hide show
  1. package/LICENSE +20 -0
  2. package/README.md +124 -0
  3. package/android/CMakeCache.txt +372 -0
  4. package/android/CMakeLists.txt +44 -0
  5. package/android/Makefile +211 -0
  6. package/android/build.gradle +110 -0
  7. package/android/cmake_install.cmake +49 -0
  8. package/android/cpp-adapter.cpp +40 -0
  9. package/android/ffmpeg_16kb/include/config.h +749 -0
  10. package/android/ffmpeg_16kb/include/libavcodec/ac3_parser.h +36 -0
  11. package/android/ffmpeg_16kb/include/libavcodec/adts_parser.h +37 -0
  12. package/android/ffmpeg_16kb/include/libavcodec/arm/mathops.h +108 -0
  13. package/android/ffmpeg_16kb/include/libavcodec/avcodec.h +3192 -0
  14. package/android/ffmpeg_16kb/include/libavcodec/avdct.h +88 -0
  15. package/android/ffmpeg_16kb/include/libavcodec/avfft.h +118 -0
  16. package/android/ffmpeg_16kb/include/libavcodec/bsf.h +332 -0
  17. package/android/ffmpeg_16kb/include/libavcodec/codec.h +375 -0
  18. package/android/ffmpeg_16kb/include/libavcodec/codec_desc.h +128 -0
  19. package/android/ffmpeg_16kb/include/libavcodec/codec_id.h +661 -0
  20. package/android/ffmpeg_16kb/include/libavcodec/codec_par.h +247 -0
  21. package/android/ffmpeg_16kb/include/libavcodec/d3d11va.h +112 -0
  22. package/android/ffmpeg_16kb/include/libavcodec/defs.h +192 -0
  23. package/android/ffmpeg_16kb/include/libavcodec/dirac.h +131 -0
  24. package/android/ffmpeg_16kb/include/libavcodec/dv_profile.h +82 -0
  25. package/android/ffmpeg_16kb/include/libavcodec/dxva2.h +93 -0
  26. package/android/ffmpeg_16kb/include/libavcodec/jni.h +46 -0
  27. package/android/ffmpeg_16kb/include/libavcodec/mathops.h +255 -0
  28. package/android/ffmpeg_16kb/include/libavcodec/mediacodec.h +103 -0
  29. package/android/ffmpeg_16kb/include/libavcodec/packet.h +731 -0
  30. package/android/ffmpeg_16kb/include/libavcodec/qsv.h +109 -0
  31. package/android/ffmpeg_16kb/include/libavcodec/vdpau.h +157 -0
  32. package/android/ffmpeg_16kb/include/libavcodec/version.h +45 -0
  33. package/android/ffmpeg_16kb/include/libavcodec/version_major.h +52 -0
  34. package/android/ffmpeg_16kb/include/libavcodec/videotoolbox.h +150 -0
  35. package/android/ffmpeg_16kb/include/libavcodec/vorbis_parser.h +74 -0
  36. package/android/ffmpeg_16kb/include/libavcodec/x86/mathops.h +133 -0
  37. package/android/ffmpeg_16kb/include/libavcodec/xvmc.h +171 -0
  38. package/android/ffmpeg_16kb/include/libavdevice/avdevice.h +397 -0
  39. package/android/ffmpeg_16kb/include/libavdevice/version.h +45 -0
  40. package/android/ffmpeg_16kb/include/libavdevice/version_major.h +36 -0
  41. package/android/ffmpeg_16kb/include/libavfilter/avfilter.h +1491 -0
  42. package/android/ffmpeg_16kb/include/libavfilter/buffersink.h +173 -0
  43. package/android/ffmpeg_16kb/include/libavfilter/buffersrc.h +218 -0
  44. package/android/ffmpeg_16kb/include/libavfilter/version.h +48 -0
  45. package/android/ffmpeg_16kb/include/libavfilter/version_major.h +38 -0
  46. package/android/ffmpeg_16kb/include/libavformat/avformat.h +2826 -0
  47. package/android/ffmpeg_16kb/include/libavformat/avio.h +837 -0
  48. package/android/ffmpeg_16kb/include/libavformat/network.h +341 -0
  49. package/android/ffmpeg_16kb/include/libavformat/os_support.h +317 -0
  50. package/android/ffmpeg_16kb/include/libavformat/url.h +409 -0
  51. package/android/ffmpeg_16kb/include/libavformat/version.h +47 -0
  52. package/android/ffmpeg_16kb/include/libavformat/version_major.h +52 -0
  53. package/android/ffmpeg_16kb/include/libavutil/aarch64/timer.h +50 -0
  54. package/android/ffmpeg_16kb/include/libavutil/adler32.h +63 -0
  55. package/android/ffmpeg_16kb/include/libavutil/aes.h +69 -0
  56. package/android/ffmpeg_16kb/include/libavutil/aes_ctr.h +99 -0
  57. package/android/ffmpeg_16kb/include/libavutil/ambient_viewing_environment.h +72 -0
  58. package/android/ffmpeg_16kb/include/libavutil/arm/timer.h +46 -0
  59. package/android/ffmpeg_16kb/include/libavutil/attributes.h +173 -0
  60. package/android/ffmpeg_16kb/include/libavutil/attributes_internal.h +34 -0
  61. package/android/ffmpeg_16kb/include/libavutil/audio_fifo.h +186 -0
  62. package/android/ffmpeg_16kb/include/libavutil/avassert.h +75 -0
  63. package/android/ffmpeg_16kb/include/libavutil/avconfig.h +6 -0
  64. package/android/ffmpeg_16kb/include/libavutil/avstring.h +429 -0
  65. package/android/ffmpeg_16kb/include/libavutil/avutil.h +371 -0
  66. package/android/ffmpeg_16kb/include/libavutil/base64.h +72 -0
  67. package/android/ffmpeg_16kb/include/libavutil/blowfish.h +82 -0
  68. package/android/ffmpeg_16kb/include/libavutil/bprint.h +251 -0
  69. package/android/ffmpeg_16kb/include/libavutil/bswap.h +111 -0
  70. package/android/ffmpeg_16kb/include/libavutil/buffer.h +322 -0
  71. package/android/ffmpeg_16kb/include/libavutil/camellia.h +70 -0
  72. package/android/ffmpeg_16kb/include/libavutil/cast5.h +80 -0
  73. package/android/ffmpeg_16kb/include/libavutil/channel_layout.h +783 -0
  74. package/android/ffmpeg_16kb/include/libavutil/common.h +578 -0
  75. package/android/ffmpeg_16kb/include/libavutil/cpu.h +134 -0
  76. package/android/ffmpeg_16kb/include/libavutil/crc.h +102 -0
  77. package/android/ffmpeg_16kb/include/libavutil/csp.h +150 -0
  78. package/android/ffmpeg_16kb/include/libavutil/des.h +81 -0
  79. package/android/ffmpeg_16kb/include/libavutil/detection_bbox.h +108 -0
  80. package/android/ffmpeg_16kb/include/libavutil/dict.h +241 -0
  81. package/android/ffmpeg_16kb/include/libavutil/display.h +109 -0
  82. package/android/ffmpeg_16kb/include/libavutil/dovi_meta.h +236 -0
  83. package/android/ffmpeg_16kb/include/libavutil/downmix_info.h +115 -0
  84. package/android/ffmpeg_16kb/include/libavutil/encryption_info.h +205 -0
  85. package/android/ffmpeg_16kb/include/libavutil/error.h +128 -0
  86. package/android/ffmpeg_16kb/include/libavutil/eval.h +140 -0
  87. package/android/ffmpeg_16kb/include/libavutil/ffversion.h +5 -0
  88. package/android/ffmpeg_16kb/include/libavutil/fifo.h +448 -0
  89. package/android/ffmpeg_16kb/include/libavutil/file.h +115 -0
  90. package/android/ffmpeg_16kb/include/libavutil/film_grain_params.h +260 -0
  91. package/android/ffmpeg_16kb/include/libavutil/frame.h +964 -0
  92. package/android/ffmpeg_16kb/include/libavutil/getenv_utf8.h +86 -0
  93. package/android/ffmpeg_16kb/include/libavutil/hash.h +264 -0
  94. package/android/ffmpeg_16kb/include/libavutil/hdr_dynamic_metadata.h +343 -0
  95. package/android/ffmpeg_16kb/include/libavutil/hdr_dynamic_vivid_metadata.h +285 -0
  96. package/android/ffmpeg_16kb/include/libavutil/hmac.h +99 -0
  97. package/android/ffmpeg_16kb/include/libavutil/hwcontext.h +610 -0
  98. package/android/ffmpeg_16kb/include/libavutil/hwcontext_cuda.h +69 -0
  99. package/android/ffmpeg_16kb/include/libavutil/hwcontext_d3d11va.h +178 -0
  100. package/android/ffmpeg_16kb/include/libavutil/hwcontext_drm.h +169 -0
  101. package/android/ffmpeg_16kb/include/libavutil/hwcontext_dxva2.h +75 -0
  102. package/android/ffmpeg_16kb/include/libavutil/hwcontext_mediacodec.h +61 -0
  103. package/android/ffmpeg_16kb/include/libavutil/hwcontext_opencl.h +100 -0
  104. package/android/ffmpeg_16kb/include/libavutil/hwcontext_qsv.h +64 -0
  105. package/android/ffmpeg_16kb/include/libavutil/hwcontext_vaapi.h +117 -0
  106. package/android/ffmpeg_16kb/include/libavutil/hwcontext_vdpau.h +44 -0
  107. package/android/ffmpeg_16kb/include/libavutil/hwcontext_videotoolbox.h +96 -0
  108. package/android/ffmpeg_16kb/include/libavutil/hwcontext_vulkan.h +281 -0
  109. package/android/ffmpeg_16kb/include/libavutil/imgutils.h +331 -0
  110. package/android/ffmpeg_16kb/include/libavutil/internal.h +190 -0
  111. package/android/ffmpeg_16kb/include/libavutil/intfloat.h +77 -0
  112. package/android/ffmpeg_16kb/include/libavutil/intreadwrite.h +644 -0
  113. package/android/ffmpeg_16kb/include/libavutil/lfg.h +81 -0
  114. package/android/ffmpeg_16kb/include/libavutil/libm.h +471 -0
  115. package/android/ffmpeg_16kb/include/libavutil/log.h +387 -0
  116. package/android/ffmpeg_16kb/include/libavutil/lzo.h +66 -0
  117. package/android/ffmpeg_16kb/include/libavutil/macros.h +80 -0
  118. package/android/ffmpeg_16kb/include/libavutil/mastering_display_metadata.h +128 -0
  119. package/android/ffmpeg_16kb/include/libavutil/mathematics.h +245 -0
  120. package/android/ffmpeg_16kb/include/libavutil/md5.h +89 -0
  121. package/android/ffmpeg_16kb/include/libavutil/mem.h +609 -0
  122. package/android/ffmpeg_16kb/include/libavutil/motion_vector.h +57 -0
  123. package/android/ffmpeg_16kb/include/libavutil/murmur3.h +115 -0
  124. package/android/ffmpeg_16kb/include/libavutil/opt.h +891 -0
  125. package/android/ffmpeg_16kb/include/libavutil/parseutils.h +197 -0
  126. package/android/ffmpeg_16kb/include/libavutil/pixdesc.h +435 -0
  127. package/android/ffmpeg_16kb/include/libavutil/pixelutils.h +51 -0
  128. package/android/ffmpeg_16kb/include/libavutil/pixfmt.h +691 -0
  129. package/android/ffmpeg_16kb/include/libavutil/random_seed.h +43 -0
  130. package/android/ffmpeg_16kb/include/libavutil/rational.h +221 -0
  131. package/android/ffmpeg_16kb/include/libavutil/rc4.h +69 -0
  132. package/android/ffmpeg_16kb/include/libavutil/replaygain.h +50 -0
  133. package/android/ffmpeg_16kb/include/libavutil/reverse.h +28 -0
  134. package/android/ffmpeg_16kb/include/libavutil/ripemd.h +83 -0
  135. package/android/ffmpeg_16kb/include/libavutil/samplefmt.h +269 -0
  136. package/android/ffmpeg_16kb/include/libavutil/sha.h +90 -0
  137. package/android/ffmpeg_16kb/include/libavutil/sha512.h +92 -0
  138. package/android/ffmpeg_16kb/include/libavutil/spherical.h +227 -0
  139. package/android/ffmpeg_16kb/include/libavutil/stereo3d.h +229 -0
  140. package/android/ffmpeg_16kb/include/libavutil/tea.h +71 -0
  141. package/android/ffmpeg_16kb/include/libavutil/thread.h +204 -0
  142. package/android/ffmpeg_16kb/include/libavutil/threadmessage.h +115 -0
  143. package/android/ffmpeg_16kb/include/libavutil/time.h +56 -0
  144. package/android/ffmpeg_16kb/include/libavutil/timecode.h +199 -0
  145. package/android/ffmpeg_16kb/include/libavutil/timer.h +156 -0
  146. package/android/ffmpeg_16kb/include/libavutil/timestamp.h +78 -0
  147. package/android/ffmpeg_16kb/include/libavutil/tree.h +137 -0
  148. package/android/ffmpeg_16kb/include/libavutil/twofish.h +70 -0
  149. package/android/ffmpeg_16kb/include/libavutil/tx.h +176 -0
  150. package/android/ffmpeg_16kb/include/libavutil/uuid.h +146 -0
  151. package/android/ffmpeg_16kb/include/libavutil/version.h +122 -0
  152. package/android/ffmpeg_16kb/include/libavutil/video_enc_params.h +171 -0
  153. package/android/ffmpeg_16kb/include/libavutil/x86/asm.h +154 -0
  154. package/android/ffmpeg_16kb/include/libavutil/x86/emms.h +58 -0
  155. package/android/ffmpeg_16kb/include/libavutil/x86/timer.h +50 -0
  156. package/android/ffmpeg_16kb/include/libavutil/xtea.h +94 -0
  157. package/android/ffmpeg_16kb/include/libswresample/swresample.h +650 -0
  158. package/android/ffmpeg_16kb/include/libswresample/version.h +46 -0
  159. package/android/ffmpeg_16kb/include/libswresample/version_major.h +31 -0
  160. package/android/ffmpeg_16kb/include/libswscale/swscale.h +436 -0
  161. package/android/ffmpeg_16kb/include/libswscale/version.h +44 -0
  162. package/android/ffmpeg_16kb/include/libswscale/version_major.h +35 -0
  163. package/android/ffmpeg_16kb/lib/arm64-v8a/libavcodec.so +0 -0
  164. package/android/ffmpeg_16kb/lib/arm64-v8a/libavdevice.so +0 -0
  165. package/android/ffmpeg_16kb/lib/arm64-v8a/libavfilter.so +0 -0
  166. package/android/ffmpeg_16kb/lib/arm64-v8a/libavformat.so +0 -0
  167. package/android/ffmpeg_16kb/lib/arm64-v8a/libavutil.so +0 -0
  168. package/android/ffmpeg_16kb/lib/arm64-v8a/libswresample.so +0 -0
  169. package/android/ffmpeg_16kb/lib/arm64-v8a/libswscale.so +0 -0
  170. package/android/ffmpeg_16kb/lib/armeabi-v7a/libavcodec_neon.so +0 -0
  171. package/android/ffmpeg_16kb/lib/armeabi-v7a/libavdevice_neon.so +0 -0
  172. package/android/ffmpeg_16kb/lib/armeabi-v7a/libavfilter_neon.so +0 -0
  173. package/android/ffmpeg_16kb/lib/armeabi-v7a/libavformat_neon.so +0 -0
  174. package/android/ffmpeg_16kb/lib/armeabi-v7a/libavutil_neon.so +0 -0
  175. package/android/ffmpeg_16kb/lib/armeabi-v7a/libswresample_neon.so +0 -0
  176. package/android/ffmpeg_16kb/lib/armeabi-v7a/libswscale_neon.so +0 -0
  177. package/android/ffmpeg_16kb/lib/x86/libavcodec.so +0 -0
  178. package/android/ffmpeg_16kb/lib/x86/libavdevice.so +0 -0
  179. package/android/ffmpeg_16kb/lib/x86/libavfilter.so +0 -0
  180. package/android/ffmpeg_16kb/lib/x86/libavformat.so +0 -0
  181. package/android/ffmpeg_16kb/lib/x86/libavutil.so +0 -0
  182. package/android/ffmpeg_16kb/lib/x86/libswresample.so +0 -0
  183. package/android/ffmpeg_16kb/lib/x86/libswscale.so +0 -0
  184. package/android/ffmpeg_16kb/lib/x86_64/libavcodec.so +0 -0
  185. package/android/ffmpeg_16kb/lib/x86_64/libavdevice.so +0 -0
  186. package/android/ffmpeg_16kb/lib/x86_64/libavfilter.so +0 -0
  187. package/android/ffmpeg_16kb/lib/x86_64/libavformat.so +0 -0
  188. package/android/ffmpeg_16kb/lib/x86_64/libavutil.so +0 -0
  189. package/android/ffmpeg_16kb/lib/x86_64/libswresample.so +0 -0
  190. package/android/ffmpeg_16kb/lib/x86_64/libswscale.so +0 -0
  191. package/android/gradle.properties +5 -0
  192. package/android/src/main/AndroidManifest.xml +3 -0
  193. package/android/src/main/AndroidManifestNew.xml +2 -0
  194. package/android/src/main/java/com/audioanalyzer/AmplitudeData.java +20 -0
  195. package/android/src/main/java/com/audioanalyzer/AudioAnalyzerModule.java +52 -0
  196. package/android/src/main/java/com/audioanalyzer/AudioAnalyzerPackage.java +28 -0
  197. package/cpp/react-native-audio-analyzer.cpp +143 -0
  198. package/cpp/react-native-audio-analyzer.h +27 -0
  199. package/ios/AudioAnalyzer.h +19 -0
  200. package/ios/AudioAnalyzer.mm +43 -0
  201. package/lib/commonjs/helpers.js +34 -0
  202. package/lib/commonjs/helpers.js.map +1 -0
  203. package/lib/commonjs/helpers.test.js +49 -0
  204. package/lib/commonjs/helpers.test.js.map +1 -0
  205. package/lib/commonjs/index.js +35 -0
  206. package/lib/commonjs/index.js.map +1 -0
  207. package/lib/module/helpers.js +27 -0
  208. package/lib/module/helpers.js.map +1 -0
  209. package/lib/module/helpers.test.js +47 -0
  210. package/lib/module/helpers.test.js.map +1 -0
  211. package/lib/module/index.js +15 -0
  212. package/lib/module/index.js.map +1 -0
  213. package/lib/typescript/src/helpers.d.ts +3 -0
  214. package/lib/typescript/src/helpers.d.ts.map +1 -0
  215. package/lib/typescript/src/helpers.test.d.ts +2 -0
  216. package/lib/typescript/src/helpers.test.d.ts.map +1 -0
  217. package/lib/typescript/src/index.d.ts +7 -0
  218. package/lib/typescript/src/index.d.ts.map +1 -0
  219. package/package.json +163 -0
  220. package/react-native-audio-analyzer.podspec +44 -0
  221. package/src/helpers.test.ts +59 -0
  222. package/src/helpers.ts +34 -0
  223. package/src/index.tsx +30 -0
@@ -0,0 +1,409 @@
1
+ /*
2
+ * This file is part of FFmpeg.
3
+ *
4
+ * FFmpeg is free software; you can redistribute it and/or
5
+ * modify it under the terms of the GNU Lesser General Public
6
+ * License as published by the Free Software Foundation; either
7
+ * version 2.1 of the License, or (at your option) any later version.
8
+ *
9
+ * FFmpeg is distributed in the hope that it will be useful,
10
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
11
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12
+ * Lesser General Public License for more details.
13
+ *
14
+ * You should have received a copy of the GNU Lesser General Public
15
+ * License along with FFmpeg; if not, write to the Free Software
16
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
+ */
18
+
19
+ /**
20
+ * @file
21
+ * unbuffered private I/O API
22
+ */
23
+
24
+ #ifndef AVFORMAT_URL_H
25
+ #define AVFORMAT_URL_H
26
+
27
+ #include "avio.h"
28
+
29
+ #include "libavutil/dict.h"
30
+ #include "libavutil/log.h"
31
+
32
+ #define URL_PROTOCOL_FLAG_NESTED_SCHEME 1 /*< The protocol name can be the first part of a nested protocol scheme */
33
+ #define URL_PROTOCOL_FLAG_NETWORK 2 /*< The protocol uses network */
34
+
35
+ extern const AVClass ffurl_context_class;
36
+
37
+ typedef struct URLContext {
38
+ const AVClass *av_class; /**< information for av_log(). Set by url_open(). */
39
+ const struct URLProtocol *prot;
40
+ void *priv_data;
41
+ char *filename; /**< specified URL */
42
+ int flags;
43
+ int max_packet_size; /**< if non zero, the stream is packetized with this max packet size */
44
+ int is_streamed; /**< true if streamed (no seek possible), default = false */
45
+ int is_connected;
46
+ AVIOInterruptCB interrupt_callback;
47
+ int64_t rw_timeout; /**< maximum time to wait for (network) read/write operation completion, in mcs */
48
+ const char *protocol_whitelist;
49
+ const char *protocol_blacklist;
50
+ int min_packet_size; /**< if non zero, the stream is packetized with this min packet size */
51
+ } URLContext;
52
+
53
+ typedef struct URLProtocol {
54
+ const char *name;
55
+ int (*url_open)( URLContext *h, const char *url, int flags);
56
+ /**
57
+ * This callback is to be used by protocols which open further nested
58
+ * protocols. options are then to be passed to ffurl_open_whitelist()
59
+ * or ffurl_connect() for those nested protocols.
60
+ */
61
+ int (*url_open2)(URLContext *h, const char *url, int flags, AVDictionary **options);
62
+ int (*url_accept)(URLContext *s, URLContext **c);
63
+ int (*url_handshake)(URLContext *c);
64
+
65
+ /**
66
+ * Read data from the protocol.
67
+ * If data is immediately available (even less than size), EOF is
68
+ * reached or an error occurs (including EINTR), return immediately.
69
+ * Otherwise:
70
+ * In non-blocking mode, return AVERROR(EAGAIN) immediately.
71
+ * In blocking mode, wait for data/EOF/error with a short timeout (0.1s),
72
+ * and return AVERROR(EAGAIN) on timeout.
73
+ * Checking interrupt_callback, looping on EINTR and EAGAIN and until
74
+ * enough data has been read is left to the calling function; see
75
+ * retry_transfer_wrapper in avio.c.
76
+ */
77
+ int (*url_read)( URLContext *h, unsigned char *buf, int size);
78
+ int (*url_write)(URLContext *h, const unsigned char *buf, int size);
79
+ int64_t (*url_seek)( URLContext *h, int64_t pos, int whence);
80
+ int (*url_close)(URLContext *h);
81
+ int (*url_read_pause)(URLContext *h, int pause);
82
+ int64_t (*url_read_seek)(URLContext *h, int stream_index,
83
+ int64_t timestamp, int flags);
84
+ int (*url_get_file_handle)(URLContext *h);
85
+ int (*url_get_multi_file_handle)(URLContext *h, int **handles,
86
+ int *numhandles);
87
+ int (*url_get_short_seek)(URLContext *h);
88
+ int (*url_shutdown)(URLContext *h, int flags);
89
+ const AVClass *priv_data_class;
90
+ int priv_data_size;
91
+ int flags;
92
+ int (*url_check)(URLContext *h, int mask);
93
+ int (*url_open_dir)(URLContext *h);
94
+ int (*url_read_dir)(URLContext *h, AVIODirEntry **next);
95
+ int (*url_close_dir)(URLContext *h);
96
+ int (*url_delete)(URLContext *h);
97
+ int (*url_move)(URLContext *h_src, URLContext *h_dst);
98
+ const char *default_whitelist;
99
+ } URLProtocol;
100
+
101
+ /**
102
+ * Create a URLContext for accessing to the resource indicated by
103
+ * url, but do not initiate the connection yet.
104
+ *
105
+ * @param puc pointer to the location where, in case of success, the
106
+ * function puts the pointer to the created URLContext
107
+ * @param flags flags which control how the resource indicated by url
108
+ * is to be opened
109
+ * @param int_cb interrupt callback to use for the URLContext, may be
110
+ * NULL
111
+ * @return >= 0 in case of success, a negative value corresponding to an
112
+ * AVERROR code in case of failure
113
+ */
114
+ int ffurl_alloc(URLContext **puc, const char *filename, int flags,
115
+ const AVIOInterruptCB *int_cb);
116
+
117
+ /**
118
+ * Connect an URLContext that has been allocated by ffurl_alloc
119
+ *
120
+ * @param options A dictionary filled with options for nested protocols,
121
+ * i.e. it will be passed to url_open2() for protocols implementing it.
122
+ * This parameter will be destroyed and replaced with a dict containing options
123
+ * that were not found. May be NULL.
124
+ */
125
+ int ffurl_connect(URLContext *uc, AVDictionary **options);
126
+
127
+ /**
128
+ * Create an URLContext for accessing to the resource indicated by
129
+ * url, and open it.
130
+ *
131
+ * @param puc pointer to the location where, in case of success, the
132
+ * function puts the pointer to the created URLContext
133
+ * @param flags flags which control how the resource indicated by url
134
+ * is to be opened
135
+ * @param int_cb interrupt callback to use for the URLContext, may be
136
+ * NULL
137
+ * @param options A dictionary filled with protocol-private options. On return
138
+ * this parameter will be destroyed and replaced with a dict containing options
139
+ * that were not found. May be NULL.
140
+ * @param parent An enclosing URLContext, whose generic options should
141
+ * be applied to this URLContext as well.
142
+ * @return >= 0 in case of success, a negative value corresponding to an
143
+ * AVERROR code in case of failure
144
+ */
145
+ int ffurl_open_whitelist(URLContext **puc, const char *filename, int flags,
146
+ const AVIOInterruptCB *int_cb, AVDictionary **options,
147
+ const char *whitelist, const char* blacklist,
148
+ URLContext *parent);
149
+
150
+ /**
151
+ * Accept an URLContext c on an URLContext s
152
+ *
153
+ * @param s server context
154
+ * @param c client context, must be unallocated.
155
+ * @return >= 0 on success, ff_neterrno() on failure.
156
+ */
157
+ int ffurl_accept(URLContext *s, URLContext **c);
158
+
159
+ /**
160
+ * Perform one step of the protocol handshake to accept a new client.
161
+ * See avio_handshake() for details.
162
+ * Implementations should try to return decreasing values.
163
+ * If the protocol uses an underlying protocol, the underlying handshake is
164
+ * usually the first step, and the return value can be:
165
+ * (largest value for this protocol) + (return value from other protocol)
166
+ *
167
+ * @param c the client context
168
+ * @return >= 0 on success or a negative value corresponding
169
+ * to an AVERROR code on failure
170
+ */
171
+ int ffurl_handshake(URLContext *c);
172
+
173
+ /**
174
+ * Read up to size bytes from the resource accessed by h, and store
175
+ * the read bytes in buf.
176
+ *
177
+ * @return The number of bytes actually read, or a negative value
178
+ * corresponding to an AVERROR code in case of error. A value of zero
179
+ * indicates that it is not possible to read more from the accessed
180
+ * resource (except if the value of the size argument is also zero).
181
+ */
182
+ int ffurl_read(URLContext *h, unsigned char *buf, int size);
183
+
184
+ /**
185
+ * Read as many bytes as possible (up to size), calling the
186
+ * read function multiple times if necessary.
187
+ * This makes special short-read handling in applications
188
+ * unnecessary, if the return value is < size then it is
189
+ * certain there was either an error or the end of file was reached.
190
+ */
191
+ int ffurl_read_complete(URLContext *h, unsigned char *buf, int size);
192
+
193
+ /**
194
+ * Write size bytes from buf to the resource accessed by h.
195
+ *
196
+ * @return the number of bytes actually written, or a negative value
197
+ * corresponding to an AVERROR code in case of failure
198
+ */
199
+ int ffurl_write(URLContext *h, const unsigned char *buf, int size);
200
+
201
+ /**
202
+ * Change the position that will be used by the next read/write
203
+ * operation on the resource accessed by h.
204
+ *
205
+ * @param pos specifies the new position to set
206
+ * @param whence specifies how pos should be interpreted, it must be
207
+ * one of SEEK_SET (seek from the beginning), SEEK_CUR (seek from the
208
+ * current position), SEEK_END (seek from the end), or AVSEEK_SIZE
209
+ * (return the filesize of the requested resource, pos is ignored).
210
+ * @return a negative value corresponding to an AVERROR code in case
211
+ * of failure, or the resulting file position, measured in bytes from
212
+ * the beginning of the file. You can use this feature together with
213
+ * SEEK_CUR to read the current file position.
214
+ */
215
+ int64_t ffurl_seek(URLContext *h, int64_t pos, int whence);
216
+
217
+ /**
218
+ * Close the resource accessed by the URLContext h, and free the
219
+ * memory used by it. Also set the URLContext pointer to NULL.
220
+ *
221
+ * @return a negative value if an error condition occurred, 0
222
+ * otherwise
223
+ */
224
+ int ffurl_closep(URLContext **h);
225
+ int ffurl_close(URLContext *h);
226
+
227
+ /**
228
+ * Return the filesize of the resource accessed by h, AVERROR(ENOSYS)
229
+ * if the operation is not supported by h, or another negative value
230
+ * corresponding to an AVERROR error code in case of failure.
231
+ */
232
+ int64_t ffurl_size(URLContext *h);
233
+
234
+ /**
235
+ * Return the file descriptor associated with this URL. For RTP, this
236
+ * will return only the RTP file descriptor, not the RTCP file descriptor.
237
+ *
238
+ * @return the file descriptor associated with this URL, or <0 on error.
239
+ */
240
+ int ffurl_get_file_handle(URLContext *h);
241
+
242
+ /**
243
+ * Return the file descriptors associated with this URL.
244
+ *
245
+ * @return 0 on success or <0 on error.
246
+ */
247
+ int ffurl_get_multi_file_handle(URLContext *h, int **handles, int *numhandles);
248
+
249
+ /**
250
+ * Return the current short seek threshold value for this URL.
251
+ *
252
+ * @return threshold (>0) on success or <=0 on error.
253
+ */
254
+ int ffurl_get_short_seek(URLContext *h);
255
+
256
+ /**
257
+ * Signal the URLContext that we are done reading or writing the stream.
258
+ *
259
+ * @param h pointer to the resource
260
+ * @param flags flags which control how the resource indicated by url
261
+ * is to be shutdown
262
+ *
263
+ * @return a negative value if an error condition occurred, 0
264
+ * otherwise
265
+ */
266
+ int ffurl_shutdown(URLContext *h, int flags);
267
+
268
+ /**
269
+ * Check if the user has requested to interrupt a blocking function
270
+ * associated with cb.
271
+ */
272
+ int ff_check_interrupt(AVIOInterruptCB *cb);
273
+
274
+ /* udp.c */
275
+ int ff_udp_set_remote_url(URLContext *h, const char *uri);
276
+ int ff_udp_get_local_port(URLContext *h);
277
+
278
+ /**
279
+ * Assemble a URL string from components. This is the reverse operation
280
+ * of av_url_split.
281
+ *
282
+ * Note, this requires networking to be initialized, so the caller must
283
+ * ensure ff_network_init has been called.
284
+ *
285
+ * @see av_url_split
286
+ *
287
+ * @param str the buffer to fill with the url
288
+ * @param size the size of the str buffer
289
+ * @param proto the protocol identifier, if null, the separator
290
+ * after the identifier is left out, too
291
+ * @param authorization an optional authorization string, may be null.
292
+ * An empty string is treated the same as a null string.
293
+ * @param hostname the host name string
294
+ * @param port the port number, left out from the string if negative
295
+ * @param fmt a generic format string for everything to add after the
296
+ * host/port, may be null
297
+ * @return the number of characters written to the destination buffer
298
+ */
299
+ int ff_url_join(char *str, int size, const char *proto,
300
+ const char *authorization, const char *hostname,
301
+ int port, const char *fmt, ...) av_printf_format(7, 8);
302
+
303
+ /**
304
+ * Convert a relative url into an absolute url, given a base url.
305
+ *
306
+ * @param buf the buffer where output absolute url is written
307
+ * @param size the size of buf
308
+ * @param base the base url, may be equal to buf.
309
+ * @param rel the new url, which is interpreted relative to base
310
+ * @param handle_dos_paths handle DOS paths for file or unspecified protocol
311
+ */
312
+ int ff_make_absolute_url2(char *buf, int size, const char *base,
313
+ const char *rel, int handle_dos_paths);
314
+
315
+ /**
316
+ * Convert a relative url into an absolute url, given a base url.
317
+ *
318
+ * Same as ff_make_absolute_url2 with handle_dos_paths being equal to
319
+ * HAVE_DOS_PATHS config variable.
320
+ */
321
+ int ff_make_absolute_url(char *buf, int size, const char *base,
322
+ const char *rel);
323
+
324
+ /**
325
+ * Allocate directory entry with default values.
326
+ *
327
+ * @return entry or NULL on error
328
+ */
329
+ AVIODirEntry *ff_alloc_dir_entry(void);
330
+
331
+ const AVClass *ff_urlcontext_child_class_iterate(void **iter);
332
+
333
+ /**
334
+ * Construct a list of protocols matching a given whitelist and/or blacklist.
335
+ *
336
+ * @param whitelist a comma-separated list of allowed protocol names or NULL. If
337
+ * this is a non-empty string, only protocols in this list will
338
+ * be included.
339
+ * @param blacklist a comma-separated list of forbidden protocol names or NULL.
340
+ * If this is a non-empty string, all protocols in this list
341
+ * will be excluded.
342
+ *
343
+ * @return a NULL-terminated array of matching protocols. The array must be
344
+ * freed by the caller.
345
+ */
346
+ const URLProtocol **ffurl_get_protocols(const char *whitelist,
347
+ const char *blacklist);
348
+
349
+ typedef struct URLComponents {
350
+ const char *url; /**< whole URL, for reference */
351
+ const char *scheme; /**< possibly including lavf-specific options */
352
+ const char *authority; /**< "//" if it is a real URL */
353
+ const char *userinfo; /**< including final '@' if present */
354
+ const char *host;
355
+ const char *port; /**< including initial ':' if present */
356
+ const char *path;
357
+ const char *query; /**< including initial '?' if present */
358
+ const char *fragment; /**< including initial '#' if present */
359
+ const char *end;
360
+ } URLComponents;
361
+
362
+ #define url_component_end_scheme authority
363
+ #define url_component_end_authority userinfo
364
+ #define url_component_end_userinfo host
365
+ #define url_component_end_host port
366
+ #define url_component_end_port path
367
+ #define url_component_end_path query
368
+ #define url_component_end_query fragment
369
+ #define url_component_end_fragment end
370
+ #define url_component_end_authority_full path
371
+
372
+ #define URL_COMPONENT_HAVE(uc, component) \
373
+ ((uc).url_component_end_##component > (uc).component)
374
+
375
+ /**
376
+ * Parse an URL to find the components.
377
+ *
378
+ * Each component runs until the start of the next component,
379
+ * possibly including a mandatory delimiter.
380
+ *
381
+ * @param uc structure to fill with pointers to the components.
382
+ * @param url URL to parse.
383
+ * @param end end of the URL, or NULL to parse to the end of string.
384
+ *
385
+ * @return >= 0 for success or an AVERROR code, especially if the URL is
386
+ * malformed.
387
+ */
388
+ int ff_url_decompose(URLComponents *uc, const char *url, const char *end);
389
+
390
+ /**
391
+ * Move or rename a resource.
392
+ *
393
+ * @note url_src and url_dst should share the same protocol and authority.
394
+ *
395
+ * @param url_src url to resource to be moved
396
+ * @param url_dst new url to resource if the operation succeeded
397
+ * @return >=0 on success or negative on error.
398
+ */
399
+ int ffurl_move(const char *url_src, const char *url_dst);
400
+
401
+ /**
402
+ * Delete a resource.
403
+ *
404
+ * @param url resource to be deleted.
405
+ * @return >=0 on success or negative on error.
406
+ */
407
+ int ffurl_delete(const char *url);
408
+
409
+ #endif /* AVFORMAT_URL_H */
@@ -0,0 +1,47 @@
1
+ /*
2
+ * Version macros.
3
+ *
4
+ * This file is part of FFmpeg.
5
+ *
6
+ * FFmpeg is free software; you can redistribute it and/or
7
+ * modify it under the terms of the GNU Lesser General Public
8
+ * License as published by the Free Software Foundation; either
9
+ * version 2.1 of the License, or (at your option) any later version.
10
+ *
11
+ * FFmpeg is distributed in the hope that it will be useful,
12
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
+ * Lesser General Public License for more details.
15
+ *
16
+ * You should have received a copy of the GNU Lesser General Public
17
+ * License along with FFmpeg; if not, write to the Free Software
18
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
+ */
20
+
21
+ #ifndef AVFORMAT_VERSION_H
22
+ #define AVFORMAT_VERSION_H
23
+
24
+ /**
25
+ * @file
26
+ * @ingroup libavf
27
+ * Libavformat version macros
28
+ */
29
+
30
+ #include "libavutil/version.h"
31
+
32
+ #include "version_major.h"
33
+
34
+ #define LIBAVFORMAT_VERSION_MINOR 3
35
+ #define LIBAVFORMAT_VERSION_MICRO 100
36
+
37
+ #define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
38
+ LIBAVFORMAT_VERSION_MINOR, \
39
+ LIBAVFORMAT_VERSION_MICRO)
40
+ #define LIBAVFORMAT_VERSION AV_VERSION(LIBAVFORMAT_VERSION_MAJOR, \
41
+ LIBAVFORMAT_VERSION_MINOR, \
42
+ LIBAVFORMAT_VERSION_MICRO)
43
+ #define LIBAVFORMAT_BUILD LIBAVFORMAT_VERSION_INT
44
+
45
+ #define LIBAVFORMAT_IDENT "Lavf" AV_STRINGIFY(LIBAVFORMAT_VERSION)
46
+
47
+ #endif /* AVFORMAT_VERSION_H */
@@ -0,0 +1,52 @@
1
+ /*
2
+ * Version macros.
3
+ *
4
+ * This file is part of FFmpeg.
5
+ *
6
+ * FFmpeg is free software; you can redistribute it and/or
7
+ * modify it under the terms of the GNU Lesser General Public
8
+ * License as published by the Free Software Foundation; either
9
+ * version 2.1 of the License, or (at your option) any later version.
10
+ *
11
+ * FFmpeg is distributed in the hope that it will be useful,
12
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
+ * Lesser General Public License for more details.
15
+ *
16
+ * You should have received a copy of the GNU Lesser General Public
17
+ * License along with FFmpeg; if not, write to the Free Software
18
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
+ */
20
+
21
+ #ifndef AVFORMAT_VERSION_MAJOR_H
22
+ #define AVFORMAT_VERSION_MAJOR_H
23
+
24
+ /**
25
+ * @file
26
+ * @ingroup libavf
27
+ * Libavformat version macros
28
+ */
29
+
30
+ // Major bumping may affect Ticket5467, 5421, 5451(compatibility with Chromium)
31
+ // Also please add any ticket numbers that you believe might be affected here
32
+ #define LIBAVFORMAT_VERSION_MAJOR 60
33
+
34
+ /**
35
+ * FF_API_* defines may be placed below to indicate public API that will be
36
+ * dropped at a future version bump. The defines themselves are not part of
37
+ * the public API and may change, break or disappear at any time.
38
+ *
39
+ * @note, when bumping the major version it is recommended to manually
40
+ * disable each FF_API_* in its own commit instead of disabling them all
41
+ * at once through the bump. This improves the git bisect-ability of the change.
42
+ *
43
+ */
44
+ #define FF_API_COMPUTE_PKT_FIELDS2 (LIBAVFORMAT_VERSION_MAJOR < 61)
45
+ #define FF_API_GET_END_PTS (LIBAVFORMAT_VERSION_MAJOR < 61)
46
+ #define FF_API_AVIODIRCONTEXT (LIBAVFORMAT_VERSION_MAJOR < 61)
47
+ #define FF_API_AVFORMAT_IO_CLOSE (LIBAVFORMAT_VERSION_MAJOR < 61)
48
+
49
+
50
+ #define FF_API_R_FRAME_RATE 1
51
+
52
+ #endif /* AVFORMAT_VERSION_MAJOR_H */
@@ -0,0 +1,50 @@
1
+ /*
2
+ * Copyright (c) 2015 Janne Grunau <janne-libav@jannau.net>
3
+ *
4
+ * This file is part of FFmpeg.
5
+ *
6
+ * FFmpeg is free software; you can redistribute it and/or
7
+ * modify it under the terms of the GNU Lesser General Public
8
+ * License as published by the Free Software Foundation; either
9
+ * version 2.1 of the License, or (at your option) any later version.
10
+ *
11
+ * FFmpeg is distributed in the hope that it will be useful,
12
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
+ * Lesser General Public License for more details.
15
+ *
16
+ * You should have received a copy of the GNU Lesser General Public
17
+ * License along with FFmpeg; if not, write to the Free Software
18
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
+ */
20
+
21
+ #ifndef AVUTIL_AARCH64_TIMER_H
22
+ #define AVUTIL_AARCH64_TIMER_H
23
+
24
+ #include <stdint.h>
25
+ #include "config.h"
26
+
27
+ #if defined(__APPLE__)
28
+
29
+ #include <mach/mach_time.h>
30
+
31
+ #define AV_READ_TIME mach_absolute_time
32
+
33
+ #elif HAVE_INLINE_ASM
34
+
35
+ #define AV_READ_TIME read_time
36
+
37
+ static inline uint64_t read_time(void)
38
+ {
39
+ uint64_t cycle_counter;
40
+ __asm__ volatile(
41
+ "isb \t\n"
42
+ "mrs %0, pmccntr_el0 "
43
+ : "=r"(cycle_counter) :: "memory" );
44
+
45
+ return cycle_counter;
46
+ }
47
+
48
+ #endif /* HAVE_INLINE_ASM */
49
+
50
+ #endif /* AVUTIL_AARCH64_TIMER_H */
@@ -0,0 +1,63 @@
1
+ /*
2
+ * copyright (c) 2006 Mans Rullgard
3
+ *
4
+ * This file is part of FFmpeg.
5
+ *
6
+ * FFmpeg is free software; you can redistribute it and/or
7
+ * modify it under the terms of the GNU Lesser General Public
8
+ * License as published by the Free Software Foundation; either
9
+ * version 2.1 of the License, or (at your option) any later version.
10
+ *
11
+ * FFmpeg is distributed in the hope that it will be useful,
12
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
+ * Lesser General Public License for more details.
15
+ *
16
+ * You should have received a copy of the GNU Lesser General Public
17
+ * License along with FFmpeg; if not, write to the Free Software
18
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
+ */
20
+
21
+ /**
22
+ * @file
23
+ * @ingroup lavu_adler32
24
+ * Public header for Adler-32 hash function implementation.
25
+ */
26
+
27
+ #ifndef AVUTIL_ADLER32_H
28
+ #define AVUTIL_ADLER32_H
29
+
30
+ #include <stddef.h>
31
+ #include <stdint.h>
32
+ #include "attributes.h"
33
+
34
+ /**
35
+ * @defgroup lavu_adler32 Adler-32
36
+ * @ingroup lavu_hash
37
+ * Adler-32 hash function implementation.
38
+ *
39
+ * @{
40
+ */
41
+
42
+ typedef uint32_t AVAdler;
43
+
44
+ /**
45
+ * Calculate the Adler32 checksum of a buffer.
46
+ *
47
+ * Passing the return value to a subsequent av_adler32_update() call
48
+ * allows the checksum of multiple buffers to be calculated as though
49
+ * they were concatenated.
50
+ *
51
+ * @param adler initial checksum value
52
+ * @param buf pointer to input buffer
53
+ * @param len size of input buffer
54
+ * @return updated checksum
55
+ */
56
+ AVAdler av_adler32_update(AVAdler adler, const uint8_t *buf,
57
+ size_t len) av_pure;
58
+
59
+ /**
60
+ * @}
61
+ */
62
+
63
+ #endif /* AVUTIL_ADLER32_H */
@@ -0,0 +1,69 @@
1
+ /*
2
+ * copyright (c) 2007 Michael Niedermayer <michaelni@gmx.at>
3
+ *
4
+ * This file is part of FFmpeg.
5
+ *
6
+ * FFmpeg is free software; you can redistribute it and/or
7
+ * modify it under the terms of the GNU Lesser General Public
8
+ * License as published by the Free Software Foundation; either
9
+ * version 2.1 of the License, or (at your option) any later version.
10
+ *
11
+ * FFmpeg is distributed in the hope that it will be useful,
12
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
+ * Lesser General Public License for more details.
15
+ *
16
+ * You should have received a copy of the GNU Lesser General Public
17
+ * License along with FFmpeg; if not, write to the Free Software
18
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
+ */
20
+
21
+ #ifndef AVUTIL_AES_H
22
+ #define AVUTIL_AES_H
23
+
24
+ #include <stdint.h>
25
+
26
+ #include "attributes.h"
27
+
28
+ /**
29
+ * @defgroup lavu_aes AES
30
+ * @ingroup lavu_crypto
31
+ * @{
32
+ */
33
+
34
+ extern const int av_aes_size;
35
+
36
+ struct AVAES;
37
+
38
+ /**
39
+ * Allocate an AVAES context.
40
+ */
41
+ struct AVAES *av_aes_alloc(void);
42
+
43
+ /**
44
+ * Initialize an AVAES context.
45
+ *
46
+ * @param a The AVAES context
47
+ * @param key Pointer to the key
48
+ * @param key_bits 128, 192 or 256
49
+ * @param decrypt 0 for encryption, 1 for decryption
50
+ */
51
+ int av_aes_init(struct AVAES *a, const uint8_t *key, int key_bits, int decrypt);
52
+
53
+ /**
54
+ * Encrypt or decrypt a buffer using a previously initialized context.
55
+ *
56
+ * @param a The AVAES context
57
+ * @param dst destination array, can be equal to src
58
+ * @param src source array, can be equal to dst
59
+ * @param count number of 16 byte blocks
60
+ * @param iv initialization vector for CBC mode, if NULL then ECB will be used
61
+ * @param decrypt 0 for encryption, 1 for decryption
62
+ */
63
+ void av_aes_crypt(struct AVAES *a, uint8_t *dst, const uint8_t *src, int count, uint8_t *iv, int decrypt);
64
+
65
+ /**
66
+ * @}
67
+ */
68
+
69
+ #endif /* AVUTIL_AES_H */