@remotion/renderer 4.0.0-alpha.4 → 4.0.0-alpha4
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.
- package/LICENSE.md +8 -8
- package/README.md +47 -0
- package/client.d.ts +1 -0
- package/client.js +1 -0
- package/dist/assets/calculate-asset-positions.d.ts +0 -0
- package/dist/assets/calculate-asset-positions.js +1 -0
- package/dist/assets/calculate-atempo.d.ts +0 -0
- package/dist/assets/calculate-atempo.js +0 -0
- package/dist/assets/convert-assets-to-file-urls.d.ts +0 -0
- package/dist/assets/convert-assets-to-file-urls.js +0 -0
- package/dist/assets/download-and-map-assets-to-file.d.ts +2 -1
- package/dist/assets/download-and-map-assets-to-file.js +60 -11
- package/dist/assets/download-file.d.ts +7 -5
- package/dist/assets/download-file.js +49 -6
- package/dist/assets/download-map.d.ts +8 -3
- package/dist/assets/download-map.js +8 -4
- package/dist/assets/ffmpeg-volume-expression.d.ts +2 -1
- package/dist/assets/ffmpeg-volume-expression.js +5 -3
- package/dist/assets/flatten-volume-array.d.ts +0 -0
- package/dist/assets/flatten-volume-array.js +0 -0
- package/dist/assets/get-audio-channels.d.ts +1 -1
- package/dist/assets/get-audio-channels.js +5 -4
- package/dist/assets/get-video-stream-duration.d.ts +7 -1
- package/dist/assets/get-video-stream-duration.js +50 -14
- package/dist/assets/read-file.d.ts +0 -0
- package/dist/assets/read-file.js +2 -4
- package/dist/assets/round-volume-to-avoid-stack-overflow.d.ts +0 -0
- package/dist/assets/round-volume-to-avoid-stack-overflow.js +0 -0
- package/dist/assets/sanitize-filename.d.ts +0 -0
- package/dist/assets/sanitize-filename.js +0 -0
- package/dist/assets/sanitize-filepath.d.ts +0 -0
- package/dist/assets/sanitize-filepath.js +0 -0
- package/dist/assets/truncate-utf8-bytes.d.ts +0 -0
- package/dist/assets/truncate-utf8-bytes.js +0 -0
- package/dist/assets/types.d.ts +1 -0
- package/dist/assets/types.js +0 -0
- package/dist/audio-codec.d.ts +27 -0
- package/dist/audio-codec.js +89 -0
- package/dist/browser/Browser.d.ts +4 -2
- package/dist/browser/Browser.js +15 -12
- package/dist/browser/BrowserConnector.d.ts +0 -0
- package/dist/browser/BrowserConnector.js +0 -0
- package/dist/browser/BrowserFetcher.d.ts +16 -63
- package/dist/browser/BrowserFetcher.js +146 -231
- package/dist/browser/BrowserPage.d.ts +8 -2
- package/dist/browser/BrowserPage.js +8 -11
- package/dist/browser/BrowserRunner.d.ts +1 -4
- package/dist/browser/BrowserRunner.js +30 -73
- package/dist/browser/Connection.d.ts +0 -0
- package/dist/browser/Connection.js +1 -1
- package/dist/browser/ConsoleMessage.d.ts +0 -0
- package/dist/browser/ConsoleMessage.js +0 -0
- package/dist/browser/DOMWorld.d.ts +2 -1
- package/dist/browser/DOMWorld.js +8 -1
- package/dist/browser/Errors.d.ts +0 -0
- package/dist/browser/Errors.js +0 -0
- package/dist/browser/EvalTypes.d.ts +0 -0
- package/dist/browser/EvalTypes.js +0 -0
- package/dist/browser/EventEmitter.d.ts +0 -0
- package/dist/browser/EventEmitter.js +0 -0
- package/dist/browser/ExecutionContext.d.ts +0 -0
- package/dist/browser/ExecutionContext.js +0 -0
- package/dist/browser/FrameManager.d.ts +0 -2
- package/dist/browser/FrameManager.js +0 -3
- package/dist/browser/HTTPRequest.d.ts +0 -0
- package/dist/browser/HTTPRequest.js +0 -0
- package/dist/browser/HTTPResponse.d.ts +0 -0
- package/dist/browser/HTTPResponse.js +0 -0
- package/dist/browser/JSHandle.d.ts +0 -0
- package/dist/browser/JSHandle.js +0 -0
- package/dist/browser/LaunchOptions.d.ts +0 -4
- package/dist/browser/LaunchOptions.js +0 -0
- package/dist/browser/Launcher.d.ts +7 -1
- package/dist/browser/Launcher.js +12 -375
- package/dist/browser/LifecycleWatcher.d.ts +0 -0
- package/dist/browser/LifecycleWatcher.js +0 -0
- package/dist/browser/NetworkEventManager.d.ts +0 -0
- package/dist/browser/NetworkEventManager.js +0 -0
- package/dist/browser/NetworkManager.d.ts +0 -0
- package/dist/browser/NetworkManager.js +0 -0
- package/dist/browser/NodeWebSocketTransport.d.ts +0 -0
- package/dist/browser/NodeWebSocketTransport.js +1 -1
- package/dist/browser/Product.d.ts +0 -0
- package/dist/browser/Product.js +0 -0
- package/dist/browser/PuppeteerNode.d.ts +0 -3
- package/dist/browser/PuppeteerNode.js +2 -14
- package/dist/browser/PuppeteerViewport.d.ts +0 -0
- package/dist/browser/PuppeteerViewport.js +0 -0
- package/dist/browser/ScreenshotOptions.d.ts +0 -14
- package/dist/browser/ScreenshotOptions.js +0 -1
- package/dist/browser/Target.d.ts +0 -0
- package/dist/browser/Target.js +0 -0
- package/dist/browser/TaskQueue.d.ts +0 -0
- package/dist/browser/TaskQueue.js +0 -0
- package/dist/browser/TimeoutSettings.d.ts +0 -0
- package/dist/browser/TimeoutSettings.js +0 -0
- package/dist/browser/assert.d.ts +0 -0
- package/dist/browser/assert.js +0 -0
- package/dist/browser/create-browser-fetcher.d.ts +0 -0
- package/dist/browser/create-browser-fetcher.js +34 -90
- package/dist/browser/devtools-commands.d.ts +0 -0
- package/dist/browser/devtools-commands.js +0 -0
- package/dist/browser/devtools-types.d.ts +4 -0
- package/dist/browser/devtools-types.js +0 -0
- package/dist/browser/get-download-destination.d.ts +0 -0
- package/dist/browser/get-download-destination.js +0 -0
- package/dist/browser/mitt/index.d.ts +0 -0
- package/dist/browser/mitt/index.js +0 -0
- package/dist/browser/node.d.ts +0 -0
- package/dist/browser/node.js +0 -0
- package/dist/browser/revisions.d.ts +0 -1
- package/dist/browser/revisions.js +0 -1
- package/dist/browser/util.d.ts +0 -0
- package/dist/browser/util.js +0 -0
- package/dist/browser-executable.d.ts +0 -0
- package/dist/browser-executable.js +0 -0
- package/dist/browser-log.d.ts +0 -0
- package/dist/browser-log.js +0 -0
- package/dist/browser.d.ts +0 -0
- package/dist/browser.js +0 -0
- package/dist/calculate-ffmpeg-filters.d.ts +2 -1
- package/dist/calculate-ffmpeg-filters.js +1 -0
- package/dist/calculate-sar-dar-pixels.d.ts +0 -0
- package/dist/calculate-sar-dar-pixels.js +0 -0
- package/dist/can-use-parallel-encoding.d.ts +0 -0
- package/dist/can-use-parallel-encoding.js +0 -0
- package/dist/check-apple-silicon.d.ts +1 -0
- package/dist/check-apple-silicon.js +55 -0
- package/dist/chunk.d.ts +0 -0
- package/dist/chunk.js +0 -0
- package/dist/client.d.ts +179 -0
- package/dist/client.js +23 -0
- package/dist/codec-supports-media.d.ts +1 -0
- package/dist/codec-supports-media.js +8 -1
- package/dist/codec.d.ts +0 -0
- package/dist/codec.js +0 -0
- package/dist/combine-videos.d.ts +9 -2
- package/dist/combine-videos.js +12 -8
- package/dist/compositor/compose.d.ts +13 -0
- package/dist/compositor/compose.js +47 -0
- package/dist/compositor/get-executable-path.d.ts +1 -0
- package/dist/compositor/get-executable-path.js +47 -0
- package/dist/compositor/payloads.d.ts +41 -0
- package/dist/compositor/payloads.js +2 -0
- package/dist/compress-assets.d.ts +0 -0
- package/dist/compress-assets.js +0 -0
- package/dist/convert-number-of-gif-loops-to-ffmpeg.d.ts +0 -0
- package/dist/convert-number-of-gif-loops-to-ffmpeg.js +0 -0
- package/dist/convert-to-positive-frame-index.d.ts +4 -0
- package/dist/convert-to-positive-frame-index.js +8 -0
- package/dist/create-ffmpeg-complex-filter.d.ts +9 -5
- package/dist/create-ffmpeg-complex-filter.js +8 -4
- package/dist/create-ffmpeg-merge-filter.d.ts +8 -1
- package/dist/create-ffmpeg-merge-filter.js +29 -13
- package/dist/create-silent-audio.d.ts +2 -1
- package/dist/create-silent-audio.js +3 -2
- package/dist/crf.d.ts +5 -1
- package/dist/crf.js +33 -6
- package/dist/cycle-browser-tabs.d.ts +2 -5
- package/dist/cycle-browser-tabs.js +5 -5
- package/dist/delay-render-embedded-stack.d.ts +0 -0
- package/dist/delay-render-embedded-stack.js +0 -0
- package/dist/delete-directory.d.ts +1 -1
- package/dist/delete-directory.js +31 -5
- package/dist/determine-resize-params.d.ts +1 -0
- package/dist/determine-resize-params.js +10 -0
- package/dist/determine-vcodec-ffmpeg-flags.d.ts +2 -0
- package/dist/determine-vcodec-ffmpeg-flags.js +13 -0
- package/dist/does-have-m2-bug.d.ts +3 -0
- package/dist/does-have-m2-bug.js +12 -0
- package/dist/ensure-ffmpeg.d.ts +18 -0
- package/dist/ensure-ffmpeg.js +58 -0
- package/dist/ensure-frames-in-order.d.ts +0 -0
- package/dist/ensure-frames-in-order.js +0 -0
- package/dist/ensure-output-directory.d.ts +0 -0
- package/dist/ensure-output-directory.js +0 -0
- package/dist/ensure-presentation-timestamp.d.ts +14 -1
- package/dist/ensure-presentation-timestamp.js +36 -17
- package/dist/error-handling/handle-javascript-exception.d.ts +0 -0
- package/dist/error-handling/handle-javascript-exception.js +10 -0
- package/dist/error-handling/symbolicate-error.d.ts +0 -0
- package/dist/error-handling/symbolicate-error.js +2 -1
- package/dist/error-handling/symbolicateable-error.d.ts +0 -0
- package/dist/error-handling/symbolicateable-error.js +0 -0
- package/dist/extract-frame-from-video.d.ts +2 -0
- package/dist/extract-frame-from-video.js +47 -110
- package/dist/ffmpeg-executable.d.ts +0 -0
- package/dist/ffmpeg-executable.js +0 -0
- package/dist/ffmpeg-filter-file.d.ts +6 -1
- package/dist/ffmpeg-filter-file.js +36 -4
- package/dist/ffmpeg-flags.d.ts +20 -2
- package/dist/ffmpeg-flags.js +205 -9
- package/dist/ffmpeg-override.d.ts +4 -0
- package/dist/ffmpeg-override.js +2 -0
- package/dist/file-extensions.d.ts +25 -0
- package/dist/file-extensions.js +88 -0
- package/dist/find-closest-package-json.d.ts +2 -0
- package/dist/find-closest-package-json.js +31 -0
- package/dist/frame-range.d.ts +0 -0
- package/dist/frame-range.js +0 -0
- package/dist/frame-to-ffmpeg-timestamp.d.ts +0 -0
- package/dist/frame-to-ffmpeg-timestamp.js +0 -0
- package/dist/get-browser-instance.d.ts +0 -0
- package/dist/get-browser-instance.js +1 -1
- package/dist/get-can-extract-frames-fast.d.ts +14 -0
- package/dist/get-can-extract-frames-fast.js +71 -0
- package/dist/get-codec-name.d.ts +0 -0
- package/dist/get-codec-name.js +0 -0
- package/dist/get-compositions.d.ts +4 -0
- package/dist/get-compositions.js +26 -7
- package/dist/get-concurrency.d.ts +1 -1
- package/dist/get-concurrency.js +8 -1
- package/dist/get-duration-from-frame-range.d.ts +0 -0
- package/dist/get-duration-from-frame-range.js +0 -0
- package/dist/get-extension-from-codec.d.ts +5 -1
- package/dist/get-extension-from-codec.js +56 -32
- package/dist/get-extension-of-filename.d.ts +0 -0
- package/dist/get-extension-of-filename.js +5 -1
- package/dist/get-frame-of-video-slow.d.ts +15 -0
- package/dist/get-frame-of-video-slow.js +72 -0
- package/dist/get-frame-padded-index.d.ts +1 -1
- package/dist/get-frame-padded-index.js +3 -2
- package/dist/get-frame-to-render.d.ts +0 -0
- package/dist/get-frame-to-render.js +1 -1
- package/dist/get-local-browser-executable.d.ts +0 -0
- package/dist/get-local-browser-executable.js +4 -14
- package/dist/get-port.d.ts +4 -1
- package/dist/get-port.js +8 -8
- package/dist/get-prores-profile-name.d.ts +0 -0
- package/dist/get-prores-profile-name.js +0 -0
- package/dist/get-video-info.d.ts +6 -1
- package/dist/get-video-info.js +19 -9
- package/dist/get-video-threads-flag.d.ts +0 -0
- package/dist/get-video-threads-flag.js +0 -0
- package/dist/guess-extension-for-media.d.ts +5 -1
- package/dist/guess-extension-for-media.js +4 -3
- package/dist/image-format.d.ts +1 -1
- package/dist/image-format.js +3 -0
- package/dist/index.d.ts +187 -41
- package/dist/index.js +31 -28
- package/dist/is-audio-codec.d.ts +0 -0
- package/dist/is-audio-codec.js +0 -0
- package/dist/is-beyond-last-frame.d.ts +0 -0
- package/dist/is-beyond-last-frame.js +0 -0
- package/dist/is-serve-url.d.ts +0 -0
- package/dist/is-serve-url.js +0 -0
- package/dist/last-frame-from-video-cache.d.ts +2 -0
- package/dist/last-frame-from-video-cache.js +0 -0
- package/dist/legacy-webpack-config.d.ts +0 -0
- package/dist/legacy-webpack-config.js +0 -0
- package/dist/locks.d.ts +7 -0
- package/dist/locks.js +44 -0
- package/dist/log-level.d.ts +0 -0
- package/dist/log-level.js +0 -0
- package/dist/make-cancel-signal.d.ts +11 -0
- package/dist/make-cancel-signal.js +24 -1
- package/dist/merge-audio-track.d.ts +3 -1
- package/dist/merge-audio-track.js +43 -30
- package/dist/mime-db.d.ts +0 -0
- package/dist/mime-db.js +0 -0
- package/dist/mime-types.d.ts +1 -0
- package/dist/mime-types.js +6 -1
- package/dist/normalize-serve-url.d.ts +0 -0
- package/dist/normalize-serve-url.js +0 -0
- package/dist/offthread-video-server.d.ts +2 -1
- package/dist/offthread-video-server.js +13 -1
- package/dist/open-browser.d.ts +5 -0
- package/dist/open-browser.js +12 -15
- package/dist/overwrite.d.ts +0 -0
- package/dist/overwrite.js +0 -0
- package/dist/p-limit.d.ts +0 -0
- package/dist/p-limit.js +0 -0
- package/dist/parse-browser-error-stack.d.ts +0 -0
- package/dist/parse-browser-error-stack.js +0 -0
- package/dist/parse-ffmpeg-progress.d.ts +0 -0
- package/dist/parse-ffmpeg-progress.js +0 -0
- package/dist/perf.d.ts +0 -0
- package/dist/perf.js +0 -0
- package/dist/pixel-format.d.ts +1 -1
- package/dist/pixel-format.js +3 -0
- package/dist/pool.d.ts +0 -0
- package/dist/pool.js +0 -0
- package/dist/prepare-server.d.ts +3 -2
- package/dist/prepare-server.js +8 -3
- package/dist/preprocess-audio-track.d.ts +7 -1
- package/dist/preprocess-audio-track.js +7 -4
- package/dist/prespawn-ffmpeg.d.ts +4 -1
- package/dist/prespawn-ffmpeg.js +17 -12
- package/dist/prestitcher-memory-usage.d.ts +0 -0
- package/dist/prestitcher-memory-usage.js +0 -0
- package/dist/prores-profile.d.ts +4 -1
- package/dist/prores-profile.js +6 -6
- package/dist/provide-screenshot.d.ts +5 -1
- package/dist/provide-screenshot.js +4 -1
- package/dist/puppeteer-evaluate.d.ts +0 -0
- package/dist/puppeteer-evaluate.js +19 -11
- package/dist/puppeteer-screenshot.d.ts +11 -2
- package/dist/puppeteer-screenshot.js +11 -14
- package/dist/quality.d.ts +0 -0
- package/dist/quality.js +0 -0
- package/dist/redirect-status-codes.d.ts +1 -0
- package/dist/redirect-status-codes.js +6 -0
- package/dist/render-frames.d.ts +15 -3
- package/dist/render-frames.js +176 -84
- package/dist/render-media.d.ts +38 -6
- package/dist/render-media.js +123 -27
- package/dist/render-still.d.ts +8 -4
- package/dist/render-still.js +66 -31
- package/dist/replace-browser.d.ts +6 -0
- package/dist/replace-browser.js +47 -0
- package/dist/resolve-asset-src.d.ts +0 -0
- package/dist/resolve-asset-src.js +0 -0
- package/dist/sample-rate.d.ts +0 -0
- package/dist/sample-rate.js +0 -0
- package/dist/screenshot-dom-element.d.ts +5 -1
- package/dist/screenshot-dom-element.js +10 -2
- package/dist/screenshot-task.d.ts +12 -2
- package/dist/screenshot-task.js +24 -9
- package/dist/seek-to-frame.d.ts +1 -0
- package/dist/seek-to-frame.js +49 -3
- package/dist/serve-handler/index.d.ts +0 -0
- package/dist/serve-handler/index.js +0 -0
- package/dist/serve-handler/is-path-inside.d.ts +0 -0
- package/dist/serve-handler/is-path-inside.js +0 -0
- package/dist/serve-handler/range-parser.d.ts +0 -0
- package/dist/serve-handler/range-parser.js +0 -0
- package/dist/serve-static.d.ts +1 -0
- package/dist/serve-static.js +77 -41
- package/dist/set-props-and-env.d.ts +3 -1
- package/dist/set-props-and-env.js +39 -15
- package/dist/stitch-frames-to-video.d.ts +14 -1
- package/dist/stitch-frames-to-video.js +122 -50
- package/dist/stringify-ffmpeg-filter.d.ts +10 -2
- package/dist/stringify-ffmpeg-filter.js +37 -34
- package/dist/symbolicate-stacktrace.d.ts +0 -0
- package/dist/symbolicate-stacktrace.js +0 -0
- package/dist/take-frame-and-compose.d.ts +20 -0
- package/dist/take-frame-and-compose.js +96 -0
- package/dist/tmp-dir.d.ts +0 -0
- package/dist/tmp-dir.js +0 -0
- package/dist/truthy.d.ts +0 -0
- package/dist/truthy.js +0 -0
- package/dist/try-to-extract-frame-of-video-fast.d.ts +13 -0
- package/dist/try-to-extract-frame-of-video-fast.js +55 -0
- package/dist/types.d.ts +0 -0
- package/dist/types.js +0 -0
- package/dist/validate-concurrency.d.ts +0 -0
- package/dist/validate-concurrency.js +14 -9
- package/dist/validate-even-dimensions-with-codec.d.ts +0 -0
- package/dist/validate-even-dimensions-with-codec.js +0 -0
- package/dist/validate-every-nth-frame.d.ts +2 -1
- package/dist/validate-every-nth-frame.js +8 -1
- package/dist/validate-ffmpeg-override.d.ts +2 -0
- package/dist/validate-ffmpeg-override.js +12 -0
- package/dist/validate-ffmpeg.d.ts +7 -2
- package/dist/validate-ffmpeg.js +48 -43
- package/dist/validate-number-of-gif-loops.d.ts +2 -0
- package/dist/validate-number-of-gif-loops.js +24 -0
- package/dist/validate-opengl-renderer.d.ts +0 -0
- package/dist/validate-opengl-renderer.js +0 -0
- package/dist/validate-output-filename.d.ts +7 -2
- package/dist/validate-output-filename.js +20 -51
- package/dist/validate-puppeteer-timeout.d.ts +0 -0
- package/dist/validate-puppeteer-timeout.js +1 -1
- package/dist/validate-scale.d.ts +0 -0
- package/dist/validate-scale.js +0 -0
- package/dist/validate-videobitrate.d.ts +1 -0
- package/dist/validate-videobitrate.js +20 -0
- package/dist/wait-for-symbolication-error-to-be-done.d.ts +0 -0
- package/dist/wait-for-symbolication-error-to-be-done.js +5 -31
- package/dist/warn-about-ffmpeg-version.d.ts +5 -0
- package/dist/warn-about-ffmpeg-version.js +37 -0
- package/dist/ws/ws-types.d.ts +0 -0
- package/dist/ws/ws-types.js +2 -1
- package/package.json +68 -60
- package/.prettierrc.js +0 -14
- package/dist/add-silent-audio-if-necessary.d.ts +0 -8
- package/dist/add-silent-audio-if-necessary.d.ts.map +0 -1
- package/dist/add-silent-audio-if-necessary.js +0 -51
- package/dist/add-silent-audio-if-necessary.js.map +0 -1
- package/dist/assets/asset-is-used-at-time.d.ts +0 -3
- package/dist/assets/asset-is-used-at-time.d.ts.map +0 -1
- package/dist/assets/asset-is-used-at-time.js +0 -8
- package/dist/assets/asset-is-used-at-time.js.map +0 -1
- package/dist/assets/calculate-asset-positions.d.ts.map +0 -1
- package/dist/assets/calculate-asset-positions.js.map +0 -1
- package/dist/assets/calculate-atempo.d.ts.map +0 -1
- package/dist/assets/calculate-atempo.js.map +0 -1
- package/dist/assets/convert-assets-to-file-urls.d.ts.map +0 -1
- package/dist/assets/convert-assets-to-file-urls.js.map +0 -1
- package/dist/assets/download-and-map-assets-to-file.d.ts.map +0 -1
- package/dist/assets/download-and-map-assets-to-file.js.map +0 -1
- package/dist/assets/download-file.d.ts.map +0 -1
- package/dist/assets/download-file.js.map +0 -1
- package/dist/assets/ffmpeg-volume-expression.d.ts.map +0 -1
- package/dist/assets/ffmpeg-volume-expression.js.map +0 -1
- package/dist/assets/flatten-volume-array.d.ts.map +0 -1
- package/dist/assets/flatten-volume-array.js.map +0 -1
- package/dist/assets/get-asset-audio-details.d.ts +0 -5
- package/dist/assets/get-asset-audio-details.d.ts.map +0 -1
- package/dist/assets/get-asset-audio-details.js +0 -21
- package/dist/assets/get-asset-audio-details.js.map +0 -1
- package/dist/assets/get-audio-channels.d.ts.map +0 -1
- package/dist/assets/get-audio-channels.js.map +0 -1
- package/dist/assets/get-simulatenous-assets.d.ts +0 -3
- package/dist/assets/get-simulatenous-assets.d.ts.map +0 -1
- package/dist/assets/get-simulatenous-assets.js +0 -14
- package/dist/assets/get-simulatenous-assets.js.map +0 -1
- package/dist/assets/read-file.d.ts.map +0 -1
- package/dist/assets/read-file.js.map +0 -1
- package/dist/assets/round-volume-to-avoid-stack-overflow.d.ts.map +0 -1
- package/dist/assets/round-volume-to-avoid-stack-overflow.js.map +0 -1
- package/dist/assets/sanitize-filename.d.ts.map +0 -1
- package/dist/assets/sanitize-filename.js.map +0 -1
- package/dist/assets/sanitize-filepath.d.ts.map +0 -1
- package/dist/assets/sanitize-filepath.js.map +0 -1
- package/dist/assets/split-assets-into-segments.d.ts +0 -6
- package/dist/assets/split-assets-into-segments.d.ts.map +0 -1
- package/dist/assets/split-assets-into-segments.js +0 -89
- package/dist/assets/split-assets-into-segments.js.map +0 -1
- package/dist/assets/truncate-utf8-bytes.d.ts.map +0 -1
- package/dist/assets/truncate-utf8-bytes.js.map +0 -1
- package/dist/assets/types.d.ts.map +0 -1
- package/dist/assets/types.js.map +0 -1
- package/dist/assets-to-ffmpeg-inputs.d.ts +0 -7
- package/dist/assets-to-ffmpeg-inputs.d.ts.map +0 -1
- package/dist/assets-to-ffmpeg-inputs.js +0 -15
- package/dist/assets-to-ffmpeg-inputs.js.map +0 -1
- package/dist/browser-log.d.ts.map +0 -1
- package/dist/browser-log.js.map +0 -1
- package/dist/calculate-ffmpeg-filters.d.ts.map +0 -1
- package/dist/calculate-ffmpeg-filters.js.map +0 -1
- package/dist/can-use-parallel-encoding.d.ts.map +0 -1
- package/dist/can-use-parallel-encoding.js.map +0 -1
- package/dist/combine-videos.d.ts.map +0 -1
- package/dist/combine-videos.js.map +0 -1
- package/dist/convert-to-pcm.d.ts +0 -6
- package/dist/convert-to-pcm.js +0 -20
- package/dist/create-ffmpeg-complex-filter.d.ts.map +0 -1
- package/dist/create-ffmpeg-complex-filter.js.map +0 -1
- package/dist/cycle-browser-tabs.d.ts.map +0 -1
- package/dist/cycle-browser-tabs.js.map +0 -1
- package/dist/delay-render-embedded-stack.d.ts.map +0 -1
- package/dist/delay-render-embedded-stack.js.map +0 -1
- package/dist/delete-directory.d.ts.map +0 -1
- package/dist/delete-directory.js.map +0 -1
- package/dist/ensure-frames-in-order.d.ts.map +0 -1
- package/dist/ensure-frames-in-order.js.map +0 -1
- package/dist/ensure-output-directory.d.ts.map +0 -1
- package/dist/ensure-output-directory.js.map +0 -1
- package/dist/error-handling/handle-javascript-exception.d.ts.map +0 -1
- package/dist/error-handling/handle-javascript-exception.js.map +0 -1
- package/dist/error-handling/symbolicate-error.d.ts.map +0 -1
- package/dist/error-handling/symbolicate-error.js.map +0 -1
- package/dist/error-handling/symbolicateable-error.d.ts.map +0 -1
- package/dist/error-handling/symbolicateable-error.js.map +0 -1
- package/dist/ffmpeg-flags.d.ts.map +0 -1
- package/dist/ffmpeg-flags.js.map +0 -1
- package/dist/get-audio-codec-name.d.ts +0 -2
- package/dist/get-audio-codec-name.d.ts.map +0 -1
- package/dist/get-audio-codec-name.js +0 -28
- package/dist/get-audio-codec-name.js.map +0 -1
- package/dist/get-browser-instance.d.ts.map +0 -1
- package/dist/get-browser-instance.js.map +0 -1
- package/dist/get-codec-name.d.ts.map +0 -1
- package/dist/get-codec-name.js.map +0 -1
- package/dist/get-compositions.d.ts.map +0 -1
- package/dist/get-compositions.js.map +0 -1
- package/dist/get-concurrency.d.ts.map +0 -1
- package/dist/get-concurrency.js.map +0 -1
- package/dist/get-extension-from-codec.d.ts.map +0 -1
- package/dist/get-extension-from-codec.js.map +0 -1
- package/dist/get-frame-to-render.d.ts.map +0 -1
- package/dist/get-frame-to-render.js.map +0 -1
- package/dist/get-local-browser-executable.d.ts.map +0 -1
- package/dist/get-local-browser-executable.js.map +0 -1
- package/dist/get-port.d.ts.map +0 -1
- package/dist/get-port.js.map +0 -1
- package/dist/get-prores-profile-name.d.ts.map +0 -1
- package/dist/get-prores-profile-name.js.map +0 -1
- package/dist/image-format.d.ts.map +0 -1
- package/dist/image-format.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/is-serve-url.d.ts.map +0 -1
- package/dist/is-serve-url.js.map +0 -1
- package/dist/legacy-webpack-config.d.ts.map +0 -1
- package/dist/legacy-webpack-config.js.map +0 -1
- package/dist/make-assets-download-dir.d.ts +0 -1
- package/dist/make-assets-download-dir.d.ts.map +0 -1
- package/dist/make-assets-download-dir.js +0 -13
- package/dist/make-assets-download-dir.js.map +0 -1
- package/dist/normalize-serve-url.d.ts.map +0 -1
- package/dist/normalize-serve-url.js.map +0 -1
- package/dist/open-browser.d.ts.map +0 -1
- package/dist/open-browser.js.map +0 -1
- package/dist/parse-browser-error-stack.d.ts.map +0 -1
- package/dist/parse-browser-error-stack.js.map +0 -1
- package/dist/parse-ffmpeg-progress.d.ts.map +0 -1
- package/dist/parse-ffmpeg-progress.js.map +0 -1
- package/dist/pool.d.ts.map +0 -1
- package/dist/pool.js.map +0 -1
- package/dist/prepare-server.d.ts.map +0 -1
- package/dist/prepare-server.js.map +0 -1
- package/dist/provide-screenshot.d.ts.map +0 -1
- package/dist/provide-screenshot.js.map +0 -1
- package/dist/puppeteer-evaluate.d.ts.map +0 -1
- package/dist/puppeteer-evaluate.js.map +0 -1
- package/dist/puppeteer-screenshot.d.ts.map +0 -1
- package/dist/puppeteer-screenshot.js.map +0 -1
- package/dist/render-media.d.ts.map +0 -1
- package/dist/render-media.js.map +0 -1
- package/dist/render-still.d.ts.map +0 -1
- package/dist/render-still.js.map +0 -1
- package/dist/render.d.ts +0 -45
- package/dist/render.d.ts.map +0 -1
- package/dist/render.js +0 -245
- package/dist/render.js.map +0 -1
- package/dist/resolve-asset-src.d.ts.map +0 -1
- package/dist/resolve-asset-src.js.map +0 -1
- package/dist/sample-rate.d.ts.map +0 -1
- package/dist/sample-rate.js.map +0 -1
- package/dist/screenshot-dom-element.d.ts.map +0 -1
- package/dist/screenshot-dom-element.js.map +0 -1
- package/dist/screenshot-task.d.ts.map +0 -1
- package/dist/screenshot-task.js.map +0 -1
- package/dist/seek-to-frame.d.ts.map +0 -1
- package/dist/seek-to-frame.js.map +0 -1
- package/dist/serve-static.d.ts.map +0 -1
- package/dist/serve-static.js.map +0 -1
- package/dist/set-props-and-env.d.ts.map +0 -1
- package/dist/set-props-and-env.js.map +0 -1
- package/dist/stitcher.d.ts +0 -32
- package/dist/stitcher.d.ts.map +0 -1
- package/dist/stitcher.js +0 -204
- package/dist/stitcher.js.map +0 -1
- package/dist/stringify-ffmpeg-filter.d.ts.map +0 -1
- package/dist/stringify-ffmpeg-filter.js.map +0 -1
- package/dist/symbolicate-stacktrace.d.ts.map +0 -1
- package/dist/symbolicate-stacktrace.js.map +0 -1
- package/dist/tmp-dir.d.ts.map +0 -1
- package/dist/tmp-dir.js.map +0 -1
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js.map +0 -1
- package/dist/validate-even-dimensions-with-codec.d.ts.map +0 -1
- package/dist/validate-even-dimensions-with-codec.js.map +0 -1
- package/dist/validate-ffmpeg.d.ts.map +0 -1
- package/dist/validate-ffmpeg.js.map +0 -1
- package/dist/validate-frame.d.ts +0 -1
- package/dist/validate-frame.js +0 -24
- package/dist/validate-puppeteer-timeout.d.ts.map +0 -1
- package/dist/validate-puppeteer-timeout.js.map +0 -1
- package/dist/validate-scale.d.ts.map +0 -1
- package/dist/validate-scale.js.map +0 -1
- package/tsconfig.json +0 -10
- package/vitest.config.ts +0 -8
|
@@ -3,19 +3,24 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.ensurePresentationTimestamps = void 0;
|
|
6
|
+
exports.ensurePresentationTimestamps = exports.ensurePresentationTimestampWithoutCache = void 0;
|
|
7
7
|
const execa_1 = __importDefault(require("execa"));
|
|
8
8
|
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const ffmpeg_flags_1 = require("./ffmpeg-flags");
|
|
9
10
|
const guess_extension_for_media_1 = require("./guess-extension-for-media");
|
|
10
11
|
const truthy_1 = require("./truthy");
|
|
11
12
|
let callbacks = [];
|
|
12
|
-
const getTemporaryOutputName = async (src) => {
|
|
13
|
+
const getTemporaryOutputName = async ({ src, remotionRoot, ffprobeBinary, }) => {
|
|
13
14
|
const parts = src.split(path_1.default.sep);
|
|
14
15
|
// If there is no file extension for the video, then we need to temporarily add an extension
|
|
15
16
|
const lastPart = parts[parts.length - 1];
|
|
16
17
|
const extraExtension = lastPart.includes('.')
|
|
17
18
|
? null
|
|
18
|
-
: await (0, guess_extension_for_media_1.guessExtensionForVideo)(
|
|
19
|
+
: await (0, guess_extension_for_media_1.guessExtensionForVideo)({
|
|
20
|
+
src,
|
|
21
|
+
remotionRoot,
|
|
22
|
+
ffprobeBinary,
|
|
23
|
+
});
|
|
19
24
|
return parts
|
|
20
25
|
.map((p, i) => {
|
|
21
26
|
if (i === parts.length - 1) {
|
|
@@ -25,7 +30,29 @@ const getTemporaryOutputName = async (src) => {
|
|
|
25
30
|
})
|
|
26
31
|
.join(path_1.default.sep);
|
|
27
32
|
};
|
|
28
|
-
const
|
|
33
|
+
const ensurePresentationTimestampWithoutCache = async ({ src, remotionRoot, ffmpegExecutable, ffprobeExecutable, }) => {
|
|
34
|
+
// If there is no file extension for the video, then we need to tempoa
|
|
35
|
+
const output = await getTemporaryOutputName({
|
|
36
|
+
src,
|
|
37
|
+
remotionRoot,
|
|
38
|
+
ffprobeBinary: ffprobeExecutable,
|
|
39
|
+
});
|
|
40
|
+
await (0, execa_1.default)(await (0, ffmpeg_flags_1.getExecutableBinary)(ffmpegExecutable, remotionRoot, 'ffmpeg'), [
|
|
41
|
+
'-i',
|
|
42
|
+
src,
|
|
43
|
+
'-fflags',
|
|
44
|
+
'+genpts+igndts',
|
|
45
|
+
'-vcodec',
|
|
46
|
+
'copy',
|
|
47
|
+
'-acodec',
|
|
48
|
+
'copy',
|
|
49
|
+
output,
|
|
50
|
+
'-y',
|
|
51
|
+
]);
|
|
52
|
+
return output;
|
|
53
|
+
};
|
|
54
|
+
exports.ensurePresentationTimestampWithoutCache = ensurePresentationTimestampWithoutCache;
|
|
55
|
+
const ensurePresentationTimestamps = async ({ downloadMap, src, remotionRoot, ffmpegExecutable, ffprobeExecutable, }) => {
|
|
29
56
|
const elem = downloadMap.ensureFileHasPresentationTimestamp[src];
|
|
30
57
|
if ((elem === null || elem === void 0 ? void 0 : elem.type) === 'encoding') {
|
|
31
58
|
return new Promise((resolve) => {
|
|
@@ -39,20 +66,12 @@ const ensurePresentationTimestamps = async (downloadMap, src) => {
|
|
|
39
66
|
return elem.src;
|
|
40
67
|
}
|
|
41
68
|
downloadMap.ensureFileHasPresentationTimestamp[src] = { type: 'encoding' };
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
69
|
+
const output = await (0, exports.ensurePresentationTimestampWithoutCache)({
|
|
70
|
+
ffmpegExecutable,
|
|
71
|
+
ffprobeExecutable,
|
|
72
|
+
remotionRoot,
|
|
46
73
|
src,
|
|
47
|
-
|
|
48
|
-
'+genpts+igndts',
|
|
49
|
-
'-vcodec',
|
|
50
|
-
'copy',
|
|
51
|
-
'-acodec',
|
|
52
|
-
'copy',
|
|
53
|
-
output,
|
|
54
|
-
'-y',
|
|
55
|
-
]);
|
|
74
|
+
});
|
|
56
75
|
callbacks = callbacks.filter((c) => {
|
|
57
76
|
if (c.src === src) {
|
|
58
77
|
c.fn(output);
|
|
File without changes
|
|
@@ -16,6 +16,9 @@ exports.ErrorWithStackFrame = ErrorWithStackFrame;
|
|
|
16
16
|
const cleanUpErrorMessage = (exception) => {
|
|
17
17
|
var _a, _b, _c, _d;
|
|
18
18
|
let errorMessage = (_a = exception.exceptionDetails.exception) === null || _a === void 0 ? void 0 : _a.description;
|
|
19
|
+
if (!errorMessage) {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
19
22
|
const errorType = (_b = exception.exceptionDetails.exception) === null || _b === void 0 ? void 0 : _b.className;
|
|
20
23
|
const prefix = `${errorType}: `;
|
|
21
24
|
if (errorMessage.startsWith(prefix)) {
|
|
@@ -46,6 +49,13 @@ const handleJavascriptException = ({ page, onError, frame, }) => {
|
|
|
46
49
|
var _a, _b, _c;
|
|
47
50
|
const rawErrorMessage = (_a = exception.exceptionDetails.exception) === null || _a === void 0 ? void 0 : _a.description;
|
|
48
51
|
const cleanErrorMessage = cleanUpErrorMessage(exception);
|
|
52
|
+
if (!cleanErrorMessage) {
|
|
53
|
+
console.error(exception);
|
|
54
|
+
const err = new Error(rawErrorMessage);
|
|
55
|
+
err.stack = rawErrorMessage;
|
|
56
|
+
onError(err);
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
49
59
|
if (!exception.exceptionDetails.stackTrace) {
|
|
50
60
|
const err = new Error(removeDelayRenderStack(cleanErrorMessage));
|
|
51
61
|
err.stack = rawErrorMessage;
|
|
File without changes
|
|
@@ -2,13 +2,14 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.symbolicateError = void 0;
|
|
4
4
|
const symbolicate_stacktrace_1 = require("../symbolicate-stacktrace");
|
|
5
|
+
const truthy_1 = require("../truthy");
|
|
5
6
|
const handle_javascript_exception_1 = require("./handle-javascript-exception");
|
|
6
7
|
const symbolicateError = async (symbolicateableError) => {
|
|
7
8
|
const { delayRenderCall, stackFrame } = symbolicateableError;
|
|
8
9
|
const [mainErrorFrames, delayRenderFrames] = await Promise.all([
|
|
9
10
|
stackFrame ? (0, symbolicate_stacktrace_1.symbolicateStackTrace)(stackFrame) : null,
|
|
10
11
|
delayRenderCall ? (0, symbolicate_stacktrace_1.symbolicateStackTrace)(delayRenderCall) : null,
|
|
11
|
-
]);
|
|
12
|
+
].filter(truthy_1.truthy));
|
|
12
13
|
const symbolicatedErr = new handle_javascript_exception_1.ErrorWithStackFrame({
|
|
13
14
|
message: symbolicateableError.message,
|
|
14
15
|
symbolicatedStackFrames: mainErrorFrames,
|
|
File without changes
|
|
File without changes
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
1
2
|
import type { OffthreadVideoImageFormat } from 'remotion';
|
|
2
3
|
import type { DownloadMap } from './assets/download-map';
|
|
3
4
|
import type { FfmpegExecutable } from './ffmpeg-executable';
|
|
@@ -10,6 +11,7 @@ declare type Options = {
|
|
|
10
11
|
ffprobeExecutable: FfmpegExecutable;
|
|
11
12
|
imageFormat: OffthreadVideoImageFormat;
|
|
12
13
|
downloadMap: DownloadMap;
|
|
14
|
+
remotionRoot: string;
|
|
13
15
|
};
|
|
14
16
|
export declare const extractFrameFromVideo: (options: Options) => Promise<Buffer>;
|
|
15
17
|
export {};
|
|
@@ -6,150 +6,70 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.extractFrameFromVideo = exports.getLastFrameOfVideo = void 0;
|
|
7
7
|
const execa_1 = __importDefault(require("execa"));
|
|
8
8
|
const get_video_stream_duration_1 = require("./assets/get-video-stream-duration");
|
|
9
|
+
const determine_resize_params_1 = require("./determine-resize-params");
|
|
10
|
+
const determine_vcodec_ffmpeg_flags_1 = require("./determine-vcodec-ffmpeg-flags");
|
|
9
11
|
const ensure_presentation_timestamp_1 = require("./ensure-presentation-timestamp");
|
|
12
|
+
const ffmpeg_flags_1 = require("./ffmpeg-flags");
|
|
10
13
|
const frame_to_ffmpeg_timestamp_1 = require("./frame-to-ffmpeg-timestamp");
|
|
14
|
+
const get_can_extract_frames_fast_1 = require("./get-can-extract-frames-fast");
|
|
15
|
+
const get_frame_of_video_slow_1 = require("./get-frame-of-video-slow");
|
|
11
16
|
const get_video_info_1 = require("./get-video-info");
|
|
12
17
|
const is_beyond_last_frame_1 = require("./is-beyond-last-frame");
|
|
13
18
|
const last_frame_from_video_cache_1 = require("./last-frame-from-video-cache");
|
|
14
19
|
const p_limit_1 = require("./p-limit");
|
|
15
20
|
const perf_1 = require("./perf");
|
|
16
21
|
const truthy_1 = require("./truthy");
|
|
22
|
+
const try_to_extract_frame_of_video_fast_1 = require("./try-to-extract-frame-of-video-fast");
|
|
17
23
|
const lastFrameLimit = (0, p_limit_1.pLimit)(1);
|
|
18
24
|
const mainLimit = (0, p_limit_1.pLimit)(5);
|
|
19
|
-
const determineVcodecFfmepgFlags = (vcodecFlag) => {
|
|
20
|
-
return [
|
|
21
|
-
vcodecFlag === 'vp9' ? '-vcodec' : null,
|
|
22
|
-
vcodecFlag === 'vp9' ? 'libvpx-vp9' : null,
|
|
23
|
-
vcodecFlag === 'vp8' ? '-vcodec' : null,
|
|
24
|
-
vcodecFlag === 'vp8' ? 'libvpx' : null,
|
|
25
|
-
].filter(truthy_1.truthy);
|
|
26
|
-
};
|
|
27
|
-
const determineResizeParams = (needsResize) => {
|
|
28
|
-
if (needsResize === null) {
|
|
29
|
-
return [];
|
|
30
|
-
}
|
|
31
|
-
return ['-s', `${needsResize[0]}x${needsResize[1]}`];
|
|
32
|
-
};
|
|
33
|
-
// Uses no seeking, therefore the whole video has to be decoded. This is a last resort and should only happen
|
|
34
|
-
// if the video is corrupted
|
|
35
|
-
const getFrameOfVideoSlow = async ({ src, timestamp, ffmpegExecutable, imageFormat, specialVCodecForTransparency, needsResize, }) => {
|
|
36
|
-
console.warn(`\nUsing a slow method to extract the frame at ${timestamp}ms of ${src}. See https://remotion.dev/docs/slow-method-to-extract-frame for advice`);
|
|
37
|
-
const actualOffset = `-${timestamp * 1000}ms`;
|
|
38
|
-
const command = [
|
|
39
|
-
'-itsoffset',
|
|
40
|
-
actualOffset,
|
|
41
|
-
...determineVcodecFfmepgFlags(specialVCodecForTransparency),
|
|
42
|
-
'-i',
|
|
43
|
-
src,
|
|
44
|
-
'-frames:v',
|
|
45
|
-
'1',
|
|
46
|
-
'-c:v',
|
|
47
|
-
imageFormat === 'jpeg' ? 'mjpeg' : 'png',
|
|
48
|
-
'-f',
|
|
49
|
-
'image2pipe',
|
|
50
|
-
...determineResizeParams(needsResize),
|
|
51
|
-
'-',
|
|
52
|
-
].filter(truthy_1.truthy);
|
|
53
|
-
const { stdout, stderr } = (0, execa_1.default)(ffmpegExecutable !== null && ffmpegExecutable !== void 0 ? ffmpegExecutable : 'ffmpeg', command);
|
|
54
|
-
if (!stderr) {
|
|
55
|
-
throw new Error('unexpectedly did not get stderr');
|
|
56
|
-
}
|
|
57
|
-
if (!stdout) {
|
|
58
|
-
throw new Error('unexpectedly did not get stdout');
|
|
59
|
-
}
|
|
60
|
-
const stderrChunks = [];
|
|
61
|
-
const stdoutChunks = [];
|
|
62
|
-
const stdErrString = new Promise((resolve, reject) => {
|
|
63
|
-
stderr.on('data', (d) => stderrChunks.push(d));
|
|
64
|
-
stderr.on('error', (err) => reject(err));
|
|
65
|
-
stderr.on('end', () => resolve(Buffer.concat(stderrChunks).toString('utf-8')));
|
|
66
|
-
});
|
|
67
|
-
const stdoutChunk = new Promise((resolve, reject) => {
|
|
68
|
-
stdout.on('data', (d) => stdoutChunks.push(d));
|
|
69
|
-
stdout.on('error', (err) => reject(err));
|
|
70
|
-
stdout.on('end', () => resolve(Buffer.concat(stdoutChunks)));
|
|
71
|
-
});
|
|
72
|
-
const [stdErr, stdoutBuffer] = await Promise.all([stdErrString, stdoutChunk]);
|
|
73
|
-
const isEmpty = stdErr.includes('Output file is empty');
|
|
74
|
-
if (isEmpty) {
|
|
75
|
-
throw new Error(`Could not get last frame of ${src}. Tried to seek to the end using the command "ffmpeg ${command.join(' ')}" but got no frame. Most likely this video is corrupted.`);
|
|
76
|
-
}
|
|
77
|
-
return stdoutBuffer;
|
|
78
|
-
};
|
|
79
25
|
const getLastFrameOfVideoFastUnlimited = async (options) => {
|
|
80
26
|
const { ffmpegExecutable, ffprobeExecutable, offset, src, downloadMap } = options;
|
|
81
27
|
const fromCache = (0, last_frame_from_video_cache_1.getLastFrameFromCache)({ ...options, offset: 0 });
|
|
82
28
|
if (fromCache) {
|
|
83
29
|
return fromCache;
|
|
84
30
|
}
|
|
85
|
-
const { duration, fps } = await (0, get_video_stream_duration_1.getVideoStreamDuration)(downloadMap, src, ffprobeExecutable);
|
|
31
|
+
const { duration, fps } = await (0, get_video_stream_duration_1.getVideoStreamDuration)(downloadMap, src, ffprobeExecutable, options.remotionRoot);
|
|
86
32
|
if (duration === null) {
|
|
87
33
|
throw new Error(`Could not determine the duration of ${src} using FFMPEG. The file is not supported.`);
|
|
88
34
|
}
|
|
89
|
-
if (options.specialVCodecForTransparency === 'vp8' ||
|
|
90
|
-
|
|
91
|
-
|
|
35
|
+
if (options.specialVCodecForTransparency === 'vp8' ||
|
|
36
|
+
offset > get_can_extract_frames_fast_1.ACCEPTABLE_OFFSET_THRESHOLD) {
|
|
37
|
+
const last = await (0, get_frame_of_video_slow_1.getFrameOfVideoSlow)({
|
|
38
|
+
duration,
|
|
92
39
|
ffmpegExecutable,
|
|
93
40
|
src,
|
|
94
41
|
imageFormat: options.imageFormat,
|
|
95
42
|
specialVCodecForTransparency: options.specialVCodecForTransparency,
|
|
96
43
|
needsResize: options.needsResize,
|
|
44
|
+
offset: offset - 1000 / (fps === null ? 10 : fps),
|
|
45
|
+
fps,
|
|
46
|
+
remotionRoot: options.remotionRoot,
|
|
97
47
|
});
|
|
98
48
|
return last;
|
|
99
49
|
}
|
|
100
50
|
const actualOffset = `${duration * 1000 - offset}ms`;
|
|
101
|
-
const
|
|
102
|
-
'-ss',
|
|
51
|
+
const [stdErr, stdoutBuffer] = await (0, try_to_extract_frame_of_video_fast_1.tryToExtractFrameOfVideoFast)({
|
|
103
52
|
actualOffset,
|
|
104
|
-
|
|
105
|
-
|
|
53
|
+
ffmpegExecutable,
|
|
54
|
+
imageFormat: options.imageFormat,
|
|
55
|
+
needsResize: options.needsResize,
|
|
56
|
+
remotionRoot: options.remotionRoot,
|
|
57
|
+
specialVCodecForTransparency: options.specialVCodecForTransparency,
|
|
106
58
|
src,
|
|
107
|
-
'-frames:v',
|
|
108
|
-
'1',
|
|
109
|
-
'-c:v',
|
|
110
|
-
options.imageFormat === 'jpeg' ? 'mjpeg' : 'png',
|
|
111
|
-
'-f',
|
|
112
|
-
'image2pipe',
|
|
113
|
-
...determineResizeParams(options.needsResize),
|
|
114
|
-
'-',
|
|
115
|
-
].filter(truthy_1.truthy));
|
|
116
|
-
if (!stderr) {
|
|
117
|
-
throw new Error('unexpectedly did not get stderr');
|
|
118
|
-
}
|
|
119
|
-
if (!stdout) {
|
|
120
|
-
throw new Error('unexpectedly did not get stdout');
|
|
121
|
-
}
|
|
122
|
-
const stderrChunks = [];
|
|
123
|
-
const stdoutChunks = [];
|
|
124
|
-
const stdErrString = new Promise((resolve, reject) => {
|
|
125
|
-
stderr.on('data', (d) => stderrChunks.push(d));
|
|
126
|
-
stderr.on('error', (err) => reject(err));
|
|
127
|
-
stderr.on('end', () => resolve(Buffer.concat(stderrChunks).toString('utf-8')));
|
|
128
59
|
});
|
|
129
|
-
const stdoutChunk = new Promise((resolve, reject) => {
|
|
130
|
-
stdout.on('data', (d) => {
|
|
131
|
-
stdoutChunks.push(d);
|
|
132
|
-
});
|
|
133
|
-
stdout.on('error', (err) => {
|
|
134
|
-
reject(err);
|
|
135
|
-
});
|
|
136
|
-
stdout.on('end', () => {
|
|
137
|
-
resolve(Buffer.concat(stdoutChunks));
|
|
138
|
-
});
|
|
139
|
-
});
|
|
140
|
-
const [stdErr, stdoutBuffer] = await Promise.all([stdErrString, stdoutChunk]);
|
|
141
60
|
const isEmpty = stdErr.includes('Output file is empty');
|
|
142
61
|
if (isEmpty) {
|
|
143
62
|
const unlimited = await getLastFrameOfVideoFastUnlimited({
|
|
144
63
|
ffmpegExecutable,
|
|
145
64
|
// Decrement in 10ms increments, or 1 frame (e.g. fps = 25 --> 40ms)
|
|
146
|
-
offset: offset +
|
|
65
|
+
offset: offset + (fps === null ? 10 : 1000 / fps),
|
|
147
66
|
src,
|
|
148
67
|
ffprobeExecutable,
|
|
149
68
|
imageFormat: options.imageFormat,
|
|
150
69
|
specialVCodecForTransparency: options.specialVCodecForTransparency,
|
|
151
70
|
needsResize: options.needsResize,
|
|
152
71
|
downloadMap: options.downloadMap,
|
|
72
|
+
remotionRoot: options.remotionRoot,
|
|
153
73
|
});
|
|
154
74
|
return unlimited;
|
|
155
75
|
}
|
|
@@ -161,19 +81,29 @@ const getLastFrameOfVideo = async (options) => {
|
|
|
161
81
|
return result;
|
|
162
82
|
};
|
|
163
83
|
exports.getLastFrameOfVideo = getLastFrameOfVideo;
|
|
164
|
-
const extractFrameFromVideoFn = async ({ time, ffmpegExecutable, ffprobeExecutable, imageFormat, downloadMap, ...options }) => {
|
|
84
|
+
const extractFrameFromVideoFn = async ({ time, ffmpegExecutable, ffprobeExecutable, imageFormat, downloadMap, remotionRoot, ...options }) => {
|
|
165
85
|
// We make a new copy of the video only for video because the conversion may affect
|
|
166
86
|
// audio rendering, so we work with 2 different files
|
|
167
|
-
const src = await (0, ensure_presentation_timestamp_1.ensurePresentationTimestamps)(
|
|
168
|
-
|
|
87
|
+
const src = await (0, ensure_presentation_timestamp_1.ensurePresentationTimestamps)({
|
|
88
|
+
downloadMap,
|
|
89
|
+
src: options.src,
|
|
90
|
+
remotionRoot,
|
|
91
|
+
ffmpegExecutable,
|
|
92
|
+
ffprobeExecutable,
|
|
93
|
+
});
|
|
94
|
+
const { specialVcodecForTransparency: specialVcodec, needsResize } = await (0, get_video_info_1.getVideoInfo)(downloadMap, src, ffprobeExecutable, remotionRoot);
|
|
169
95
|
if (specialVcodec === 'vp8') {
|
|
170
|
-
|
|
96
|
+
const { fps } = await (0, get_video_stream_duration_1.getVideoStreamDuration)(downloadMap, src, ffprobeExecutable, remotionRoot);
|
|
97
|
+
return (0, get_frame_of_video_slow_1.getFrameOfVideoSlow)({
|
|
171
98
|
ffmpegExecutable,
|
|
172
99
|
imageFormat,
|
|
173
100
|
specialVCodecForTransparency: specialVcodec,
|
|
174
101
|
src,
|
|
175
|
-
|
|
102
|
+
duration: time,
|
|
176
103
|
needsResize,
|
|
104
|
+
offset: 0,
|
|
105
|
+
fps,
|
|
106
|
+
remotionRoot,
|
|
177
107
|
});
|
|
178
108
|
}
|
|
179
109
|
if ((0, is_beyond_last_frame_1.isBeyondLastFrame)(downloadMap, src, time)) {
|
|
@@ -186,14 +116,15 @@ const extractFrameFromVideoFn = async ({ time, ffmpegExecutable, ffprobeExecutab
|
|
|
186
116
|
specialVCodecForTransparency: specialVcodec,
|
|
187
117
|
needsResize,
|
|
188
118
|
downloadMap,
|
|
119
|
+
remotionRoot,
|
|
189
120
|
});
|
|
190
121
|
return lastFrame;
|
|
191
122
|
}
|
|
192
123
|
const ffmpegTimestamp = (0, frame_to_ffmpeg_timestamp_1.frameToFfmpegTimestamp)(time);
|
|
193
|
-
const { stdout, stderr } = (0, execa_1.default)(
|
|
124
|
+
const { stdout, stderr } = (0, execa_1.default)(await (0, ffmpeg_flags_1.getExecutableBinary)(ffmpegExecutable, remotionRoot, 'ffmpeg'), [
|
|
194
125
|
'-ss',
|
|
195
126
|
ffmpegTimestamp,
|
|
196
|
-
...
|
|
127
|
+
...(0, determine_vcodec_ffmpeg_flags_1.determineVcodecFfmpegFlags)(specialVcodec),
|
|
197
128
|
'-i',
|
|
198
129
|
src,
|
|
199
130
|
'-frames:v',
|
|
@@ -202,7 +133,7 @@ const extractFrameFromVideoFn = async ({ time, ffmpegExecutable, ffprobeExecutab
|
|
|
202
133
|
'image2pipe',
|
|
203
134
|
'-vcodec',
|
|
204
135
|
imageFormat === 'jpeg' ? 'mjpeg' : 'png',
|
|
205
|
-
...determineResizeParams(needsResize),
|
|
136
|
+
...(0, determine_resize_params_1.determineResizeParams)(needsResize),
|
|
206
137
|
'-',
|
|
207
138
|
].filter(truthy_1.truthy), {
|
|
208
139
|
buffer: false,
|
|
@@ -240,9 +171,15 @@ const extractFrameFromVideoFn = async ({ time, ffmpegExecutable, ffprobeExecutab
|
|
|
240
171
|
specialVCodecForTransparency: specialVcodec,
|
|
241
172
|
needsResize,
|
|
242
173
|
downloadMap,
|
|
174
|
+
remotionRoot,
|
|
243
175
|
});
|
|
244
176
|
return last;
|
|
245
177
|
}
|
|
178
|
+
if (stdOut.length === 0) {
|
|
179
|
+
console.log('FFMPEG Logs:');
|
|
180
|
+
console.log(stderrStr);
|
|
181
|
+
throw new Error("Couldn't extract frame from video - FFMPEG did not return any data. Check logs to see more information");
|
|
182
|
+
}
|
|
246
183
|
return stdOut;
|
|
247
184
|
};
|
|
248
185
|
const extractFrameFromVideo = async (options) => {
|
|
File without changes
|
|
File without changes
|
|
@@ -1,5 +1,10 @@
|
|
|
1
1
|
import type { DownloadMap } from './assets/download-map';
|
|
2
|
-
|
|
2
|
+
import type { FilterWithoutPaddingApplied } from './stringify-ffmpeg-filter';
|
|
3
|
+
export declare const makeFfmpegFilterFile: (complexFilter: FilterWithoutPaddingApplied, downloadMap: DownloadMap) => Promise<{
|
|
4
|
+
file: string;
|
|
5
|
+
cleanup: () => void;
|
|
6
|
+
}>;
|
|
7
|
+
export declare const makeFfmpegFilterFileStr: (complexFilter: string, downloadMap: DownloadMap) => Promise<{
|
|
3
8
|
file: string;
|
|
4
9
|
cleanup: () => void;
|
|
5
10
|
}>;
|
|
@@ -1,16 +1,48 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
// While an FFMPEG filter can be passed directly, if it's too long
|
|
3
3
|
// we run into Windows command length limits.
|
|
4
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
5
|
+
if (k2 === undefined) k2 = k;
|
|
6
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
7
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
8
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
9
|
+
}
|
|
10
|
+
Object.defineProperty(o, k2, desc);
|
|
11
|
+
}) : (function(o, m, k, k2) {
|
|
12
|
+
if (k2 === undefined) k2 = k;
|
|
13
|
+
o[k2] = m[k];
|
|
14
|
+
}));
|
|
15
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
16
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
17
|
+
}) : function(o, v) {
|
|
18
|
+
o["default"] = v;
|
|
19
|
+
});
|
|
20
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
21
|
+
if (mod && mod.__esModule) return mod;
|
|
22
|
+
var result = {};
|
|
23
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
24
|
+
__setModuleDefault(result, mod);
|
|
25
|
+
return result;
|
|
26
|
+
};
|
|
4
27
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
5
28
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
6
29
|
};
|
|
7
30
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.makeFfmpegFilterFile = void 0;
|
|
9
|
-
const fs_1 =
|
|
31
|
+
exports.makeFfmpegFilterFileStr = exports.makeFfmpegFilterFile = void 0;
|
|
32
|
+
const fs_1 = __importStar(require("fs"));
|
|
10
33
|
const path_1 = __importDefault(require("path"));
|
|
11
|
-
const makeFfmpegFilterFile =
|
|
34
|
+
const makeFfmpegFilterFile = (complexFilter, downloadMap) => {
|
|
35
|
+
return (0, exports.makeFfmpegFilterFileStr)(complexFilter.filter, downloadMap);
|
|
36
|
+
};
|
|
37
|
+
exports.makeFfmpegFilterFile = makeFfmpegFilterFile;
|
|
38
|
+
const makeFfmpegFilterFileStr = async (complexFilter, downloadMap) => {
|
|
12
39
|
const random = Math.random().toString().replace('.', '');
|
|
13
40
|
const filterFile = path_1.default.join(downloadMap.complexFilter, 'complex-filter-' + random + '.txt');
|
|
41
|
+
// Race condition: Sometimes the download map is deleted before the file is written.
|
|
42
|
+
// Can remove this once the original bug has been fixed
|
|
43
|
+
if (!(0, fs_1.existsSync)(downloadMap.complexFilter)) {
|
|
44
|
+
fs_1.default.mkdirSync(downloadMap.complexFilter, { recursive: true });
|
|
45
|
+
}
|
|
14
46
|
await fs_1.default.promises.writeFile(filterFile, complexFilter);
|
|
15
47
|
return {
|
|
16
48
|
file: filterFile,
|
|
@@ -19,4 +51,4 @@ const makeFfmpegFilterFile = async (complexFilter, downloadMap) => {
|
|
|
19
51
|
},
|
|
20
52
|
};
|
|
21
53
|
};
|
|
22
|
-
exports.
|
|
54
|
+
exports.makeFfmpegFilterFileStr = makeFfmpegFilterFileStr;
|
package/dist/ffmpeg-flags.d.ts
CHANGED
|
@@ -1,13 +1,31 @@
|
|
|
1
|
+
import type { FfmpegExecutable } from './ffmpeg-executable';
|
|
1
2
|
export declare type FfmpegVersion = [number, number, number] | null;
|
|
2
3
|
export declare const getFfmpegBuildInfo: (options: {
|
|
3
4
|
ffmpegExecutable: string | null;
|
|
5
|
+
remotionRoot: string;
|
|
4
6
|
}) => Promise<string>;
|
|
5
|
-
export declare const
|
|
7
|
+
export declare const ffmpegInNodeModules: (remotionRoot: string, binary: 'ffmpeg' | 'ffprobe') => string | null;
|
|
8
|
+
export declare const ffmpegHasFeature: ({ ffmpegExecutable, feature, remotionRoot, }: {
|
|
6
9
|
ffmpegExecutable: string | null;
|
|
7
10
|
feature: 'enable-gpl' | 'enable-libx265' | 'enable-libvpx';
|
|
8
|
-
|
|
11
|
+
remotionRoot: string;
|
|
9
12
|
}) => Promise<boolean>;
|
|
10
13
|
export declare const parseFfmpegVersion: (buildconf: string) => FfmpegVersion;
|
|
11
14
|
export declare const getFfmpegVersion: (options: {
|
|
12
15
|
ffmpegExecutable: string | null;
|
|
16
|
+
remotionRoot: string;
|
|
13
17
|
}) => Promise<FfmpegVersion>;
|
|
18
|
+
export declare const downloadBinary: (remotionRoot: string, url: string, binary: 'ffmpeg' | 'ffprobe') => Promise<string>;
|
|
19
|
+
export declare const lambdaFfmpegPaths: {
|
|
20
|
+
readonly ffmpeg: "/opt/bin/ffmpeg";
|
|
21
|
+
readonly ffprobe: "/opt/bin/ffprobe";
|
|
22
|
+
};
|
|
23
|
+
export declare const getExecutableBinary: (ffmpegExecutable: FfmpegExecutable, remotionRoot: string, binary: 'ffmpeg' | 'ffprobe') => string | Promise<string>;
|
|
24
|
+
export declare const getBinaryDownloadUrl: (binary: 'ffmpeg' | 'ffprobe') => {
|
|
25
|
+
url: string;
|
|
26
|
+
contentLength: number;
|
|
27
|
+
} | null;
|
|
28
|
+
export declare const warnAboutFfmpegVersion: ({ ffmpegVersion, buildConf, }: {
|
|
29
|
+
ffmpegVersion: FfmpegVersion;
|
|
30
|
+
buildConf: string | null;
|
|
31
|
+
}) => null | undefined;
|