@kenkaiiii/gg-editor 0.1.0
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 +21 -0
- package/README.md +453 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +173 -0
- package/dist/cli.js.map +1 -0
- package/dist/core/ass.d.ts +75 -0
- package/dist/core/ass.d.ts.map +1 -0
- package/dist/core/ass.js +128 -0
- package/dist/core/ass.js.map +1 -0
- package/dist/core/ass.test.d.ts +2 -0
- package/dist/core/ass.test.d.ts.map +1 -0
- package/dist/core/ass.test.js +112 -0
- package/dist/core/ass.test.js.map +1 -0
- package/dist/core/audio-cleanup.d.ts +16 -0
- package/dist/core/audio-cleanup.d.ts.map +1 -0
- package/dist/core/audio-cleanup.js +79 -0
- package/dist/core/audio-cleanup.js.map +1 -0
- package/dist/core/audio-cleanup.test.d.ts +2 -0
- package/dist/core/audio-cleanup.test.d.ts.map +1 -0
- package/dist/core/audio-cleanup.test.js +41 -0
- package/dist/core/audio-cleanup.test.js.map +1 -0
- package/dist/core/audio-mix.d.ts +89 -0
- package/dist/core/audio-mix.d.ts.map +1 -0
- package/dist/core/audio-mix.js +156 -0
- package/dist/core/audio-mix.js.map +1 -0
- package/dist/core/audio-mix.test.d.ts +2 -0
- package/dist/core/audio-mix.test.d.ts.map +1 -0
- package/dist/core/audio-mix.test.js +91 -0
- package/dist/core/audio-mix.test.js.map +1 -0
- package/dist/core/auth/anthropic.d.ts +4 -0
- package/dist/core/auth/anthropic.d.ts.map +1 -0
- package/dist/core/auth/anthropic.js +78 -0
- package/dist/core/auth/anthropic.js.map +1 -0
- package/dist/core/auth/index.d.ts +7 -0
- package/dist/core/auth/index.d.ts.map +1 -0
- package/dist/core/auth/index.js +6 -0
- package/dist/core/auth/index.js.map +1 -0
- package/dist/core/auth/login.d.ts +13 -0
- package/dist/core/auth/login.d.ts.map +1 -0
- package/dist/core/auth/login.js +188 -0
- package/dist/core/auth/login.js.map +1 -0
- package/dist/core/auth/openai.d.ts +4 -0
- package/dist/core/auth/openai.d.ts.map +1 -0
- package/dist/core/auth/openai.js +170 -0
- package/dist/core/auth/openai.js.map +1 -0
- package/dist/core/auth/pkce.d.ts +5 -0
- package/dist/core/auth/pkce.d.ts.map +1 -0
- package/dist/core/auth/pkce.js +17 -0
- package/dist/core/auth/pkce.js.map +1 -0
- package/dist/core/auth/storage.d.ts +29 -0
- package/dist/core/auth/storage.d.ts.map +1 -0
- package/dist/core/auth/storage.js +127 -0
- package/dist/core/auth/storage.js.map +1 -0
- package/dist/core/auth/types.d.ts +22 -0
- package/dist/core/auth/types.d.ts.map +1 -0
- package/dist/core/auth/types.js +12 -0
- package/dist/core/auth/types.js.map +1 -0
- package/dist/core/clustering.d.ts +52 -0
- package/dist/core/clustering.d.ts.map +1 -0
- package/dist/core/clustering.js +163 -0
- package/dist/core/clustering.js.map +1 -0
- package/dist/core/clustering.test.d.ts +2 -0
- package/dist/core/clustering.test.d.ts.map +1 -0
- package/dist/core/clustering.test.js +112 -0
- package/dist/core/clustering.test.js.map +1 -0
- package/dist/core/color-match.d.ts +19 -0
- package/dist/core/color-match.d.ts.map +1 -0
- package/dist/core/color-match.js +118 -0
- package/dist/core/color-match.js.map +1 -0
- package/dist/core/color-match.test.d.ts +2 -0
- package/dist/core/color-match.test.d.ts.map +1 -0
- package/dist/core/color-match.test.js +40 -0
- package/dist/core/color-match.test.js.map +1 -0
- package/dist/core/ducking.d.ts +37 -0
- package/dist/core/ducking.d.ts.map +1 -0
- package/dist/core/ducking.js +71 -0
- package/dist/core/ducking.js.map +1 -0
- package/dist/core/ducking.test.d.ts +2 -0
- package/dist/core/ducking.test.d.ts.map +1 -0
- package/dist/core/ducking.test.js +38 -0
- package/dist/core/ducking.test.js.map +1 -0
- package/dist/core/edl-roundtrip.test.d.ts +2 -0
- package/dist/core/edl-roundtrip.test.d.ts.map +1 -0
- package/dist/core/edl-roundtrip.test.js +171 -0
- package/dist/core/edl-roundtrip.test.js.map +1 -0
- package/dist/core/edl.d.ts +41 -0
- package/dist/core/edl.d.ts.map +1 -0
- package/dist/core/edl.js +56 -0
- package/dist/core/edl.js.map +1 -0
- package/dist/core/edl.test.d.ts +2 -0
- package/dist/core/edl.test.d.ts.map +1 -0
- package/dist/core/edl.test.js +62 -0
- package/dist/core/edl.test.js.map +1 -0
- package/dist/core/envelope-sync.d.ts +52 -0
- package/dist/core/envelope-sync.d.ts.map +1 -0
- package/dist/core/envelope-sync.js +169 -0
- package/dist/core/envelope-sync.js.map +1 -0
- package/dist/core/envelope-sync.test.d.ts +2 -0
- package/dist/core/envelope-sync.test.d.ts.map +1 -0
- package/dist/core/envelope-sync.test.js +70 -0
- package/dist/core/envelope-sync.test.js.map +1 -0
- package/dist/core/fcpxml-roundtrip.test.d.ts +2 -0
- package/dist/core/fcpxml-roundtrip.test.d.ts.map +1 -0
- package/dist/core/fcpxml-roundtrip.test.js +251 -0
- package/dist/core/fcpxml-roundtrip.test.js.map +1 -0
- package/dist/core/fcpxml.d.ts +172 -0
- package/dist/core/fcpxml.d.ts.map +1 -0
- package/dist/core/fcpxml.js +406 -0
- package/dist/core/fcpxml.js.map +1 -0
- package/dist/core/fcpxml.test.d.ts +2 -0
- package/dist/core/fcpxml.test.d.ts.map +1 -0
- package/dist/core/fcpxml.test.js +360 -0
- package/dist/core/fcpxml.test.js.map +1 -0
- package/dist/core/filler-words.d.ts +107 -0
- package/dist/core/filler-words.d.ts.map +1 -0
- package/dist/core/filler-words.js +221 -0
- package/dist/core/filler-words.js.map +1 -0
- package/dist/core/filler-words.test.d.ts +2 -0
- package/dist/core/filler-words.test.d.ts.map +1 -0
- package/dist/core/filler-words.test.js +177 -0
- package/dist/core/filler-words.test.js.map +1 -0
- package/dist/core/format.d.ts +36 -0
- package/dist/core/format.d.ts.map +1 -0
- package/dist/core/format.js +57 -0
- package/dist/core/format.js.map +1 -0
- package/dist/core/format.test.d.ts +2 -0
- package/dist/core/format.test.d.ts.map +1 -0
- package/dist/core/format.test.js +81 -0
- package/dist/core/format.test.js.map +1 -0
- package/dist/core/frames.d.ts +35 -0
- package/dist/core/frames.d.ts.map +1 -0
- package/dist/core/frames.js +64 -0
- package/dist/core/frames.js.map +1 -0
- package/dist/core/hook-analysis.d.ts +90 -0
- package/dist/core/hook-analysis.d.ts.map +1 -0
- package/dist/core/hook-analysis.js +222 -0
- package/dist/core/hook-analysis.js.map +1 -0
- package/dist/core/hook-analysis.test.d.ts +2 -0
- package/dist/core/hook-analysis.test.d.ts.map +1 -0
- package/dist/core/hook-analysis.test.js +130 -0
- package/dist/core/hook-analysis.test.js.map +1 -0
- package/dist/core/hosts/detect.d.ts +17 -0
- package/dist/core/hosts/detect.d.ts.map +1 -0
- package/dist/core/hosts/detect.js +64 -0
- package/dist/core/hosts/detect.js.map +1 -0
- package/dist/core/hosts/detect.test.d.ts +2 -0
- package/dist/core/hosts/detect.test.d.ts.map +1 -0
- package/dist/core/hosts/detect.test.js +17 -0
- package/dist/core/hosts/detect.test.js.map +1 -0
- package/dist/core/hosts/index.d.ts +13 -0
- package/dist/core/hosts/index.d.ts.map +1 -0
- package/dist/core/hosts/index.js +30 -0
- package/dist/core/hosts/index.js.map +1 -0
- package/dist/core/hosts/lazy.d.ts +53 -0
- package/dist/core/hosts/lazy.d.ts.map +1 -0
- package/dist/core/hosts/lazy.js +125 -0
- package/dist/core/hosts/lazy.js.map +1 -0
- package/dist/core/hosts/lazy.test.d.ts +2 -0
- package/dist/core/hosts/lazy.test.d.ts.map +1 -0
- package/dist/core/hosts/lazy.test.js +117 -0
- package/dist/core/hosts/lazy.test.js.map +1 -0
- package/dist/core/hosts/none/adapter.d.ts +74 -0
- package/dist/core/hosts/none/adapter.d.ts.map +1 -0
- package/dist/core/hosts/none/adapter.js +99 -0
- package/dist/core/hosts/none/adapter.js.map +1 -0
- package/dist/core/hosts/premiere/adapter.d.ts +87 -0
- package/dist/core/hosts/premiere/adapter.d.ts.map +1 -0
- package/dist/core/hosts/premiere/adapter.js +218 -0
- package/dist/core/hosts/premiere/adapter.js.map +1 -0
- package/dist/core/hosts/premiere/bridge-source.d.ts +26 -0
- package/dist/core/hosts/premiere/bridge-source.d.ts.map +1 -0
- package/dist/core/hosts/premiere/bridge-source.js +326 -0
- package/dist/core/hosts/premiere/bridge-source.js.map +1 -0
- package/dist/core/hosts/premiere/bridge-source.test.d.ts +2 -0
- package/dist/core/hosts/premiere/bridge-source.test.d.ts.map +1 -0
- package/dist/core/hosts/premiere/bridge-source.test.js +36 -0
- package/dist/core/hosts/premiere/bridge-source.test.js.map +1 -0
- package/dist/core/hosts/premiere/bridge.d.ts +38 -0
- package/dist/core/hosts/premiere/bridge.d.ts.map +1 -0
- package/dist/core/hosts/premiere/bridge.js +238 -0
- package/dist/core/hosts/premiere/bridge.js.map +1 -0
- package/dist/core/hosts/premiere/http-bridge.d.ts +47 -0
- package/dist/core/hosts/premiere/http-bridge.d.ts.map +1 -0
- package/dist/core/hosts/premiere/http-bridge.js +82 -0
- package/dist/core/hosts/premiere/http-bridge.js.map +1 -0
- package/dist/core/hosts/premiere/http-bridge.test.d.ts +2 -0
- package/dist/core/hosts/premiere/http-bridge.test.d.ts.map +1 -0
- package/dist/core/hosts/premiere/http-bridge.test.js +113 -0
- package/dist/core/hosts/premiere/http-bridge.test.js.map +1 -0
- package/dist/core/hosts/premiere/ws-bridge.d.ts +91 -0
- package/dist/core/hosts/premiere/ws-bridge.d.ts.map +1 -0
- package/dist/core/hosts/premiere/ws-bridge.js +303 -0
- package/dist/core/hosts/premiere/ws-bridge.js.map +1 -0
- package/dist/core/hosts/premiere/ws-bridge.test.d.ts +2 -0
- package/dist/core/hosts/premiere/ws-bridge.test.d.ts.map +1 -0
- package/dist/core/hosts/premiere/ws-bridge.test.js +146 -0
- package/dist/core/hosts/premiere/ws-bridge.test.js.map +1 -0
- package/dist/core/hosts/resolve/adapter.d.ts +99 -0
- package/dist/core/hosts/resolve/adapter.d.ts.map +1 -0
- package/dist/core/hosts/resolve/adapter.js +187 -0
- package/dist/core/hosts/resolve/adapter.js.map +1 -0
- package/dist/core/hosts/resolve/bridge-source.d.ts +17 -0
- package/dist/core/hosts/resolve/bridge-source.d.ts.map +1 -0
- package/dist/core/hosts/resolve/bridge-source.js +660 -0
- package/dist/core/hosts/resolve/bridge-source.js.map +1 -0
- package/dist/core/hosts/resolve/bridge.d.ts +51 -0
- package/dist/core/hosts/resolve/bridge.d.ts.map +1 -0
- package/dist/core/hosts/resolve/bridge.integration.test.d.ts +2 -0
- package/dist/core/hosts/resolve/bridge.integration.test.d.ts.map +1 -0
- package/dist/core/hosts/resolve/bridge.integration.test.js +472 -0
- package/dist/core/hosts/resolve/bridge.integration.test.js.map +1 -0
- package/dist/core/hosts/resolve/bridge.js +270 -0
- package/dist/core/hosts/resolve/bridge.js.map +1 -0
- package/dist/core/hosts/resolve/bridge.test.d.ts +2 -0
- package/dist/core/hosts/resolve/bridge.test.d.ts.map +1 -0
- package/dist/core/hosts/resolve/bridge.test.js +50 -0
- package/dist/core/hosts/resolve/bridge.test.js.map +1 -0
- package/dist/core/hosts/types.d.ts +167 -0
- package/dist/core/hosts/types.d.ts.map +1 -0
- package/dist/core/hosts/types.js +27 -0
- package/dist/core/hosts/types.js.map +1 -0
- package/dist/core/keyframes.d.ts +35 -0
- package/dist/core/keyframes.d.ts.map +1 -0
- package/dist/core/keyframes.js +90 -0
- package/dist/core/keyframes.js.map +1 -0
- package/dist/core/keyframes.test.d.ts +2 -0
- package/dist/core/keyframes.test.d.ts.map +1 -0
- package/dist/core/keyframes.test.js +73 -0
- package/dist/core/keyframes.test.js.map +1 -0
- package/dist/core/keyword-captions.d.ts +75 -0
- package/dist/core/keyword-captions.d.ts.map +1 -0
- package/dist/core/keyword-captions.js +285 -0
- package/dist/core/keyword-captions.js.map +1 -0
- package/dist/core/keyword-captions.test.d.ts +2 -0
- package/dist/core/keyword-captions.test.d.ts.map +1 -0
- package/dist/core/keyword-captions.test.js +90 -0
- package/dist/core/keyword-captions.test.js.map +1 -0
- package/dist/core/loudness.d.ts +52 -0
- package/dist/core/loudness.d.ts.map +1 -0
- package/dist/core/loudness.js +120 -0
- package/dist/core/loudness.js.map +1 -0
- package/dist/core/loudness.test.d.ts +2 -0
- package/dist/core/loudness.test.d.ts.map +1 -0
- package/dist/core/loudness.test.js +34 -0
- package/dist/core/loudness.test.js.map +1 -0
- package/dist/core/marker-colors.d.ts +39 -0
- package/dist/core/marker-colors.d.ts.map +1 -0
- package/dist/core/marker-colors.js +83 -0
- package/dist/core/marker-colors.js.map +1 -0
- package/dist/core/marker-colors.test.d.ts +2 -0
- package/dist/core/marker-colors.test.d.ts.map +1 -0
- package/dist/core/marker-colors.test.js +116 -0
- package/dist/core/marker-colors.test.js.map +1 -0
- package/dist/core/media/ffmpeg.d.ts +27 -0
- package/dist/core/media/ffmpeg.d.ts.map +1 -0
- package/dist/core/media/ffmpeg.js +53 -0
- package/dist/core/media/ffmpeg.js.map +1 -0
- package/dist/core/multicam.d.ts +40 -0
- package/dist/core/multicam.d.ts.map +1 -0
- package/dist/core/multicam.js +77 -0
- package/dist/core/multicam.js.map +1 -0
- package/dist/core/multicam.test.d.ts +2 -0
- package/dist/core/multicam.test.d.ts.map +1 -0
- package/dist/core/multicam.test.js +56 -0
- package/dist/core/multicam.test.js.map +1 -0
- package/dist/core/punch-in.d.ts +72 -0
- package/dist/core/punch-in.d.ts.map +1 -0
- package/dist/core/punch-in.js +133 -0
- package/dist/core/punch-in.js.map +1 -0
- package/dist/core/punch-in.test.d.ts +2 -0
- package/dist/core/punch-in.test.d.ts.map +1 -0
- package/dist/core/punch-in.test.js +118 -0
- package/dist/core/punch-in.test.js.map +1 -0
- package/dist/core/reformat.d.ts +26 -0
- package/dist/core/reformat.d.ts.map +1 -0
- package/dist/core/reformat.js +31 -0
- package/dist/core/reformat.js.map +1 -0
- package/dist/core/reformat.test.d.ts +2 -0
- package/dist/core/reformat.test.d.ts.map +1 -0
- package/dist/core/reformat.test.js +29 -0
- package/dist/core/reformat.test.js.map +1 -0
- package/dist/core/reorder.d.ts +42 -0
- package/dist/core/reorder.d.ts.map +1 -0
- package/dist/core/reorder.js +80 -0
- package/dist/core/reorder.js.map +1 -0
- package/dist/core/reorder.test.d.ts +2 -0
- package/dist/core/reorder.test.d.ts.map +1 -0
- package/dist/core/reorder.test.js +88 -0
- package/dist/core/reorder.test.js.map +1 -0
- package/dist/core/review.d.ts +38 -0
- package/dist/core/review.d.ts.map +1 -0
- package/dist/core/review.js +128 -0
- package/dist/core/review.js.map +1 -0
- package/dist/core/review.test.d.ts +2 -0
- package/dist/core/review.test.d.ts.map +1 -0
- package/dist/core/review.test.js +76 -0
- package/dist/core/review.test.js.map +1 -0
- package/dist/core/sessions.d.ts +40 -0
- package/dist/core/sessions.d.ts.map +1 -0
- package/dist/core/sessions.js +61 -0
- package/dist/core/sessions.js.map +1 -0
- package/dist/core/sfx-on-cuts.d.ts +60 -0
- package/dist/core/sfx-on-cuts.d.ts.map +1 -0
- package/dist/core/sfx-on-cuts.js +90 -0
- package/dist/core/sfx-on-cuts.js.map +1 -0
- package/dist/core/sfx-on-cuts.test.d.ts +2 -0
- package/dist/core/sfx-on-cuts.test.d.ts.map +1 -0
- package/dist/core/sfx-on-cuts.test.js +53 -0
- package/dist/core/sfx-on-cuts.test.js.map +1 -0
- package/dist/core/silence.d.ts +41 -0
- package/dist/core/silence.d.ts.map +1 -0
- package/dist/core/silence.js +104 -0
- package/dist/core/silence.js.map +1 -0
- package/dist/core/silence.test.d.ts +2 -0
- package/dist/core/silence.test.d.ts.map +1 -0
- package/dist/core/silence.test.js +143 -0
- package/dist/core/silence.test.js.map +1 -0
- package/dist/core/skills-loader.d.ts +34 -0
- package/dist/core/skills-loader.d.ts.map +1 -0
- package/dist/core/skills-loader.js +80 -0
- package/dist/core/skills-loader.js.map +1 -0
- package/dist/core/skills-loader.test.d.ts +2 -0
- package/dist/core/skills-loader.test.d.ts.map +1 -0
- package/dist/core/skills-loader.test.js +68 -0
- package/dist/core/skills-loader.test.js.map +1 -0
- package/dist/core/skin-grade.d.ts +62 -0
- package/dist/core/skin-grade.d.ts.map +1 -0
- package/dist/core/skin-grade.js +270 -0
- package/dist/core/skin-grade.js.map +1 -0
- package/dist/core/skin-grade.test.d.ts +2 -0
- package/dist/core/skin-grade.test.d.ts.map +1 -0
- package/dist/core/skin-grade.test.js +182 -0
- package/dist/core/skin-grade.test.js.map +1 -0
- package/dist/core/speaker-changes.d.ts +30 -0
- package/dist/core/speaker-changes.d.ts.map +1 -0
- package/dist/core/speaker-changes.js +19 -0
- package/dist/core/speaker-changes.js.map +1 -0
- package/dist/core/speaker-changes.test.d.ts +2 -0
- package/dist/core/speaker-changes.test.d.ts.map +1 -0
- package/dist/core/speaker-changes.test.js +46 -0
- package/dist/core/speaker-changes.test.js.map +1 -0
- package/dist/core/speed-ramp.d.ts +60 -0
- package/dist/core/speed-ramp.d.ts.map +1 -0
- package/dist/core/speed-ramp.js +113 -0
- package/dist/core/speed-ramp.js.map +1 -0
- package/dist/core/speed-ramp.test.d.ts +2 -0
- package/dist/core/speed-ramp.test.d.ts.map +1 -0
- package/dist/core/speed-ramp.test.js +74 -0
- package/dist/core/speed-ramp.test.js.map +1 -0
- package/dist/core/srt.d.ts +56 -0
- package/dist/core/srt.d.ts.map +1 -0
- package/dist/core/srt.js +90 -0
- package/dist/core/srt.js.map +1 -0
- package/dist/core/srt.test.d.ts +2 -0
- package/dist/core/srt.test.d.ts.map +1 -0
- package/dist/core/srt.test.js +107 -0
- package/dist/core/srt.test.js.map +1 -0
- package/dist/core/stabilize.d.ts +15 -0
- package/dist/core/stabilize.d.ts.map +1 -0
- package/dist/core/stabilize.js +69 -0
- package/dist/core/stabilize.js.map +1 -0
- package/dist/core/styles-loader.d.ts +33 -0
- package/dist/core/styles-loader.d.ts.map +1 -0
- package/dist/core/styles-loader.js +67 -0
- package/dist/core/styles-loader.js.map +1 -0
- package/dist/core/styles-loader.test.d.ts +2 -0
- package/dist/core/styles-loader.test.d.ts.map +1 -0
- package/dist/core/styles-loader.test.js +72 -0
- package/dist/core/styles-loader.test.js.map +1 -0
- package/dist/core/text-overlay.d.ts +76 -0
- package/dist/core/text-overlay.d.ts.map +1 -0
- package/dist/core/text-overlay.js +233 -0
- package/dist/core/text-overlay.js.map +1 -0
- package/dist/core/text-overlay.test.d.ts +2 -0
- package/dist/core/text-overlay.test.d.ts.map +1 -0
- package/dist/core/text-overlay.test.js +103 -0
- package/dist/core/text-overlay.test.js.map +1 -0
- package/dist/core/vision.d.ts +53 -0
- package/dist/core/vision.d.ts.map +1 -0
- package/dist/core/vision.js +150 -0
- package/dist/core/vision.js.map +1 -0
- package/dist/core/vision.test.d.ts +2 -0
- package/dist/core/vision.test.d.ts.map +1 -0
- package/dist/core/vision.test.js +76 -0
- package/dist/core/vision.test.js.map +1 -0
- package/dist/core/whisper.d.ts +188 -0
- package/dist/core/whisper.d.ts.map +1 -0
- package/dist/core/whisper.js +380 -0
- package/dist/core/whisper.js.map +1 -0
- package/dist/core/whisper.test.d.ts +2 -0
- package/dist/core/whisper.test.d.ts.map +1 -0
- package/dist/core/whisper.test.js +262 -0
- package/dist/core/whisper.test.js.map +1 -0
- package/dist/director/delegate-tool.d.ts +22 -0
- package/dist/director/delegate-tool.d.ts.map +1 -0
- package/dist/director/delegate-tool.js +62 -0
- package/dist/director/delegate-tool.js.map +1 -0
- package/dist/director/delegate-tool.test.d.ts +2 -0
- package/dist/director/delegate-tool.test.d.ts.map +1 -0
- package/dist/director/delegate-tool.test.js +38 -0
- package/dist/director/delegate-tool.test.js.map +1 -0
- package/dist/director/director-prompt.d.ts +7 -0
- package/dist/director/director-prompt.d.ts.map +1 -0
- package/dist/director/director-prompt.js +52 -0
- package/dist/director/director-prompt.js.map +1 -0
- package/dist/director/director.d.ts +16 -0
- package/dist/director/director.d.ts.map +1 -0
- package/dist/director/director.js +28 -0
- package/dist/director/director.js.map +1 -0
- package/dist/director/executor.d.ts +19 -0
- package/dist/director/executor.d.ts.map +1 -0
- package/dist/director/executor.js +93 -0
- package/dist/director/executor.js.map +1 -0
- package/dist/director/index.d.ts +6 -0
- package/dist/director/index.d.ts.map +1 -0
- package/dist/director/index.js +5 -0
- package/dist/director/index.js.map +1 -0
- package/dist/director/types.d.ts +38 -0
- package/dist/director/types.d.ts.map +1 -0
- package/dist/director/types.js +2 -0
- package/dist/director/types.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +12 -0
- package/dist/index.js.map +1 -0
- package/dist/skills.d.ts +18 -0
- package/dist/skills.d.ts.map +1 -0
- package/dist/skills.js +674 -0
- package/dist/skills.js.map +1 -0
- package/dist/system-prompt.d.ts +35 -0
- package/dist/system-prompt.d.ts.map +1 -0
- package/dist/system-prompt.js +478 -0
- package/dist/system-prompt.js.map +1 -0
- package/dist/system-prompt.test.d.ts +2 -0
- package/dist/system-prompt.test.d.ts.map +1 -0
- package/dist/system-prompt.test.js +87 -0
- package/dist/system-prompt.test.js.map +1 -0
- package/dist/tools/add-fades.d.ts +13 -0
- package/dist/tools/add-fades.d.ts.map +1 -0
- package/dist/tools/add-fades.js +88 -0
- package/dist/tools/add-fades.js.map +1 -0
- package/dist/tools/add-marker.d.ts +31 -0
- package/dist/tools/add-marker.d.ts.map +1 -0
- package/dist/tools/add-marker.js +56 -0
- package/dist/tools/add-marker.js.map +1 -0
- package/dist/tools/add-sfx-at-cuts.d.ts +24 -0
- package/dist/tools/add-sfx-at-cuts.d.ts.map +1 -0
- package/dist/tools/add-sfx-at-cuts.js +120 -0
- package/dist/tools/add-sfx-at-cuts.js.map +1 -0
- package/dist/tools/add-track.d.ts +13 -0
- package/dist/tools/add-track.d.ts.map +1 -0
- package/dist/tools/add-track.js +26 -0
- package/dist/tools/add-track.js.map +1 -0
- package/dist/tools/analyze-hook.d.ts +28 -0
- package/dist/tools/analyze-hook.d.ts.map +1 -0
- package/dist/tools/analyze-hook.js +126 -0
- package/dist/tools/analyze-hook.js.map +1 -0
- package/dist/tools/append-clip.d.ts +10 -0
- package/dist/tools/append-clip.d.ts.map +1 -0
- package/dist/tools/append-clip.js +27 -0
- package/dist/tools/append-clip.js.map +1 -0
- package/dist/tools/apply-lut.d.ts +11 -0
- package/dist/tools/apply-lut.d.ts.map +1 -0
- package/dist/tools/apply-lut.js +33 -0
- package/dist/tools/apply-lut.js.map +1 -0
- package/dist/tools/burn-subtitles.d.ts +28 -0
- package/dist/tools/burn-subtitles.d.ts.map +1 -0
- package/dist/tools/burn-subtitles.js +87 -0
- package/dist/tools/burn-subtitles.js.map +1 -0
- package/dist/tools/clean-audio.d.ts +18 -0
- package/dist/tools/clean-audio.d.ts.map +1 -0
- package/dist/tools/clean-audio.js +54 -0
- package/dist/tools/clean-audio.js.map +1 -0
- package/dist/tools/clone-timeline.d.ts +9 -0
- package/dist/tools/clone-timeline.d.ts.map +1 -0
- package/dist/tools/clone-timeline.js +28 -0
- package/dist/tools/clone-timeline.js.map +1 -0
- package/dist/tools/cluster-takes.d.ts +11 -0
- package/dist/tools/cluster-takes.d.ts.map +1 -0
- package/dist/tools/cluster-takes.js +71 -0
- package/dist/tools/cluster-takes.js.map +1 -0
- package/dist/tools/color-match.d.ts +16 -0
- package/dist/tools/color-match.d.ts.map +1 -0
- package/dist/tools/color-match.js +55 -0
- package/dist/tools/color-match.js.map +1 -0
- package/dist/tools/compose-layered.d.ts +47 -0
- package/dist/tools/compose-layered.d.ts.map +1 -0
- package/dist/tools/compose-layered.js +103 -0
- package/dist/tools/compose-layered.js.map +1 -0
- package/dist/tools/compose-thumbnail.d.ts +35 -0
- package/dist/tools/compose-thumbnail.d.ts.map +1 -0
- package/dist/tools/compose-thumbnail.js +130 -0
- package/dist/tools/compose-thumbnail.js.map +1 -0
- package/dist/tools/concat-videos.d.ts +18 -0
- package/dist/tools/concat-videos.d.ts.map +1 -0
- package/dist/tools/concat-videos.js +79 -0
- package/dist/tools/concat-videos.js.map +1 -0
- package/dist/tools/copy-grade.d.ts +10 -0
- package/dist/tools/copy-grade.d.ts.map +1 -0
- package/dist/tools/copy-grade.js +29 -0
- package/dist/tools/copy-grade.js.map +1 -0
- package/dist/tools/create-timeline.d.ts +12 -0
- package/dist/tools/create-timeline.d.ts.map +1 -0
- package/dist/tools/create-timeline.js +35 -0
- package/dist/tools/create-timeline.js.map +1 -0
- package/dist/tools/crossfade-videos.d.ts +49 -0
- package/dist/tools/crossfade-videos.d.ts.map +1 -0
- package/dist/tools/crossfade-videos.js +121 -0
- package/dist/tools/crossfade-videos.js.map +1 -0
- package/dist/tools/cut-at.d.ts +10 -0
- package/dist/tools/cut-at.d.ts.map +1 -0
- package/dist/tools/cut-at.js +24 -0
- package/dist/tools/cut-at.js.map +1 -0
- package/dist/tools/cut-filler-words.d.ts +27 -0
- package/dist/tools/cut-filler-words.d.ts.map +1 -0
- package/dist/tools/cut-filler-words.js +165 -0
- package/dist/tools/cut-filler-words.js.map +1 -0
- package/dist/tools/detect-silence.d.ts +13 -0
- package/dist/tools/detect-silence.d.ts.map +1 -0
- package/dist/tools/detect-silence.js +98 -0
- package/dist/tools/detect-silence.js.map +1 -0
- package/dist/tools/detect-speaker-changes.d.ts +9 -0
- package/dist/tools/detect-speaker-changes.d.ts.map +1 -0
- package/dist/tools/detect-speaker-changes.js +42 -0
- package/dist/tools/detect-speaker-changes.js.map +1 -0
- package/dist/tools/dry-run.d.ts +23 -0
- package/dist/tools/dry-run.d.ts.map +1 -0
- package/dist/tools/dry-run.js +66 -0
- package/dist/tools/dry-run.js.map +1 -0
- package/dist/tools/dry-run.test.d.ts +2 -0
- package/dist/tools/dry-run.test.d.ts.map +1 -0
- package/dist/tools/dry-run.test.js +66 -0
- package/dist/tools/dry-run.test.js.map +1 -0
- package/dist/tools/duck-audio.d.ts +16 -0
- package/dist/tools/duck-audio.d.ts.map +1 -0
- package/dist/tools/duck-audio.js +73 -0
- package/dist/tools/duck-audio.js.map +1 -0
- package/dist/tools/extract-audio.d.ts +10 -0
- package/dist/tools/extract-audio.d.ts.map +1 -0
- package/dist/tools/extract-audio.js +30 -0
- package/dist/tools/extract-audio.js.map +1 -0
- package/dist/tools/extract-frame.d.ts +12 -0
- package/dist/tools/extract-frame.d.ts.map +1 -0
- package/dist/tools/extract-frame.js +63 -0
- package/dist/tools/extract-frame.js.map +1 -0
- package/dist/tools/generate-gif.d.ts +13 -0
- package/dist/tools/generate-gif.d.ts.map +1 -0
- package/dist/tools/generate-gif.js +94 -0
- package/dist/tools/generate-gif.js.map +1 -0
- package/dist/tools/get-markers.d.ts +13 -0
- package/dist/tools/get-markers.d.ts.map +1 -0
- package/dist/tools/get-markers.js +71 -0
- package/dist/tools/get-markers.js.map +1 -0
- package/dist/tools/get-timeline.d.ts +9 -0
- package/dist/tools/get-timeline.d.ts.map +1 -0
- package/dist/tools/get-timeline.js +43 -0
- package/dist/tools/get-timeline.js.map +1 -0
- package/dist/tools/grade-skin-tones.d.ts +31 -0
- package/dist/tools/grade-skin-tones.d.ts.map +1 -0
- package/dist/tools/grade-skin-tones.js +92 -0
- package/dist/tools/grade-skin-tones.js.map +1 -0
- package/dist/tools/host-info.d.ts +7 -0
- package/dist/tools/host-info.d.ts.map +1 -0
- package/dist/tools/host-info.js +33 -0
- package/dist/tools/host-info.js.map +1 -0
- package/dist/tools/host-tools.test.d.ts +2 -0
- package/dist/tools/host-tools.test.d.ts.map +1 -0
- package/dist/tools/host-tools.test.js +83 -0
- package/dist/tools/host-tools.test.js.map +1 -0
- package/dist/tools/import-edl.d.ts +9 -0
- package/dist/tools/import-edl.d.ts.map +1 -0
- package/dist/tools/import-edl.js +25 -0
- package/dist/tools/import-edl.js.map +1 -0
- package/dist/tools/import-subtitles.d.ts +9 -0
- package/dist/tools/import-subtitles.d.ts.map +1 -0
- package/dist/tools/import-subtitles.js +31 -0
- package/dist/tools/import-subtitles.js.map +1 -0
- package/dist/tools/import-to-media-pool.d.ts +10 -0
- package/dist/tools/import-to-media-pool.d.ts.map +1 -0
- package/dist/tools/import-to-media-pool.js +27 -0
- package/dist/tools/import-to-media-pool.js.map +1 -0
- package/dist/tools/index.d.ts +94 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +242 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/index.test.d.ts +2 -0
- package/dist/tools/index.test.d.ts.map +1 -0
- package/dist/tools/index.test.js +128 -0
- package/dist/tools/index.test.js.map +1 -0
- package/dist/tools/insert-broll.d.ts +13 -0
- package/dist/tools/insert-broll.d.ts.map +1 -0
- package/dist/tools/insert-broll.js +56 -0
- package/dist/tools/insert-broll.js.map +1 -0
- package/dist/tools/ken-burns.d.ts +26 -0
- package/dist/tools/ken-burns.d.ts.map +1 -0
- package/dist/tools/ken-burns.js +125 -0
- package/dist/tools/ken-burns.js.map +1 -0
- package/dist/tools/list-render-presets.d.ts +7 -0
- package/dist/tools/list-render-presets.d.ts.map +1 -0
- package/dist/tools/list-render-presets.js +30 -0
- package/dist/tools/list-render-presets.js.map +1 -0
- package/dist/tools/match-clip-color.d.ts +29 -0
- package/dist/tools/match-clip-color.d.ts.map +1 -0
- package/dist/tools/match-clip-color.js +99 -0
- package/dist/tools/match-clip-color.js.map +1 -0
- package/dist/tools/measure-loudness.d.ts +8 -0
- package/dist/tools/measure-loudness.d.ts.map +1 -0
- package/dist/tools/measure-loudness.js +40 -0
- package/dist/tools/measure-loudness.js.map +1 -0
- package/dist/tools/mix-audio.d.ts +46 -0
- package/dist/tools/mix-audio.d.ts.map +1 -0
- package/dist/tools/mix-audio.js +101 -0
- package/dist/tools/mix-audio.js.map +1 -0
- package/dist/tools/multicam-sync.d.ts +14 -0
- package/dist/tools/multicam-sync.d.ts.map +1 -0
- package/dist/tools/multicam-sync.js +75 -0
- package/dist/tools/multicam-sync.js.map +1 -0
- package/dist/tools/new-tools.test.d.ts +2 -0
- package/dist/tools/new-tools.test.d.ts.map +1 -0
- package/dist/tools/new-tools.test.js +511 -0
- package/dist/tools/new-tools.test.js.map +1 -0
- package/dist/tools/normalize-loudness.d.ts +21 -0
- package/dist/tools/normalize-loudness.d.ts.map +1 -0
- package/dist/tools/normalize-loudness.js +94 -0
- package/dist/tools/normalize-loudness.js.map +1 -0
- package/dist/tools/open-page.d.ts +17 -0
- package/dist/tools/open-page.d.ts.map +1 -0
- package/dist/tools/open-page.js +27 -0
- package/dist/tools/open-page.js.map +1 -0
- package/dist/tools/overlay-watermark.d.ts +28 -0
- package/dist/tools/overlay-watermark.d.ts.map +1 -0
- package/dist/tools/overlay-watermark.js +98 -0
- package/dist/tools/overlay-watermark.js.map +1 -0
- package/dist/tools/pick-best-takes.d.ts +20 -0
- package/dist/tools/pick-best-takes.d.ts.map +1 -0
- package/dist/tools/pick-best-takes.js +147 -0
- package/dist/tools/pick-best-takes.js.map +1 -0
- package/dist/tools/post-tools.test.d.ts +2 -0
- package/dist/tools/post-tools.test.d.ts.map +1 -0
- package/dist/tools/post-tools.test.js +83 -0
- package/dist/tools/post-tools.test.js.map +1 -0
- package/dist/tools/pre-render-check.d.ts +23 -0
- package/dist/tools/pre-render-check.d.ts.map +1 -0
- package/dist/tools/pre-render-check.js +134 -0
- package/dist/tools/pre-render-check.js.map +1 -0
- package/dist/tools/probe-media.d.ts +8 -0
- package/dist/tools/probe-media.d.ts.map +1 -0
- package/dist/tools/probe-media.js +32 -0
- package/dist/tools/probe-media.js.map +1 -0
- package/dist/tools/punch-in.d.ts +30 -0
- package/dist/tools/punch-in.d.ts.map +1 -0
- package/dist/tools/punch-in.js +130 -0
- package/dist/tools/punch-in.js.map +1 -0
- package/dist/tools/read-skill.d.ts +9 -0
- package/dist/tools/read-skill.d.ts.map +1 -0
- package/dist/tools/read-skill.js +24 -0
- package/dist/tools/read-skill.js.map +1 -0
- package/dist/tools/read-transcript.d.ts +14 -0
- package/dist/tools/read-transcript.d.ts.map +1 -0
- package/dist/tools/read-transcript.js +85 -0
- package/dist/tools/read-transcript.js.map +1 -0
- package/dist/tools/read-transcript.test.d.ts +2 -0
- package/dist/tools/read-transcript.test.d.ts.map +1 -0
- package/dist/tools/read-transcript.test.js +136 -0
- package/dist/tools/read-transcript.test.js.map +1 -0
- package/dist/tools/reformat-timeline.d.ts +25 -0
- package/dist/tools/reformat-timeline.d.ts.map +1 -0
- package/dist/tools/reformat-timeline.js +60 -0
- package/dist/tools/reformat-timeline.js.map +1 -0
- package/dist/tools/render.d.ts +10 -0
- package/dist/tools/render.d.ts.map +1 -0
- package/dist/tools/render.js +26 -0
- package/dist/tools/render.js.map +1 -0
- package/dist/tools/reorder-timeline.d.ts +12 -0
- package/dist/tools/reorder-timeline.d.ts.map +1 -0
- package/dist/tools/reorder-timeline.js +65 -0
- package/dist/tools/reorder-timeline.js.map +1 -0
- package/dist/tools/replace-clip.d.ts +10 -0
- package/dist/tools/replace-clip.d.ts.map +1 -0
- package/dist/tools/replace-clip.js +28 -0
- package/dist/tools/replace-clip.js.map +1 -0
- package/dist/tools/review-edit.d.ts +23 -0
- package/dist/tools/review-edit.d.ts.map +1 -0
- package/dist/tools/review-edit.js +47 -0
- package/dist/tools/review-edit.js.map +1 -0
- package/dist/tools/ripple-delete.d.ts +11 -0
- package/dist/tools/ripple-delete.d.ts.map +1 -0
- package/dist/tools/ripple-delete.js +27 -0
- package/dist/tools/ripple-delete.js.map +1 -0
- package/dist/tools/save-project.d.ts +7 -0
- package/dist/tools/save-project.d.ts.map +1 -0
- package/dist/tools/save-project.js +22 -0
- package/dist/tools/save-project.js.map +1 -0
- package/dist/tools/score-shot.d.ts +18 -0
- package/dist/tools/score-shot.d.ts.map +1 -0
- package/dist/tools/score-shot.js +127 -0
- package/dist/tools/score-shot.js.map +1 -0
- package/dist/tools/set-clip-speed.d.ts +10 -0
- package/dist/tools/set-clip-speed.d.ts.map +1 -0
- package/dist/tools/set-clip-speed.js +28 -0
- package/dist/tools/set-clip-speed.js.map +1 -0
- package/dist/tools/set-clip-volume.d.ts +10 -0
- package/dist/tools/set-clip-volume.d.ts.map +1 -0
- package/dist/tools/set-clip-volume.js +33 -0
- package/dist/tools/set-clip-volume.js.map +1 -0
- package/dist/tools/set-primary-correction.d.ts +14 -0
- package/dist/tools/set-primary-correction.d.ts.map +1 -0
- package/dist/tools/set-primary-correction.js +45 -0
- package/dist/tools/set-primary-correction.js.map +1 -0
- package/dist/tools/smart-reframe.d.ts +22 -0
- package/dist/tools/smart-reframe.d.ts.map +1 -0
- package/dist/tools/smart-reframe.js +39 -0
- package/dist/tools/smart-reframe.js.map +1 -0
- package/dist/tools/speed-ramp.d.ts +14 -0
- package/dist/tools/speed-ramp.d.ts.map +1 -0
- package/dist/tools/speed-ramp.js +71 -0
- package/dist/tools/speed-ramp.js.map +1 -0
- package/dist/tools/stabilize-video.d.ts +12 -0
- package/dist/tools/stabilize-video.d.ts.map +1 -0
- package/dist/tools/stabilize-video.js +63 -0
- package/dist/tools/stabilize-video.js.map +1 -0
- package/dist/tools/transcribe.d.ts +29 -0
- package/dist/tools/transcribe.d.ts.map +1 -0
- package/dist/tools/transcribe.js +116 -0
- package/dist/tools/transcribe.js.map +1 -0
- package/dist/tools/transition-videos.d.ts +29 -0
- package/dist/tools/transition-videos.d.ts.map +1 -0
- package/dist/tools/transition-videos.js +129 -0
- package/dist/tools/transition-videos.js.map +1 -0
- package/dist/tools/write-ass.d.ts +34 -0
- package/dist/tools/write-ass.d.ts.map +1 -0
- package/dist/tools/write-ass.js +101 -0
- package/dist/tools/write-ass.js.map +1 -0
- package/dist/tools/write-edl.d.ts +24 -0
- package/dist/tools/write-edl.d.ts.map +1 -0
- package/dist/tools/write-edl.js +59 -0
- package/dist/tools/write-edl.js.map +1 -0
- package/dist/tools/write-fcpxml.d.ts +20 -0
- package/dist/tools/write-fcpxml.d.ts.map +1 -0
- package/dist/tools/write-fcpxml.js +52 -0
- package/dist/tools/write-fcpxml.js.map +1 -0
- package/dist/tools/write-keyword-captions.d.ts +36 -0
- package/dist/tools/write-keyword-captions.d.ts.map +1 -0
- package/dist/tools/write-keyword-captions.js +183 -0
- package/dist/tools/write-keyword-captions.js.map +1 -0
- package/dist/tools/write-lower-third.d.ts +34 -0
- package/dist/tools/write-lower-third.d.ts.map +1 -0
- package/dist/tools/write-lower-third.js +52 -0
- package/dist/tools/write-lower-third.js.map +1 -0
- package/dist/tools/write-srt.d.ts +20 -0
- package/dist/tools/write-srt.d.ts.map +1 -0
- package/dist/tools/write-srt.js +72 -0
- package/dist/tools/write-srt.js.map +1 -0
- package/dist/tools/write-title-card.d.ts +25 -0
- package/dist/tools/write-title-card.d.ts.map +1 -0
- package/dist/tools/write-title-card.js +57 -0
- package/dist/tools/write-title-card.js.map +1 -0
- package/dist/types.d.ts +83 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/dist/ui/App.d.ts +44 -0
- package/dist/ui/App.d.ts.map +1 -0
- package/dist/ui/App.js +454 -0
- package/dist/ui/App.js.map +1 -0
- package/dist/ui/components/Banner.d.ts +13 -0
- package/dist/ui/components/Banner.d.ts.map +1 -0
- package/dist/ui/components/Banner.js +59 -0
- package/dist/ui/components/Banner.js.map +1 -0
- package/dist/ui/components/Footer.d.ts +19 -0
- package/dist/ui/components/Footer.d.ts.map +1 -0
- package/dist/ui/components/Footer.js +20 -0
- package/dist/ui/components/Footer.js.map +1 -0
- package/dist/ui/components/Header.d.ts +16 -0
- package/dist/ui/components/Header.d.ts.map +1 -0
- package/dist/ui/components/Header.js +12 -0
- package/dist/ui/components/Header.js.map +1 -0
- package/dist/ui/components/InputBox.d.ts +21 -0
- package/dist/ui/components/InputBox.d.ts.map +1 -0
- package/dist/ui/components/InputBox.js +81 -0
- package/dist/ui/components/InputBox.js.map +1 -0
- package/dist/ui/components/Message.d.ts +14 -0
- package/dist/ui/components/Message.d.ts.map +1 -0
- package/dist/ui/components/Message.js +24 -0
- package/dist/ui/components/Message.js.map +1 -0
- package/dist/ui/components/SlashMenu.d.ts +19 -0
- package/dist/ui/components/SlashMenu.d.ts.map +1 -0
- package/dist/ui/components/SlashMenu.js +33 -0
- package/dist/ui/components/SlashMenu.js.map +1 -0
- package/dist/ui/components/SlashMenu.test.d.ts +2 -0
- package/dist/ui/components/SlashMenu.test.d.ts.map +1 -0
- package/dist/ui/components/SlashMenu.test.js +23 -0
- package/dist/ui/components/SlashMenu.test.js.map +1 -0
- package/dist/ui/components/Spinner.d.ts +6 -0
- package/dist/ui/components/Spinner.d.ts.map +1 -0
- package/dist/ui/components/Spinner.js +16 -0
- package/dist/ui/components/Spinner.js.map +1 -0
- package/dist/ui/components/ToolCallLine.d.ts +16 -0
- package/dist/ui/components/ToolCallLine.d.ts.map +1 -0
- package/dist/ui/components/ToolCallLine.js +35 -0
- package/dist/ui/components/ToolCallLine.js.map +1 -0
- package/dist/ui/render.d.ts +9 -0
- package/dist/ui/render.d.ts.map +1 -0
- package/dist/ui/render.js +56 -0
- package/dist/ui/render.js.map +1 -0
- package/dist/ui/spinner-frames.d.ts +3 -0
- package/dist/ui/spinner-frames.d.ts.map +1 -0
- package/dist/ui/spinner-frames.js +16 -0
- package/dist/ui/spinner-frames.js.map +1 -0
- package/dist/ui/theme.d.ts +27 -0
- package/dist/ui/theme.d.ts.map +1 -0
- package/dist/ui/theme.js +26 -0
- package/dist/ui/theme.js.map +1 -0
- package/package.json +50 -0
|
@@ -0,0 +1,660 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Embedded Python source for the Resolve bridge. Written to a temp file at
|
|
3
|
+
* first launch and spawned with python3.
|
|
4
|
+
*
|
|
5
|
+
* Protocol: one JSON object per stdin line (request), one JSON object per
|
|
6
|
+
* stdout line (response). All Resolve API access is wrapped in try/except so
|
|
7
|
+
* a single failed call cannot kill the bridge.
|
|
8
|
+
*
|
|
9
|
+
* Request: {"id": "1", "method": "get_timeline", "params": {}}
|
|
10
|
+
* Response: {"id": "1", "ok": true, "result": {...}}
|
|
11
|
+
* {"id": "1", "ok": false, "error": "..."}
|
|
12
|
+
*
|
|
13
|
+
* The bridge keeps the resolve / project / timeline references fresh by
|
|
14
|
+
* re-fetching them per call (cheap, and handles the user switching projects).
|
|
15
|
+
*/
|
|
16
|
+
export const BRIDGE_PY = String.raw `#!/usr/bin/env python3
|
|
17
|
+
import json
|
|
18
|
+
import os
|
|
19
|
+
import sys
|
|
20
|
+
import traceback
|
|
21
|
+
|
|
22
|
+
# Resolve loads its scripting module from a non-standard path. The TS wrapper
|
|
23
|
+
# guarantees PYTHONPATH already contains the right Modules dir, but we double-
|
|
24
|
+
# check here so the error is clear if not.
|
|
25
|
+
try:
|
|
26
|
+
import DaVinciResolveScript as dvr # type: ignore
|
|
27
|
+
except ModuleNotFoundError as e:
|
|
28
|
+
sys.stdout.write(json.dumps({
|
|
29
|
+
"id": "_bootstrap",
|
|
30
|
+
"ok": False,
|
|
31
|
+
"error": "DaVinciResolveScript not importable. Set RESOLVE_SCRIPT_API and PYTHONPATH. " + str(e),
|
|
32
|
+
}) + "\n")
|
|
33
|
+
sys.stdout.flush()
|
|
34
|
+
sys.exit(2)
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
def get_resolve():
|
|
38
|
+
r = dvr.scriptapp("Resolve")
|
|
39
|
+
if r is None:
|
|
40
|
+
raise RuntimeError("Could not connect to Resolve. Is the app running and is external scripting enabled in Preferences?")
|
|
41
|
+
return r
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
def get_project():
|
|
45
|
+
r = get_resolve()
|
|
46
|
+
pm = r.GetProjectManager()
|
|
47
|
+
p = pm.GetCurrentProject()
|
|
48
|
+
if p is None:
|
|
49
|
+
raise RuntimeError("No project open in Resolve.")
|
|
50
|
+
return p
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
def get_timeline_obj():
|
|
54
|
+
p = get_project()
|
|
55
|
+
t = p.GetCurrentTimeline()
|
|
56
|
+
if t is None:
|
|
57
|
+
raise RuntimeError("No timeline open in Resolve.")
|
|
58
|
+
return t
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
# ── Helpers ─────────────────────────────────────────────────
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
def _find_timeline_item(clip_id):
|
|
65
|
+
t = get_timeline_obj()
|
|
66
|
+
cid = str(clip_id)
|
|
67
|
+
for kind in ("video", "audio"):
|
|
68
|
+
try:
|
|
69
|
+
count = int(t.GetTrackCount(kind))
|
|
70
|
+
except Exception:
|
|
71
|
+
count = 0
|
|
72
|
+
for ti in range(1, count + 1):
|
|
73
|
+
for item in (t.GetItemListInTrack(kind, ti) or []):
|
|
74
|
+
try:
|
|
75
|
+
iid = str(item.GetUniqueId()) if hasattr(item, "GetUniqueId") else item.GetName()
|
|
76
|
+
except Exception:
|
|
77
|
+
iid = None
|
|
78
|
+
if iid == cid:
|
|
79
|
+
return item
|
|
80
|
+
raise RuntimeError(f"clip not found on timeline: {clip_id}")
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
# ── Method implementations ──────────────────────────────────
|
|
84
|
+
|
|
85
|
+
def m_ping(_params):
|
|
86
|
+
r = get_resolve()
|
|
87
|
+
return {"pong": True, "product": r.GetProductName(), "version": r.GetVersionString()}
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
def m_get_timeline(_params):
|
|
91
|
+
t = get_timeline_obj()
|
|
92
|
+
fr = float(t.GetSetting("timelineFrameRate") or 24.0)
|
|
93
|
+
start_frame = int(t.GetStartFrame())
|
|
94
|
+
end_frame = int(t.GetEndFrame())
|
|
95
|
+
|
|
96
|
+
clips = []
|
|
97
|
+
for kind in ("video", "audio"):
|
|
98
|
+
try:
|
|
99
|
+
count = int(t.GetTrackCount(kind))
|
|
100
|
+
except Exception:
|
|
101
|
+
count = 0
|
|
102
|
+
for ti in range(1, count + 1):
|
|
103
|
+
items = t.GetItemListInTrack(kind, ti) or []
|
|
104
|
+
for item in items:
|
|
105
|
+
try:
|
|
106
|
+
clips.append({
|
|
107
|
+
"id": str(item.GetUniqueId()) if hasattr(item, "GetUniqueId") else item.GetName(),
|
|
108
|
+
"track": ti,
|
|
109
|
+
"trackKind": kind,
|
|
110
|
+
"startFrame": int(item.GetStart()) - start_frame,
|
|
111
|
+
"endFrame": int(item.GetEnd()) - start_frame,
|
|
112
|
+
"name": item.GetName(),
|
|
113
|
+
})
|
|
114
|
+
except Exception:
|
|
115
|
+
# Skip clips we can't introspect (compound/timeline items)
|
|
116
|
+
pass
|
|
117
|
+
|
|
118
|
+
markers_dict = t.GetMarkers() or {}
|
|
119
|
+
markers = []
|
|
120
|
+
for frame_id, info in markers_dict.items():
|
|
121
|
+
markers.append({
|
|
122
|
+
"frame": int(frame_id),
|
|
123
|
+
"note": info.get("note", "") or info.get("name", ""),
|
|
124
|
+
"color": info.get("color"),
|
|
125
|
+
"durationFrames": int(info.get("duration", 1)),
|
|
126
|
+
})
|
|
127
|
+
|
|
128
|
+
return {
|
|
129
|
+
"name": t.GetName(),
|
|
130
|
+
"frameRate": fr,
|
|
131
|
+
"durationFrames": end_frame - start_frame,
|
|
132
|
+
"clips": clips,
|
|
133
|
+
"markers": markers,
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
def m_add_marker(params):
|
|
138
|
+
t = get_timeline_obj()
|
|
139
|
+
frame = int(params["frame"])
|
|
140
|
+
note = str(params.get("note", ""))
|
|
141
|
+
color = str(params.get("color", "Blue")).capitalize()
|
|
142
|
+
duration = int(params.get("durationFrames", 1) or 1)
|
|
143
|
+
# Resolve marker color names: Blue, Cyan, Green, Yellow, Red, Pink, Purple,
|
|
144
|
+
# Fuchsia, Rose, Lavender, Sky, Mint, Lemon, Sand, Cocoa, Cream
|
|
145
|
+
ok = t.AddMarker(frame, color, note[:60], note, duration, "")
|
|
146
|
+
if not ok:
|
|
147
|
+
raise RuntimeError("AddMarker returned False (frame may already have a marker, or be out of range).")
|
|
148
|
+
return None
|
|
149
|
+
|
|
150
|
+
|
|
151
|
+
def m_append_clip(params):
|
|
152
|
+
project = get_project()
|
|
153
|
+
media_pool = project.GetMediaPool()
|
|
154
|
+
media_path = params["mediaPath"]
|
|
155
|
+
track = int(params.get("track", 1))
|
|
156
|
+
|
|
157
|
+
# Import the file into the media pool first.
|
|
158
|
+
media_storage = get_resolve().GetMediaStorage()
|
|
159
|
+
items = media_storage.AddItemListToMediaPool([media_path]) or []
|
|
160
|
+
if not items:
|
|
161
|
+
raise RuntimeError(f"Failed to import {media_path} into the media pool.")
|
|
162
|
+
|
|
163
|
+
# AppendToTimeline appends to the end of whatever the current timeline is.
|
|
164
|
+
# Track index is honoured for audio-only / video-only items; for AV items
|
|
165
|
+
# the audio component goes to A1 by default.
|
|
166
|
+
appended = media_pool.AppendToTimeline(items) or []
|
|
167
|
+
if not appended:
|
|
168
|
+
raise RuntimeError("AppendToTimeline returned no items.")
|
|
169
|
+
|
|
170
|
+
item = appended[0]
|
|
171
|
+
t = get_timeline_obj()
|
|
172
|
+
start_frame = int(t.GetStartFrame())
|
|
173
|
+
return {
|
|
174
|
+
"id": str(item.GetUniqueId()) if hasattr(item, "GetUniqueId") else item.GetName(),
|
|
175
|
+
"track": track,
|
|
176
|
+
"trackKind": "video",
|
|
177
|
+
"startFrame": int(item.GetStart()) - start_frame,
|
|
178
|
+
"endFrame": int(item.GetEnd()) - start_frame,
|
|
179
|
+
"name": item.GetName(),
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
|
|
183
|
+
def m_import_timeline(params):
|
|
184
|
+
project = get_project()
|
|
185
|
+
media_pool = project.GetMediaPool()
|
|
186
|
+
file_path = params["filePath"]
|
|
187
|
+
timeline = media_pool.ImportTimelineFromFile(file_path, {})
|
|
188
|
+
if timeline is None:
|
|
189
|
+
raise RuntimeError(f"ImportTimelineFromFile returned None for {file_path}.")
|
|
190
|
+
return {"name": timeline.GetName()}
|
|
191
|
+
|
|
192
|
+
|
|
193
|
+
def m_render(params):
|
|
194
|
+
project = get_project()
|
|
195
|
+
preset = params["preset"]
|
|
196
|
+
output_path = params["output"]
|
|
197
|
+
|
|
198
|
+
if not project.LoadRenderPreset(preset):
|
|
199
|
+
# Try as a built-in preset key. List available so the agent can recover.
|
|
200
|
+
available = project.GetRenderPresetList() or []
|
|
201
|
+
raise RuntimeError(f"Render preset not found: {preset}. Available: {available[:10]}")
|
|
202
|
+
|
|
203
|
+
out_dir = os.path.dirname(output_path) or "."
|
|
204
|
+
out_file = os.path.basename(output_path)
|
|
205
|
+
project.SetRenderSettings({
|
|
206
|
+
"TargetDir": out_dir,
|
|
207
|
+
"CustomName": os.path.splitext(out_file)[0],
|
|
208
|
+
})
|
|
209
|
+
|
|
210
|
+
job_id = project.AddRenderJob()
|
|
211
|
+
if not job_id:
|
|
212
|
+
raise RuntimeError("AddRenderJob failed.")
|
|
213
|
+
project.StartRendering([job_id], False)
|
|
214
|
+
|
|
215
|
+
# Block until done.
|
|
216
|
+
import time
|
|
217
|
+
while project.IsRenderingInProgress():
|
|
218
|
+
time.sleep(0.5)
|
|
219
|
+
|
|
220
|
+
return {"jobId": job_id, "output": output_path}
|
|
221
|
+
|
|
222
|
+
|
|
223
|
+
def m_get_markers(_params):
|
|
224
|
+
t = get_timeline_obj()
|
|
225
|
+
markers_dict = t.GetMarkers() or {}
|
|
226
|
+
out = []
|
|
227
|
+
for frame_id, info in markers_dict.items():
|
|
228
|
+
out.append({
|
|
229
|
+
"frame": int(frame_id),
|
|
230
|
+
"note": info.get("note", "") or info.get("name", ""),
|
|
231
|
+
"color": info.get("color"),
|
|
232
|
+
"durationFrames": int(info.get("duration", 1)),
|
|
233
|
+
})
|
|
234
|
+
return out
|
|
235
|
+
|
|
236
|
+
|
|
237
|
+
def m_create_timeline(params):
|
|
238
|
+
project = get_project()
|
|
239
|
+
media_pool = project.GetMediaPool()
|
|
240
|
+
name = str(params["name"])
|
|
241
|
+
fps = params.get("fps")
|
|
242
|
+
width = params.get("width")
|
|
243
|
+
height = params.get("height")
|
|
244
|
+
|
|
245
|
+
# Project-level frame rate must be set BEFORE creating the timeline; once a
|
|
246
|
+
# project has timelines, the frame rate becomes locked. We try, and if it
|
|
247
|
+
# fails because timelines exist, the new timeline will inherit project fps.
|
|
248
|
+
if fps is not None:
|
|
249
|
+
try:
|
|
250
|
+
project.SetSetting("timelineFrameRate", str(float(fps)))
|
|
251
|
+
except Exception:
|
|
252
|
+
pass
|
|
253
|
+
|
|
254
|
+
timeline = media_pool.CreateEmptyTimeline(name)
|
|
255
|
+
if timeline is None:
|
|
256
|
+
raise RuntimeError("CreateEmptyTimeline returned None.")
|
|
257
|
+
|
|
258
|
+
if width is not None:
|
|
259
|
+
try:
|
|
260
|
+
timeline.SetSetting("useCustomSettings", "1")
|
|
261
|
+
timeline.SetSetting("timelineResolutionWidth", str(int(width)))
|
|
262
|
+
except Exception:
|
|
263
|
+
pass
|
|
264
|
+
if height is not None:
|
|
265
|
+
try:
|
|
266
|
+
timeline.SetSetting("timelineResolutionHeight", str(int(height)))
|
|
267
|
+
except Exception:
|
|
268
|
+
pass
|
|
269
|
+
|
|
270
|
+
return {"name": timeline.GetName()}
|
|
271
|
+
|
|
272
|
+
|
|
273
|
+
def m_import_to_media_pool(params):
|
|
274
|
+
project = get_project()
|
|
275
|
+
media_pool = project.GetMediaPool()
|
|
276
|
+
paths = list(params.get("paths") or [])
|
|
277
|
+
bin_name = params.get("bin")
|
|
278
|
+
|
|
279
|
+
if bin_name:
|
|
280
|
+
# Walk top-level bins for a name match; create if absent.
|
|
281
|
+
root = media_pool.GetRootFolder()
|
|
282
|
+
target = None
|
|
283
|
+
for sub in root.GetSubFolderList() or []:
|
|
284
|
+
if sub.GetName() == bin_name:
|
|
285
|
+
target = sub
|
|
286
|
+
break
|
|
287
|
+
if target is None:
|
|
288
|
+
target = media_pool.AddSubFolder(root, bin_name)
|
|
289
|
+
if target is not None:
|
|
290
|
+
media_pool.SetCurrentFolder(target)
|
|
291
|
+
|
|
292
|
+
media_storage = get_resolve().GetMediaStorage()
|
|
293
|
+
items = media_storage.AddItemListToMediaPool(paths) or []
|
|
294
|
+
return {"imported": len(items)}
|
|
295
|
+
|
|
296
|
+
|
|
297
|
+
def m_open_page(params):
|
|
298
|
+
r = get_resolve()
|
|
299
|
+
name = str(params["name"]).lower()
|
|
300
|
+
valid = {"media", "cut", "edit", "fusion", "color", "fairlight", "deliver"}
|
|
301
|
+
if name not in valid:
|
|
302
|
+
raise RuntimeError(f"unknown page: {name}; valid: {sorted(valid)}")
|
|
303
|
+
ok = r.OpenPage(name)
|
|
304
|
+
if not ok:
|
|
305
|
+
raise RuntimeError(f"OpenPage('{name}') returned False.")
|
|
306
|
+
return None
|
|
307
|
+
|
|
308
|
+
|
|
309
|
+
def m_set_clip_speed(params):
|
|
310
|
+
clip_id = str(params["clipId"])
|
|
311
|
+
speed = float(params["speed"])
|
|
312
|
+
if speed <= 0:
|
|
313
|
+
raise RuntimeError("speed must be > 0")
|
|
314
|
+
found = _find_timeline_item(clip_id)
|
|
315
|
+
|
|
316
|
+
last_err = None
|
|
317
|
+
# Try several APIs; Resolve versions differ.
|
|
318
|
+
for setter in (
|
|
319
|
+
lambda i: i.SetClipProperty("Speed", str(speed * 100.0)),
|
|
320
|
+
lambda i: i.SetProperty("Speed", speed),
|
|
321
|
+
lambda i: i.SetClipProperty("Speed", speed),
|
|
322
|
+
):
|
|
323
|
+
try:
|
|
324
|
+
ok = setter(found)
|
|
325
|
+
if ok:
|
|
326
|
+
return {"clipId": clip_id, "speed": speed}
|
|
327
|
+
except Exception as e:
|
|
328
|
+
last_err = e
|
|
329
|
+
raise RuntimeError(
|
|
330
|
+
f"Resolve refused all clip-speed setters for this version. Last error: {last_err}. "
|
|
331
|
+
f"fix: rebuild via FCPXML with explicit timeMap."
|
|
332
|
+
)
|
|
333
|
+
|
|
334
|
+
|
|
335
|
+
def m_apply_lut(params):
|
|
336
|
+
import os as _os
|
|
337
|
+
clip_id = str(params["clipId"])
|
|
338
|
+
lut_path = str(params["lutPath"])
|
|
339
|
+
node_index = int(params.get("nodeIndex", 1) or 1)
|
|
340
|
+
if not _os.path.exists(lut_path):
|
|
341
|
+
raise RuntimeError(f"LUT file not found: {lut_path}")
|
|
342
|
+
item = _find_timeline_item(clip_id)
|
|
343
|
+
if not hasattr(item, "SetLUT"):
|
|
344
|
+
raise RuntimeError("this Resolve version's TimelineItem has no SetLUT")
|
|
345
|
+
ok = item.SetLUT(node_index, lut_path)
|
|
346
|
+
if not ok:
|
|
347
|
+
raise RuntimeError(
|
|
348
|
+
f"SetLUT returned False (node {node_index}, lut {lut_path}). "
|
|
349
|
+
f"fix: ensure node {node_index} exists; node 1 always does."
|
|
350
|
+
)
|
|
351
|
+
return {"clipId": clip_id, "lutPath": lut_path, "nodeIndex": node_index}
|
|
352
|
+
|
|
353
|
+
|
|
354
|
+
def _fmt3(triple):
|
|
355
|
+
return "%g %g %g" % (float(triple[0]), float(triple[1]), float(triple[2]))
|
|
356
|
+
|
|
357
|
+
|
|
358
|
+
def m_set_primary_correction(params):
|
|
359
|
+
clip_id = str(params["clipId"])
|
|
360
|
+
node_index = int(params.get("nodeIndex", 1) or 1)
|
|
361
|
+
item = _find_timeline_item(clip_id)
|
|
362
|
+
if not hasattr(item, "SetCDL"):
|
|
363
|
+
raise RuntimeError("this Resolve version's TimelineItem has no SetCDL")
|
|
364
|
+
cdl = {"NodeIndex": node_index}
|
|
365
|
+
if params.get("slope") is not None:
|
|
366
|
+
cdl["Slope"] = _fmt3(params["slope"])
|
|
367
|
+
if params.get("offset") is not None:
|
|
368
|
+
cdl["Offset"] = _fmt3(params["offset"])
|
|
369
|
+
if params.get("power") is not None:
|
|
370
|
+
cdl["Power"] = _fmt3(params["power"])
|
|
371
|
+
if params.get("saturation") is not None:
|
|
372
|
+
cdl["Saturation"] = "%g" % float(params["saturation"])
|
|
373
|
+
ok = item.SetCDL(cdl)
|
|
374
|
+
if not ok:
|
|
375
|
+
raise RuntimeError(
|
|
376
|
+
f"SetCDL returned False for node {node_index}. "
|
|
377
|
+
f"fix: open the Color page (open_page('color')) and retry."
|
|
378
|
+
)
|
|
379
|
+
return {"clipId": clip_id, "nodeIndex": node_index}
|
|
380
|
+
|
|
381
|
+
|
|
382
|
+
def m_copy_grade(params):
|
|
383
|
+
source_id = str(params["sourceClipId"])
|
|
384
|
+
target_ids = [str(x) for x in (params.get("targetClipIds") or [])]
|
|
385
|
+
if not target_ids:
|
|
386
|
+
raise RuntimeError("targetClipIds must be a non-empty list")
|
|
387
|
+
src = _find_timeline_item(source_id)
|
|
388
|
+
targets = [_find_timeline_item(tid) for tid in target_ids]
|
|
389
|
+
if not hasattr(src, "CopyGrades"):
|
|
390
|
+
raise RuntimeError("this Resolve version's TimelineItem has no CopyGrades")
|
|
391
|
+
ok = src.CopyGrades(targets)
|
|
392
|
+
if not ok:
|
|
393
|
+
raise RuntimeError(
|
|
394
|
+
"CopyGrades returned False. fix: open the Color page (open_page('color')) and retry."
|
|
395
|
+
)
|
|
396
|
+
return {"sourceClipId": source_id, "copied": len(targets)}
|
|
397
|
+
|
|
398
|
+
|
|
399
|
+
def m_list_render_presets(_params):
|
|
400
|
+
project = get_project()
|
|
401
|
+
presets = project.GetRenderPresetList() or []
|
|
402
|
+
return list(presets)
|
|
403
|
+
|
|
404
|
+
|
|
405
|
+
def m_replace_clip(params):
|
|
406
|
+
clip_id = str(params["clipId"])
|
|
407
|
+
media_path = str(params["mediaPath"])
|
|
408
|
+
item = _find_timeline_item(clip_id)
|
|
409
|
+
# Newer Resolve API: TimelineItem.ReplaceClip(media_path) or .ReplaceMedia.
|
|
410
|
+
last_err = None
|
|
411
|
+
for setter in (
|
|
412
|
+
lambda i: i.ReplaceClip(media_path) if hasattr(i, "ReplaceClip") else False,
|
|
413
|
+
lambda i: i.ReplaceMedia(media_path) if hasattr(i, "ReplaceMedia") else False,
|
|
414
|
+
):
|
|
415
|
+
try:
|
|
416
|
+
ok = setter(item)
|
|
417
|
+
if ok:
|
|
418
|
+
return {"clipId": clip_id, "mediaPath": media_path}
|
|
419
|
+
except Exception as e:
|
|
420
|
+
last_err = e
|
|
421
|
+
raise RuntimeError(
|
|
422
|
+
f"replace_clip not supported by this Resolve version. Last error: {last_err}. "
|
|
423
|
+
f"fix: rebuild the segment via FCPXML with the new media reference."
|
|
424
|
+
)
|
|
425
|
+
|
|
426
|
+
|
|
427
|
+
def m_add_track(params):
|
|
428
|
+
t = get_timeline_obj()
|
|
429
|
+
kind = str(params.get("kind", "video"))
|
|
430
|
+
if kind not in ("video", "audio", "subtitle"):
|
|
431
|
+
raise RuntimeError(f"unknown track kind: {kind}")
|
|
432
|
+
if not hasattr(t, "AddTrack"):
|
|
433
|
+
raise RuntimeError("this Resolve version's Timeline has no AddTrack")
|
|
434
|
+
ok = t.AddTrack(kind)
|
|
435
|
+
if not ok:
|
|
436
|
+
raise RuntimeError(f"AddTrack({kind}) returned False")
|
|
437
|
+
try:
|
|
438
|
+
new_count = int(t.GetTrackCount(kind))
|
|
439
|
+
except Exception:
|
|
440
|
+
new_count = 0
|
|
441
|
+
return {"kind": kind, "track": new_count}
|
|
442
|
+
|
|
443
|
+
|
|
444
|
+
def m_set_clip_volume(params):
|
|
445
|
+
clip_id = str(params["clipId"])
|
|
446
|
+
volume_db = float(params["volumeDb"])
|
|
447
|
+
item = _find_timeline_item(clip_id)
|
|
448
|
+
# Resolve audio clips expose Volume as a clip property in dB. Some versions
|
|
449
|
+
# accept dB directly; older versions need linear (10**(dB/20)). Try both.
|
|
450
|
+
last_err = None
|
|
451
|
+
for setter in (
|
|
452
|
+
lambda i: i.SetClipProperty("Volume", str(volume_db)),
|
|
453
|
+
lambda i: i.SetClipProperty("Volume", volume_db),
|
|
454
|
+
lambda i: i.SetClipProperty("Volume", str(10 ** (volume_db / 20.0))),
|
|
455
|
+
):
|
|
456
|
+
try:
|
|
457
|
+
ok = setter(item)
|
|
458
|
+
if ok:
|
|
459
|
+
return {"clipId": clip_id, "volumeDb": volume_db}
|
|
460
|
+
except Exception as e:
|
|
461
|
+
last_err = e
|
|
462
|
+
raise RuntimeError(
|
|
463
|
+
f"Resolve refused all volume setters. Last error: {last_err}. "
|
|
464
|
+
f"fix: adjust volume manually on the Fairlight page."
|
|
465
|
+
)
|
|
466
|
+
|
|
467
|
+
|
|
468
|
+
def m_clone_timeline(params):
|
|
469
|
+
project = get_project()
|
|
470
|
+
pm = get_resolve().GetProjectManager()
|
|
471
|
+
src = project.GetCurrentTimeline()
|
|
472
|
+
if src is None:
|
|
473
|
+
raise RuntimeError("No active timeline to clone.")
|
|
474
|
+
new_name = str(params["newName"])
|
|
475
|
+
# Resolve API: TimelineItem dup is via Timeline.DuplicateTimeline(name).
|
|
476
|
+
if not hasattr(src, "DuplicateTimeline"):
|
|
477
|
+
raise RuntimeError("this Resolve version's Timeline has no DuplicateTimeline")
|
|
478
|
+
new_tl = src.DuplicateTimeline(new_name)
|
|
479
|
+
if new_tl is None:
|
|
480
|
+
raise RuntimeError("DuplicateTimeline returned None")
|
|
481
|
+
project.SetCurrentTimeline(new_tl)
|
|
482
|
+
pm.SaveProject()
|
|
483
|
+
return {"name": new_tl.GetName()}
|
|
484
|
+
|
|
485
|
+
|
|
486
|
+
def m_save_project(_params):
|
|
487
|
+
pm = get_resolve().GetProjectManager()
|
|
488
|
+
ok = pm.SaveProject()
|
|
489
|
+
if not ok:
|
|
490
|
+
raise RuntimeError("SaveProject returned False")
|
|
491
|
+
return None
|
|
492
|
+
|
|
493
|
+
|
|
494
|
+
def m_insert_clip_on_track(params):
|
|
495
|
+
project = get_project()
|
|
496
|
+
media_pool = project.GetMediaPool()
|
|
497
|
+
media_path = str(params["mediaPath"])
|
|
498
|
+
track = int(params.get("track", 2))
|
|
499
|
+
record_frame = int(params["recordFrame"])
|
|
500
|
+
|
|
501
|
+
# Import media into the pool first.
|
|
502
|
+
media_storage = get_resolve().GetMediaStorage()
|
|
503
|
+
items = media_storage.AddItemListToMediaPool([media_path]) or []
|
|
504
|
+
if not items:
|
|
505
|
+
raise RuntimeError(f"failed to import {media_path} into media pool")
|
|
506
|
+
item = items[0]
|
|
507
|
+
|
|
508
|
+
clip_info = {
|
|
509
|
+
"mediaPoolItem": item,
|
|
510
|
+
"mediaType": 1, # video
|
|
511
|
+
"trackIndex": track,
|
|
512
|
+
"recordFrame": record_frame,
|
|
513
|
+
}
|
|
514
|
+
if params.get("sourceInFrame") is not None:
|
|
515
|
+
clip_info["startFrame"] = int(params["sourceInFrame"])
|
|
516
|
+
if params.get("sourceOutFrame") is not None:
|
|
517
|
+
clip_info["endFrame"] = int(params["sourceOutFrame"])
|
|
518
|
+
|
|
519
|
+
appended = media_pool.AppendToTimeline([clip_info]) or []
|
|
520
|
+
if not appended:
|
|
521
|
+
raise RuntimeError(
|
|
522
|
+
"AppendToTimeline returned no items; verify track index exists and recordFrame is within the timeline."
|
|
523
|
+
)
|
|
524
|
+
inserted = appended[0]
|
|
525
|
+
t = get_timeline_obj()
|
|
526
|
+
start_offset = int(t.GetStartFrame())
|
|
527
|
+
return {
|
|
528
|
+
"id": str(inserted.GetUniqueId()) if hasattr(inserted, "GetUniqueId") else inserted.GetName(),
|
|
529
|
+
"track": track,
|
|
530
|
+
"trackKind": "video",
|
|
531
|
+
"startFrame": int(inserted.GetStart()) - start_offset,
|
|
532
|
+
"endFrame": int(inserted.GetEnd()) - start_offset,
|
|
533
|
+
"name": inserted.GetName(),
|
|
534
|
+
}
|
|
535
|
+
|
|
536
|
+
|
|
537
|
+
def m_smart_reframe(params):
|
|
538
|
+
clip_id = str(params["clipId"])
|
|
539
|
+
aspect = str(params["aspect"])
|
|
540
|
+
frame_interest = str(params.get("frameInterest", "all"))
|
|
541
|
+
reference_frame = params.get("referenceFrame")
|
|
542
|
+
item = _find_timeline_item(clip_id)
|
|
543
|
+
if not hasattr(item, "SmartReframe"):
|
|
544
|
+
raise RuntimeError(
|
|
545
|
+
"this Resolve version's TimelineItem has no SmartReframe (Studio-only feature)"
|
|
546
|
+
)
|
|
547
|
+
# SmartReframe signature varies; pass aspect always, then optional kwargs.
|
|
548
|
+
try:
|
|
549
|
+
if reference_frame is not None and frame_interest == "reference-frame":
|
|
550
|
+
ok = item.SmartReframe(aspect, frame_interest, int(reference_frame))
|
|
551
|
+
else:
|
|
552
|
+
ok = item.SmartReframe(aspect, frame_interest)
|
|
553
|
+
except TypeError:
|
|
554
|
+
ok = item.SmartReframe(aspect)
|
|
555
|
+
if not ok:
|
|
556
|
+
raise RuntimeError(
|
|
557
|
+
"SmartReframe returned False. fix: ensure Resolve Studio (free version lacks AI), and the clip is on the active timeline."
|
|
558
|
+
)
|
|
559
|
+
return {"clipId": clip_id, "aspect": aspect}
|
|
560
|
+
|
|
561
|
+
|
|
562
|
+
def m_import_subtitles(params):
|
|
563
|
+
project = get_project()
|
|
564
|
+
media_pool = project.GetMediaPool()
|
|
565
|
+
srt_path = params["srtPath"]
|
|
566
|
+
|
|
567
|
+
items = media_pool.ImportMedia([srt_path]) or []
|
|
568
|
+
if not items:
|
|
569
|
+
raise RuntimeError(
|
|
570
|
+
f"ImportMedia returned no items for {srt_path}. fix: import the SRT manually via File > Import Subtitle."
|
|
571
|
+
)
|
|
572
|
+
|
|
573
|
+
t = get_timeline_obj()
|
|
574
|
+
# Make sure at least one subtitle track exists.
|
|
575
|
+
try:
|
|
576
|
+
sub_count = int(t.GetTrackCount("subtitle"))
|
|
577
|
+
except Exception:
|
|
578
|
+
sub_count = 0
|
|
579
|
+
if sub_count < 1:
|
|
580
|
+
try:
|
|
581
|
+
t.AddTrack("subtitle")
|
|
582
|
+
except Exception:
|
|
583
|
+
pass
|
|
584
|
+
|
|
585
|
+
appended = media_pool.AppendToTimeline(items) or []
|
|
586
|
+
if not appended:
|
|
587
|
+
return {
|
|
588
|
+
"imported": True,
|
|
589
|
+
"attached": False,
|
|
590
|
+
"note": "SRT imported to media pool but auto-attach failed; drag onto subtitle track manually.",
|
|
591
|
+
}
|
|
592
|
+
return {"imported": True, "attached": True}
|
|
593
|
+
|
|
594
|
+
|
|
595
|
+
METHODS = {
|
|
596
|
+
"ping": m_ping,
|
|
597
|
+
"get_timeline": m_get_timeline,
|
|
598
|
+
"add_marker": m_add_marker,
|
|
599
|
+
"append_clip": m_append_clip,
|
|
600
|
+
"import_timeline": m_import_timeline,
|
|
601
|
+
"render": m_render,
|
|
602
|
+
"get_markers": m_get_markers,
|
|
603
|
+
"create_timeline": m_create_timeline,
|
|
604
|
+
"import_to_media_pool": m_import_to_media_pool,
|
|
605
|
+
"open_page": m_open_page,
|
|
606
|
+
"set_clip_speed": m_set_clip_speed,
|
|
607
|
+
"apply_lut": m_apply_lut,
|
|
608
|
+
"set_primary_correction": m_set_primary_correction,
|
|
609
|
+
"copy_grade": m_copy_grade,
|
|
610
|
+
"list_render_presets": m_list_render_presets,
|
|
611
|
+
"replace_clip": m_replace_clip,
|
|
612
|
+
"smart_reframe": m_smart_reframe,
|
|
613
|
+
"insert_clip_on_track": m_insert_clip_on_track,
|
|
614
|
+
"clone_timeline": m_clone_timeline,
|
|
615
|
+
"save_project": m_save_project,
|
|
616
|
+
"add_track": m_add_track,
|
|
617
|
+
"set_clip_volume": m_set_clip_volume,
|
|
618
|
+
"import_subtitles": m_import_subtitles,
|
|
619
|
+
}
|
|
620
|
+
|
|
621
|
+
|
|
622
|
+
def main():
|
|
623
|
+
# Signal we're alive.
|
|
624
|
+
sys.stdout.write(json.dumps({"id": "_ready", "ok": True, "result": {"ready": True}}) + "\n")
|
|
625
|
+
sys.stdout.flush()
|
|
626
|
+
|
|
627
|
+
for line in sys.stdin:
|
|
628
|
+
line = line.strip()
|
|
629
|
+
if not line:
|
|
630
|
+
continue
|
|
631
|
+
try:
|
|
632
|
+
req = json.loads(line)
|
|
633
|
+
except json.JSONDecodeError as e:
|
|
634
|
+
sys.stdout.write(json.dumps({"id": "_parse", "ok": False, "error": f"bad json: {e}"}) + "\n")
|
|
635
|
+
sys.stdout.flush()
|
|
636
|
+
continue
|
|
637
|
+
|
|
638
|
+
rid = req.get("id", "?")
|
|
639
|
+
method = req.get("method", "")
|
|
640
|
+
params = req.get("params", {}) or {}
|
|
641
|
+
|
|
642
|
+
fn = METHODS.get(method)
|
|
643
|
+
if fn is None:
|
|
644
|
+
sys.stdout.write(json.dumps({"id": rid, "ok": False, "error": f"unknown method: {method}"}) + "\n")
|
|
645
|
+
sys.stdout.flush()
|
|
646
|
+
continue
|
|
647
|
+
|
|
648
|
+
try:
|
|
649
|
+
result = fn(params)
|
|
650
|
+
sys.stdout.write(json.dumps({"id": rid, "ok": True, "result": result}) + "\n")
|
|
651
|
+
except Exception as e:
|
|
652
|
+
tb = traceback.format_exc(limit=2)
|
|
653
|
+
sys.stdout.write(json.dumps({"id": rid, "ok": False, "error": f"{e.__class__.__name__}: {e}", "trace": tb}) + "\n")
|
|
654
|
+
sys.stdout.flush()
|
|
655
|
+
|
|
656
|
+
|
|
657
|
+
if __name__ == "__main__":
|
|
658
|
+
main()
|
|
659
|
+
`;
|
|
660
|
+
//# sourceMappingURL=bridge-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bridge-source.js","sourceRoot":"","sources":["../../../../src/core/hosts/resolve/bridge-source.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,MAAM,CAAC,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAmoBlC,CAAC"}
|