diff --git a/Cargo.lock b/Cargo.lock index dadd7f9..03cb8d8 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2,21 +2,23 @@ # It is not intended for manual editing. version = 4 -[[package]] -name = "addr2line" -version = "0.24.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dfbe277e56a376000877090da837660b4427aad530e3028d44e0bffe4f89a1c1" -dependencies = [ - "gimli", -] - [[package]] name = "adler2" version = "2.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "512761e0bb2578dd7380c6baaa0f4ce03e84f95e960231d1dec8bf4d7d6e2627" +[[package]] +name = "aes" +version = "0.8.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b169f7a6d4742236a0a00c541b845991d0ac43e546831af1249753ab4c3aa3a0" +dependencies = [ + "cfg-if 1.0.0", + "cipher", + "cpufeatures", +] + [[package]] name = "ahash" version = "0.4.8" @@ -56,7 +58,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ed7572b7ba83a31e20d1b48970ee402d2e3e0537dcfe0a3ff4d6eb7508617d43" dependencies = [ "alsa-sys", - "bitflags 2.6.0", + "bitflags 2.7.0", "cfg-if 1.0.0", "libc", ] @@ -97,6 +99,9 @@ name = "arbitrary" version = "1.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dde20b3d026af13f561bdd0f15edf01fc734f0dafcedbaf42bba506a9517f223" +dependencies = [ + "derive_arbitrary", +] [[package]] name = "arg_enum_proc_macro" @@ -106,7 +111,7 @@ checksum = "0ae92a5119aa49cdbcf6b9f893fe4e1d98b04ccbf82ee0584ad948a44a734dea" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -131,7 +136,7 @@ version = "0.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "435a87a52755b8f27fcf321ac4f04b2802e337c8c4872923137471ec39c37532" dependencies = [ - "event-listener 5.3.1", + "event-listener 5.4.0", "event-listener-strategy", "futures-core", "pin-project-lite", @@ -169,7 +174,7 @@ dependencies = [ "async-task", "concurrent-queue", "fastrand 2.3.0", - "futures-lite 2.5.0", + "futures-lite 2.6.0", "slab", ] @@ -181,7 +186,7 @@ checksum = "ebcd09b382f40fcd159c2d695175b2ae620ffa5f3bd6f664131efff4e8b9e04a" dependencies = [ "async-lock 3.4.0", "blocking", - "futures-lite 2.5.0", + "futures-lite 2.6.0", ] [[package]] @@ -195,7 +200,7 @@ dependencies = [ "async-io 2.4.0", "async-lock 3.4.0", "blocking", - "futures-lite 2.5.0", + "futures-lite 2.6.0", "once_cell", ] @@ -213,9 +218,9 @@ dependencies = [ "log", "parking", "polling 2.8.0", - "rustix 0.37.27", + "rustix 0.37.28", "slab", - "socket2 0.4.10", + "socket2", "waker-fn", ] @@ -229,10 +234,10 @@ dependencies = [ "cfg-if 1.0.0", "concurrent-queue", "futures-io", - "futures-lite 2.5.0", + "futures-lite 2.6.0", "parking", "polling 3.7.4", - "rustix 0.38.42", + "rustix 0.38.43", "slab", "tracing", "windows-sys 0.59.0", @@ -253,7 +258,7 @@ version = "3.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ff6e472cdea888a4bd64f342f09b3f50e1886d32afe8df3d663c01140b811b18" dependencies = [ - "event-listener 5.3.1", + "event-listener 5.4.0", "event-listener-strategy", "pin-project-lite", ] @@ -271,9 +276,9 @@ dependencies = [ "async-task", "blocking", "cfg-if 1.0.0", - "event-listener 5.3.1", - "futures-lite 2.5.0", - "rustix 0.38.42", + "event-listener 5.4.0", + "futures-lite 2.6.0", + "rustix 0.38.43", "tracing", ] @@ -285,7 +290,7 @@ checksum = "3b43422f69d8ff38f95f1b2bb76517c91589a924d1559a0e935d7c8ce0274c11" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -300,7 +305,7 @@ dependencies = [ "cfg-if 1.0.0", "futures-core", "futures-io", - "rustix 0.38.42", + "rustix 0.38.43", "signal-hook-registry", "slab", "windows-sys 0.59.0", @@ -321,7 +326,7 @@ dependencies = [ "futures-channel", "futures-core", "futures-io", - "futures-lite 2.5.0", + "futures-lite 2.6.0", "gloo-timers", "kv-log-macro", "log", @@ -341,13 +346,13 @@ checksum = "8b75356056920673b02621b35afd0f7dda9306d03c79a30f5c56c44cf256e3de" [[package]] name = "async-trait" -version = "0.1.84" +version = "0.1.85" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1b1244b10dcd56c92219da4e14caa97e312079e185f04ba3eea25061561dc0a0" +checksum = "3f934833b4b7233644e5848f235df3f57ed8c80f1528a26c3dfa13d2147fa056" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -385,21 +390,6 @@ dependencies = [ "arrayvec", ] -[[package]] -name = "backtrace" -version = "0.3.74" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d82cb332cdfaed17ae235a638438ac4d4839913cc2af585c3c6746e8f8bee1a" -dependencies = [ - "addr2line", - "cfg-if 1.0.0", - "libc", - "miniz_oxide", - "object", - "rustc-demangle", - "windows-targets 0.52.6", -] - [[package]] name = "base64" version = "0.22.1" @@ -412,7 +402,7 @@ version = "0.70.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f49d8fed880d473ea71efb9bf597651e77201bdd4893efe54c9e5d65ae04ce6f" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "cexpr", "clang-sys", "itertools 0.13.0", @@ -421,7 +411,7 @@ dependencies = [ "regex", "rustc-hash", "shlex", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -438,9 +428,9 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" [[package]] name = "bitflags" -version = "2.6.0" +version = "2.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de" +checksum = "1be3f42a67d6d345ecd59f675f3f012d6974981560836e938c22b424b85ce1be" [[package]] name = "bitstream-io" @@ -472,7 +462,7 @@ dependencies = [ "async-channel 2.3.1", "async-task", "futures-io", - "futures-lite 2.5.0", + "futures-lite 2.6.0", "piper", ] @@ -547,6 +537,27 @@ version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "325918d6fe32f23b19878fe4b34794ae41fc19ddbe53b10571a4874d44ffd39b" +[[package]] +name = "bzip2" +version = "0.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bdb116a6ef3f6c3698828873ad02c3014b3c85cadb88496095628e3ef1e347f8" +dependencies = [ + "bzip2-sys", + "libc", +] + +[[package]] +name = "bzip2-sys" +version = "0.1.11+1.0.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "736a955f3fa7875102d57c82b8cac37ec45224a07fd32d58f9f7a186b6cd4cdc" +dependencies = [ + "cc", + "libc", + "pkg-config", +] + [[package]] name = "cairo-rs" version = "0.16.7" @@ -558,7 +569,7 @@ dependencies = [ "glib 0.16.9", "libc", "once_cell", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -574,9 +585,9 @@ dependencies = [ [[package]] name = "cc" -version = "1.2.7" +version = "1.2.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a012a0df96dd6d06ba9a1b29d6402d1a5d77c6befd2566afdc26e10603dc93d7" +checksum = "c8293772165d9345bdaaa39b45b2109591e63fe5e6fbc23c6ff930a048aa310b" dependencies = [ "jobserver", "libc", @@ -640,6 +651,16 @@ dependencies = [ "windows-targets 0.52.6", ] +[[package]] +name = "cipher" +version = "0.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "773f3b9af64447d2ce9850330c473515014aa235e6a783b02db81ff39e4a3dad" +dependencies = [ + "crypto-common", + "inout", +] + [[package]] name = "clang-sys" version = "1.8.1" @@ -657,12 +678,12 @@ version = "0.26.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f79398230a6e2c08f5c9760610eb6924b52aa9e7950a619602baba59dcbbdbb2" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "block", "cocoa-foundation", "core-foundation 0.10.0", "core-graphics 0.24.0", - "foreign-types 0.5.0", + "foreign-types", "libc", "objc", ] @@ -673,7 +694,7 @@ version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e14045fb83be07b5acf1c0884b2180461635b433455fa35d1cd6f17f1450679d" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "block", "core-foundation 0.10.0", "core-graphics-types 0.2.0", @@ -706,6 +727,12 @@ dependencies = [ "crossbeam-utils", ] +[[package]] +name = "constant_time_eq" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7c74b8349d32d297c9134b8c88677813a227df8f779daa29bfc29c183fe3dca6" + [[package]] name = "core-foundation" version = "0.9.4" @@ -741,7 +768,7 @@ dependencies = [ "bitflags 1.3.2", "core-foundation 0.9.4", "core-graphics-types 0.1.3", - "foreign-types 0.5.0", + "foreign-types", "libc", ] @@ -751,10 +778,10 @@ version = "0.24.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fa95a34622365fa5bbf40b20b75dba8dfa8c94c734aea8ac9a5ca38af14316f1" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "core-foundation 0.10.0", "core-graphics-types 0.2.0", - "foreign-types 0.5.0", + "foreign-types", "libc", ] @@ -775,7 +802,7 @@ version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3d44a101f213f6c4cdc1853d4b78aef6db6bdfa3468798cc1d9912f4735013eb" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "core-foundation 0.10.0", "libc", ] @@ -832,6 +859,21 @@ dependencies = [ "libc", ] +[[package]] +name = "crc" +version = "3.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "69e6e4d7b33a94f0991c26729976b10ebde1d34c3ee82408fb536164fa10d636" +dependencies = [ + "crc-catalog", +] + +[[package]] +name = "crc-catalog" +version = "2.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "19d374276b40fb8bbdee95aef7c7fa6b5316ec764510eb64b8dd0e2ed0d7e7f5" + [[package]] name = "crc32fast" version = "1.4.2" @@ -916,6 +958,21 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7046468a81e6a002061c01e6a7c83139daf91b11c30e66795b13217c2d885c8b" +[[package]] +name = "deflate64" +version = "0.1.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "da692b8d1080ea3045efaab14434d40468c3d8657e42abddfffca87b428f4c1b" + +[[package]] +name = "deranged" +version = "0.3.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" +dependencies = [ + "powerfmt", +] + [[package]] name = "derivative" version = "2.2.0" @@ -927,6 +984,17 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "derive_arbitrary" +version = "1.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "30542c1ad912e0e3d22a1935c290e12e8a29d704a420177a31faad4a601a0800" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.96", +] + [[package]] name = "detect-desktop-environment" version = "0.2.0" @@ -941,6 +1009,7 @@ checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" dependencies = [ "block-buffer", "crypto-common", + "subtle", ] [[package]] @@ -987,7 +1056,7 @@ checksum = "97369cbbc041bc366949bc74d34658d6cda5621039731c6310521892a3a20ae0" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -1026,15 +1095,6 @@ version = "1.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "60b1af1c220855b6ceac025d3f6ecdd2b7c4894bfe9cd9bda4fbb4bc7c0d4cf0" -[[package]] -name = "encoding_rs" -version = "0.8.35" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "75030f3c4f45dafd7586dd6780965a8c7e8e285a5ecb86713e63a79c5b2766f3" -dependencies = [ - "cfg-if 1.0.0", -] - [[package]] name = "endi" version = "1.1.0" @@ -1080,7 +1140,7 @@ checksum = "de0d48a183585823424a4ce1aa132d174a6a81bd540895822eb4c8373a8e49e8" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -1107,9 +1167,9 @@ checksum = "0206175f82b8d6bf6652ff7d71a1e27fd2e4efde587fd368662814d6ec1d9ce0" [[package]] name = "event-listener" -version = "5.3.1" +version = "5.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6032be9bd27023a771701cc49f9f053c751055f71efb2e0ae5c15809093675ba" +checksum = "3492acde4c3fc54c845eaab3eed8bd00c7a7d881f78bfc801e43a93dec1331ae" dependencies = [ "concurrent-queue", "parking", @@ -1122,7 +1182,7 @@ version = "0.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3c3e4e0dd3673c1139bf041f3008816d9cf2946bbfac2945c09e523b8d7b05b2" dependencies = [ - "event-listener 5.3.1", + "event-listener 5.4.0", "pin-project-lite", ] @@ -1167,12 +1227,15 @@ dependencies = [ [[package]] name = "ffmpeg-sidecar" -version = "1.2.0" +version = "2.0.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d67d09bdb90406a420b30ba06d464a976c9642081c2ecdf09e35ec80bd7eb9b1" +checksum = "57523e081f3afa5731b47829968beb2ed787fcc2ace71a055b0a93a5ea6b3ebb" dependencies = [ "anyhow", - "reqwest", + "tar", + "ureq", + "xz2", + "zip", ] [[package]] @@ -1185,6 +1248,18 @@ dependencies = [ "rustc_version", ] +[[package]] +name = "filetime" +version = "0.2.25" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "35c0522e981e68cbfa8c3f978441a5f34b30b96e146b33cd3359176b50fe8586" +dependencies = [ + "cfg-if 1.0.0", + "libc", + "libredox", + "windows-sys 0.59.0", +] + [[package]] name = "flate2" version = "1.0.35" @@ -1226,22 +1301,7 @@ version = "0.11.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2a530c4694a6a8d528794ee9bbd8ba0122e779629ac908d15ad5a7ae7763a33d" dependencies = [ - "thiserror", -] - -[[package]] -name = "fnv" -version = "1.0.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" - -[[package]] -name = "foreign-types" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" -dependencies = [ - "foreign-types-shared 0.1.1", + "thiserror 1.0.69", ] [[package]] @@ -1251,7 +1311,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d737d9aa519fb7b749cbc3b962edcf310a8dd1f4b67c91c4f83975dbdd17d965" dependencies = [ "foreign-types-macros", - "foreign-types-shared 0.3.1", + "foreign-types-shared", ] [[package]] @@ -1262,15 +1322,9 @@ checksum = "1a5c6c585bc94aaf2c7b51dd4c2ba22680844aba4c687be581871a6f518c5742" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] -[[package]] -name = "foreign-types-shared" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" - [[package]] name = "foreign-types-shared" version = "0.3.1" @@ -1351,9 +1405,9 @@ dependencies = [ [[package]] name = "futures-lite" -version = "2.5.0" +version = "2.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cef40d21ae2c515b51041df9ed313ed21e572df340ea58a922a0aefe7e8891a1" +checksum = "f5edaec856126859abb19ed65f39e90fea3a9574b9707f13539acf4abf7eb532" dependencies = [ "fastrand 2.3.0", "futures-core", @@ -1370,7 +1424,7 @@ checksum = "162ee34ebcb7c64a8abebc059ce0fee27c2262618d7b60ed8faf72fef13c3650" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -1502,12 +1556,6 @@ dependencies = [ "weezl", ] -[[package]] -name = "gimli" -version = "0.31.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "07e28edb80900c19c28f1072f2e8aeca7fa06b23cd4169cefe1af5aa3260783f" - [[package]] name = "gio" version = "0.16.7" @@ -1525,7 +1573,7 @@ dependencies = [ "once_cell", "pin-project-lite", "smallvec", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -1579,7 +1627,7 @@ dependencies = [ "libc", "once_cell", "smallvec", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -1784,25 +1832,6 @@ dependencies = [ "system-deps 6.2.2", ] -[[package]] -name = "h2" -version = "0.4.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ccae279728d634d083c00f6099cb58f01cc99c145b84b8be2f6c74618d79922e" -dependencies = [ - "atomic-waker", - "bytes", - "fnv", - "futures-core", - "futures-sink", - "http", - "indexmap", - "slab", - "tokio", - "tokio-util", - "tracing", -] - [[package]] name = "half" version = "2.4.1" @@ -1877,115 +1906,12 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70" [[package]] -name = "http" -version = "1.2.0" +name = "hmac" +version = "0.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f16ca2af56261c99fba8bac40a10251ce8188205a4c448fbb745a2e4daa76fea" +checksum = "6c49c37c09c17a53d937dfbb742eb3a961d65a994e6bcdcf37e7399d0cc8ab5e" dependencies = [ - "bytes", - "fnv", - "itoa", -] - -[[package]] -name = "http-body" -version = "1.0.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1efedce1fb8e6913f23e0c92de8e62cd5b772a67e7b3946df930a62566c93184" -dependencies = [ - "bytes", - "http", -] - -[[package]] -name = "http-body-util" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "793429d76616a256bcb62c2a2ec2bed781c8307e797e2598c50010f2bee2544f" -dependencies = [ - "bytes", - "futures-util", - "http", - "http-body", - "pin-project-lite", -] - -[[package]] -name = "httparse" -version = "1.9.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7d71d3574edd2771538b901e6549113b4006ece66150fb69c0fb6d9a2adae946" - -[[package]] -name = "hyper" -version = "1.5.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "256fb8d4bd6413123cc9d91832d78325c48ff41677595be797d90f42969beae0" -dependencies = [ - "bytes", - "futures-channel", - "futures-util", - "h2", - "http", - "http-body", - "httparse", - "itoa", - "pin-project-lite", - "smallvec", - "tokio", - "want", -] - -[[package]] -name = "hyper-rustls" -version = "0.27.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2d191583f3da1305256f22463b9bb0471acad48a4e534a5218b9963e9c1f59b2" -dependencies = [ - "futures-util", - "http", - "hyper", - "hyper-util", - "rustls", - "rustls-pki-types", - "tokio", - "tokio-rustls", - "tower-service", -] - -[[package]] -name = "hyper-tls" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "70206fc6890eaca9fde8a0bf71caa2ddfc9fe045ac9e5c70df101a7dbde866e0" -dependencies = [ - "bytes", - "http-body-util", - "hyper", - "hyper-util", - "native-tls", - "tokio", - "tokio-native-tls", - "tower-service", -] - -[[package]] -name = "hyper-util" -version = "0.1.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "df2dcfbe0677734ab2f3ffa7fa7bfd4706bfdc1ef393f2ee30184aed67e631b4" -dependencies = [ - "bytes", - "futures-channel", - "futures-util", - "http", - "http-body", - "hyper", - "pin-project-lite", - "socket2 0.5.8", - "tokio", - "tower-service", - "tracing", + "digest", ] [[package]] @@ -2126,7 +2052,7 @@ checksum = "1ec89e9337638ecdc08744df490b221a7399bf8d164eb52a665454e60e075ad6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -2175,9 +2101,9 @@ dependencies = [ [[package]] name = "image-webp" -version = "0.2.0" +version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e031e8e3d94711a9ccb5d6ea357439ef3dcbed361798bd4071dc4d9793fbe22f" +checksum = "b77d01e822461baa8409e156015a1d91735549f0f2c17691bd2d996bef238f7f" dependencies = [ "byteorder-lite", "quick-error", @@ -2199,6 +2125,15 @@ dependencies = [ "hashbrown 0.15.2", ] +[[package]] +name = "inout" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a0c10553d664a4d0bcff9f4215d0aac67a639cc68ef660840afe309b807bc9f5" +dependencies = [ + "generic-array", +] + [[package]] name = "instant" version = "0.1.13" @@ -2216,7 +2151,7 @@ checksum = "c34819042dc3d3971c46c2190835914dfbe0c3c13f61449b2997f4e9722dfa60" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -2249,12 +2184,6 @@ dependencies = [ "windows-sys 0.48.0", ] -[[package]] -name = "ipnet" -version = "2.10.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ddc24109865250148c2e0f3d25d4f0f479571723792d3802153c60922a4fb708" - [[package]] name = "is-docker" version = "0.2.0" @@ -2318,7 +2247,7 @@ dependencies = [ "combine", "jni-sys", "log", - "thiserror", + "thiserror 1.0.69", "walkdir", "windows-sys 0.45.0", ] @@ -2346,9 +2275,9 @@ checksum = "f5d4a7da358eff58addd2877a45865158f0d78c911d43a5784ceb7bbf52833b0" [[package]] name = "js-sys" -version = "0.3.76" +version = "0.3.77" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6717b6b5b077764fb5966237269cb3c64edddde4b14ce42647430a78ced9e7b7" +checksum = "1cfaf33c695fc6e08064efbc1f72ec937429614f25eef83af942d0e227c3a28f" dependencies = [ "once_cell", "wasm-bindgen", @@ -2436,8 +2365,9 @@ version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c0ff37bd590ca25063e35af745c343cb7a0271906fb7b37e4813e8f79f00268d" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "libc", + "redox_syscall", ] [[package]] @@ -2448,9 +2378,9 @@ checksum = "ef53942eb7bf7ff43a617b3e2c1c4a5ecf5944a7c1bc12d7ee39bbb15e5c1519" [[package]] name = "linux-raw-sys" -version = "0.4.14" +version = "0.4.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "78b3ae25bc7c8c38cec158d1f2757ee79e9b3740fbc7ccf0e59e4b08d793fa89" +checksum = "d26c52dbd32dccf2d10cac7725f8eae5296885fb5703b261f7d0a0739ec807ab" [[package]] name = "litemap" @@ -2458,6 +2388,12 @@ version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4ee93343901ab17bd981295f2cf0026d4ad018c7c31ba84549a4ddbb47a45104" +[[package]] +name = "lockfree-object-pool" +version = "0.1.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9374ef4228402d4b7e403e5838cb880d9ee663314b0a900d5a6aabf0c213552e" + [[package]] name = "log" version = "0.4.22" @@ -2476,6 +2412,27 @@ dependencies = [ "imgref", ] +[[package]] +name = "lzma-rs" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "297e814c836ae64db86b36cf2a557ba54368d03f6afcd7d947c266692f71115e" +dependencies = [ + "byteorder", + "crc", +] + +[[package]] +name = "lzma-sys" +version = "0.1.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5fda04ab3764e6cde78b9974eec4f779acaba7c4e84b36eca3cf77c581b85d27" +dependencies = [ + "cc", + "libc", + "pkg-config", +] + [[package]] name = "mach2" version = "0.4.2" @@ -2537,12 +2494,6 @@ dependencies = [ "autocfg", ] -[[package]] -name = "mime" -version = "0.3.17" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6877bb514081ee2a7ff5ef9de3281f14a4dd4bceac4c09388074a6b5df8a139a" - [[package]] name = "minimal-lexical" version = "0.2.1" @@ -2559,34 +2510,6 @@ dependencies = [ "simd-adler32", ] -[[package]] -name = "mio" -version = "1.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2886843bf800fba2e3377cff24abf6379b4c4d5c6681eaf9ea5b0d15090450bd" -dependencies = [ - "libc", - "wasi", - "windows-sys 0.52.0", -] - -[[package]] -name = "native-tls" -version = "0.2.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a8614eb2c83d59d1c8cc974dd3f920198647674a0a035e1af1fa58707e317466" -dependencies = [ - "libc", - "log", - "openssl", - "openssl-probe", - "openssl-sys", - "schannel", - "security-framework", - "security-framework-sys", - "tempfile", -] - [[package]] name = "nb-connect" version = "1.2.0" @@ -2594,7 +2517,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b1bb540dc6ef51cfe1916ec038ce7a620daf3a111e2502d745197cd53d6bca15" dependencies = [ "libc", - "socket2 0.4.10", + "socket2", ] [[package]] @@ -2603,12 +2526,12 @@ version = "0.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2076a31b7010b17a38c01907c45b945e8f11495ee4dd588309718901b1f7a5b7" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "jni-sys", "log", "ndk-sys", "num_enum", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -2651,7 +2574,7 @@ version = "0.29.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "71e2746dc3a24dd78b3cfcb7be93368c6de9963d30f43a6a73998a9cf4b17b46" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "cfg-if 1.0.0", "cfg_aliases", "libc", @@ -2684,6 +2607,12 @@ dependencies = [ "num-traits", ] +[[package]] +name = "num-conv" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" + [[package]] name = "num-derive" version = "0.4.2" @@ -2692,7 +2621,7 @@ checksum = "ed3955f1a9c7c0c15e092f9c887db08b1fc683305fdf6eb6684f22555355e202" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -2742,7 +2671,7 @@ dependencies = [ "proc-macro-crate 3.2.0", "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -2754,15 +2683,6 @@ dependencies = [ "malloc_buf", ] -[[package]] -name = "object" -version = "0.36.7" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "62948e14d923ea95ea2c7c86c71013138b66525b86bdc08d2dcc262bdb497b87" -dependencies = [ - "memchr", -] - [[package]] name = "oboe" version = "0.6.1" @@ -2803,50 +2723,6 @@ dependencies = [ "pathdiff", ] -[[package]] -name = "openssl" -version = "0.10.68" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6174bc48f102d208783c2c84bf931bb75927a617866870de8a4ea85597f871f5" -dependencies = [ - "bitflags 2.6.0", - "cfg-if 1.0.0", - "foreign-types 0.3.2", - "libc", - "once_cell", - "openssl-macros", - "openssl-sys", -] - -[[package]] -name = "openssl-macros" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.95", -] - -[[package]] -name = "openssl-probe" -version = "0.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" - -[[package]] -name = "openssl-sys" -version = "0.9.104" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "45abf306cbf99debc8195b66b7346498d7b10c210de50418b5ccd7ceba08c741" -dependencies = [ - "cc", - "libc", - "pkg-config", - "vcpkg", -] - [[package]] name = "ordered-multimap" version = "0.3.1" @@ -2921,6 +2797,16 @@ version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "df94ce210e5bc13cb6651479fa48d14f601d9858cfe0467f43ae157023b938d3" +[[package]] +name = "pbkdf2" +version = "0.12.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f8ed6a7761f76e3b9f92dfb0a60a6a6477c61024b775147ff0973a02653abaf2" +dependencies = [ + "digest", + "hmac", +] + [[package]] name = "percent-encoding" version = "2.3.1" @@ -2929,9 +2815,9 @@ checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" [[package]] name = "pin-project-lite" -version = "0.2.15" +version = "0.2.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "915a1e146535de9163f3987b8944ed8cf49a18bb0056bcebcdcece385cece4ff" +checksum = "3b3cff922bd51709b605d9ead9aa71031d81447142d828eb4a6eba76fe619f9b" [[package]] name = "pin-utils" @@ -2995,11 +2881,17 @@ dependencies = [ "concurrent-queue", "hermit-abi 0.4.0", "pin-project-lite", - "rustix 0.38.42", + "rustix 0.38.43", "tracing", "windows-sys 0.59.0", ] +[[package]] +name = "powerfmt" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" + [[package]] name = "ppv-lite86" version = "0.2.20" @@ -3063,9 +2955,9 @@ dependencies = [ [[package]] name = "proc-macro2" -version = "1.0.92" +version = "1.0.93" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "37d3544b3f2748c54e147655edb5025752e2303145b5aefb3c3ea2c78b973bb0" +checksum = "60946a68e5f9d28b0dc1c21bb8a97ee7d018a8b322fa57838ba31cc878e22d99" dependencies = [ "unicode-ident", ] @@ -3086,7 +2978,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a65f2e60fbf1063868558d69c6beacf412dc755f9fc020f514b7955fc914fe30" dependencies = [ "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -3191,7 +3083,7 @@ dependencies = [ "rand_chacha", "simd_helpers", "system-deps 6.2.2", - "thiserror", + "thiserror 1.0.69", "v_frame", "wasm-bindgen", ] @@ -3231,6 +3123,15 @@ dependencies = [ "crossbeam-utils", ] +[[package]] +name = "redox_syscall" +version = "0.5.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "03a862b389f93e68874fbf580b9de08dd02facb9a788ebadaf4a3fd33cf58834" +dependencies = [ + "bitflags 2.7.0", +] + [[package]] name = "redox_users" version = "0.4.6" @@ -3239,7 +3140,7 @@ checksum = "ba009ff324d1fc1b900bd1fdb31564febe58a8ccc8a6fdbb93b543d33b13ca43" dependencies = [ "getrandom", "libredox", - "thiserror", + "thiserror 1.0.69", ] [[package]] @@ -3271,51 +3172,6 @@ version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2b15c43186be67a4fd63bee50d0303afffcef381492ebe2c5d87f324e1b8815c" -[[package]] -name = "reqwest" -version = "0.12.12" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "43e734407157c3c2034e0258f5e4473ddb361b1e85f95a66690d67264d7cd1da" -dependencies = [ - "base64", - "bytes", - "encoding_rs", - "futures-channel", - "futures-core", - "futures-util", - "h2", - "http", - "http-body", - "http-body-util", - "hyper", - "hyper-rustls", - "hyper-tls", - "hyper-util", - "ipnet", - "js-sys", - "log", - "mime", - "native-tls", - "once_cell", - "percent-encoding", - "pin-project-lite", - "rustls-pemfile", - "serde", - "serde_json", - "serde_urlencoded", - "sync_wrapper", - "system-configuration", - "tokio", - "tokio-native-tls", - "tower", - "tower-service", - "url", - "wasm-bindgen", - "wasm-bindgen-futures", - "web-sys", - "windows-registry", -] - [[package]] name = "rgb" version = "0.8.50" @@ -3357,12 +3213,6 @@ dependencies = [ "ordered-multimap 0.4.3", ] -[[package]] -name = "rustc-demangle" -version = "0.1.24" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f" - [[package]] name = "rustc-hash" version = "1.1.0" @@ -3380,9 +3230,9 @@ dependencies = [ [[package]] name = "rustix" -version = "0.37.27" +version = "0.37.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fea8ca367a3a01fe35e6943c400addf443c0f57670e6ec51196f71a4b8762dd2" +checksum = "519165d378b97752ca44bbe15047d5d3409e875f39327546b42ac81d7e18c1b6" dependencies = [ "bitflags 1.3.2", "errno", @@ -3394,39 +3244,32 @@ dependencies = [ [[package]] name = "rustix" -version = "0.38.42" +version = "0.38.43" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f93dc38ecbab2eb790ff964bb77fa94faf256fd3e73285fd7ba0903b76bedb85" +checksum = "a78891ee6bf2340288408954ac787aa063d8e8817e9f53abb37c695c6d834ef6" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "errno", "libc", - "linux-raw-sys 0.4.14", + "linux-raw-sys 0.4.15", "windows-sys 0.59.0", ] [[package]] name = "rustls" -version = "0.23.20" +version = "0.23.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5065c3f250cbd332cd894be57c40fa52387247659b14a2d6041d121547903b1b" +checksum = "8f287924602bf649d949c63dc8ac8b235fa5387d394020705b80c4eb597ce5b8" dependencies = [ + "log", "once_cell", + "ring", "rustls-pki-types", "rustls-webpki", "subtle", "zeroize", ] -[[package]] -name = "rustls-pemfile" -version = "2.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dce314e5fee3f39953d46bb63bb8a46d40c2f8fb7cc5a3b6cab2bde9721d6e50" -dependencies = [ - "rustls-pki-types", -] - [[package]] name = "rustls-pki-types" version = "1.10.1" @@ -3444,6 +3287,12 @@ dependencies = [ "untrusted", ] +[[package]] +name = "rustversion" +version = "1.0.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f7c45b9784283f1b2e7fb61b42047c2fd678ef0960d4f6f1eba131594cc369d4" + [[package]] name = "ryu" version = "1.0.18" @@ -3459,15 +3308,6 @@ dependencies = [ "winapi-util", ] -[[package]] -name = "schannel" -version = "0.1.27" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1f29ebaa345f945cec9fbbc532eb307f0fdad8161f281b6369539c8d84876b3d" -dependencies = [ - "windows-sys 0.59.0", -] - [[package]] name = "scoped-tls" version = "1.0.1" @@ -3480,29 +3320,6 @@ version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c8c73432861711997c5d0a1f61275cb4e875884c820da5ff2cffad3d3577201c" -[[package]] -name = "security-framework" -version = "2.11.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "897b2245f0b511c87893af39b033e5ca9cce68824c4d7e7630b5a1d339658d02" -dependencies = [ - "bitflags 2.6.0", - "core-foundation 0.9.4", - "core-foundation-sys", - "libc", - "security-framework-sys", -] - -[[package]] -name = "security-framework-sys" -version = "2.13.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1863fd3768cd83c56a7f60faa4dc0d403f1b6df0a38c3c25f44b7894e45370d5" -dependencies = [ - "core-foundation-sys", - "libc", -] - [[package]] name = "self_cell" version = "0.10.3" @@ -3541,14 +3358,14 @@ checksum = "5a9bf7cf98d04a2b28aead066b7496853d4779c9cc183c440dbac457641e19a0" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] name = "serde_json" -version = "1.0.134" +version = "1.0.135" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d00f4175c42ee48b15416f6193a959ba3a0d67fc699a0db9ad12df9f83991c7d" +checksum = "2b0d7ba2887406110130a978386c4e1befb98c674b4fba677954e4db976630d9" dependencies = [ "itoa", "memchr", @@ -3564,7 +3381,7 @@ checksum = "6c64451ba24fc7a6a2d60fc75dd9c83c90903b19028d4eff35e88fc1e86564e9" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -3576,18 +3393,6 @@ dependencies = [ "serde", ] -[[package]] -name = "serde_urlencoded" -version = "0.7.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d3491c14715ca2294c4d6a88f15e84739788c1d030eed8c110436aafdaa2f3fd" -dependencies = [ - "form_urlencoded", - "itoa", - "ryu", - "serde", -] - [[package]] name = "sha1" version = "0.10.6" @@ -3650,13 +3455,13 @@ version = "0.18.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "922fd3eeab3bd820d76537ce8f582b1cf951eceb5475c28500c7457d9d17f53a" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "cursor-icon", "libc", "log", "memmap2", - "rustix 0.38.42", - "thiserror", + "rustix 0.38.43", + "thiserror 1.0.69", "wayland-backend", "wayland-client", "wayland-csd-frame", @@ -3677,16 +3482,6 @@ dependencies = [ "winapi", ] -[[package]] -name = "socket2" -version = "0.5.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c970269d99b64e60ec3bd6ad27270092a5394c4e309314b18ae3fe575695fbe8" -dependencies = [ - "libc", - "windows-sys 0.52.0", -] - [[package]] name = "spin" version = "0.9.8" @@ -3752,24 +3547,15 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.95" +version = "2.0.96" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "46f71c0377baf4ef1cc3e3402ded576dccc315800fbc62dfc7fe04b009773b4a" +checksum = "d5d0adab1ae378d7f53bdebc67a39f1f151407ef230f0ce2883572f5d8985c80" dependencies = [ "proc-macro2", "quote", "unicode-ident", ] -[[package]] -name = "sync_wrapper" -version = "1.0.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0bf256ce5efdfa370213c1dabab5935a12e49f2c58d15e9eac2870d3b4f27263" -dependencies = [ - "futures-core", -] - [[package]] name = "synstructure" version = "0.13.1" @@ -3778,28 +3564,7 @@ checksum = "c8af7666ab7b6390ab78131fb5b0fce11d6b7a6951602017c35fa82800708971" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", -] - -[[package]] -name = "system-configuration" -version = "0.6.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c879d448e9d986b661742763247d3693ed13609438cf3d006f51f5368a5ba6b" -dependencies = [ - "bitflags 2.6.0", - "core-foundation 0.9.4", - "system-configuration-sys", -] - -[[package]] -name = "system-configuration-sys" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e1d1b10ced5ca923a1fcb8d03e96b8d3268065d724548c0211415ff6ac6bac4" -dependencies = [ - "core-foundation-sys", - "libc", + "syn 2.0.96", ] [[package]] @@ -3812,7 +3577,7 @@ dependencies = [ "pkg-config", "strum", "strum_macros", - "thiserror", + "thiserror 1.0.69", "toml 0.5.11", "version-compare 0.0.10", ] @@ -3830,6 +3595,17 @@ dependencies = [ "version-compare 0.2.0", ] +[[package]] +name = "tar" +version = "0.4.43" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c65998313f8e17d0d553d28f91a0df93e4dbbbf770279c7bc21ca0f09ea1a1f6" +dependencies = [ + "filetime", + "libc", + "xattr", +] + [[package]] name = "target-lexicon" version = "0.12.16" @@ -3846,7 +3622,7 @@ dependencies = [ "fastrand 2.3.0", "getrandom", "once_cell", - "rustix 0.38.42", + "rustix 0.38.43", "windows-sys 0.59.0", ] @@ -3856,7 +3632,16 @@ version = "1.0.69" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b6aaf5339b578ea85b50e080feb250a3e8ae8cfcdff9a461c9ec2904bc923f52" dependencies = [ - "thiserror-impl", + "thiserror-impl 1.0.69", +] + +[[package]] +name = "thiserror" +version = "2.0.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d452f284b73e6d76dd36758a0c8684b1d5be31f92b89d07fd5822175732206fc" +dependencies = [ + "thiserror-impl 2.0.11", ] [[package]] @@ -3867,7 +3652,18 @@ checksum = "4fee6c4efc90059e10f81e6d42c60a18f76588c3d74cb83a0b242a2b6c7504c1" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", +] + +[[package]] +name = "thiserror-impl" +version = "2.0.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "26afc1baea8a989337eeb52b6e72a039780ce45c3edfcc9c5b9d112feeb173c2" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.96", ] [[package]] @@ -3881,6 +3677,25 @@ dependencies = [ "weezl", ] +[[package]] +name = "time" +version = "0.3.37" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "35e7868883861bd0e56d9ac6efcaaca0d6d5d82a2a7ec8209ff492c07cf37b21" +dependencies = [ + "deranged", + "num-conv", + "powerfmt", + "serde", + "time-core", +] + +[[package]] +name = "time-core" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" + [[package]] name = "tinystr" version = "0.7.6" @@ -3891,54 +3706,6 @@ dependencies = [ "zerovec", ] -[[package]] -name = "tokio" -version = "1.43.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d61fa4ffa3de412bfea335c6ecff681de2b609ba3c77ef3e00e521813a9ed9e" -dependencies = [ - "backtrace", - "bytes", - "libc", - "mio", - "pin-project-lite", - "socket2 0.5.8", - "windows-sys 0.52.0", -] - -[[package]] -name = "tokio-native-tls" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bbae76ab933c85776efabc971569dd6119c580d8f5d448769dec1764bf796ef2" -dependencies = [ - "native-tls", - "tokio", -] - -[[package]] -name = "tokio-rustls" -version = "0.26.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f6d0975eaace0cf0fcadee4e4aaa5da15b5c079146f2cffb67c113be122bf37" -dependencies = [ - "rustls", - "tokio", -] - -[[package]] -name = "tokio-util" -version = "0.7.13" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d7fcaa8d55a2bdd6b83ace262b016eca0d79ee02818c5c1bcdf0305114081078" -dependencies = [ - "bytes", - "futures-core", - "futures-sink", - "pin-project-lite", - "tokio", -] - [[package]] name = "toml" version = "0.5.11" @@ -3990,36 +3757,9 @@ dependencies = [ "serde", "serde_spanned", "toml_datetime", - "winnow 0.6.22", + "winnow 0.6.24", ] -[[package]] -name = "tower" -version = "0.5.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d039ad9159c98b70ecfd540b2573b97f7f52c3e8d9f8ad57a24b916a536975f9" -dependencies = [ - "futures-core", - "futures-util", - "pin-project-lite", - "sync_wrapper", - "tokio", - "tower-layer", - "tower-service", -] - -[[package]] -name = "tower-layer" -version = "0.3.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "121c2a6cda46980bb0fcd1647ffaf6cd3fc79a013de288782836f6df9c48780e" - -[[package]] -name = "tower-service" -version = "0.3.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8df9b6e13f2d32c91b9bd719c00d1958837bc7dec474d94952798cc8e69eeec3" - [[package]] name = "tracing" version = "0.1.41" @@ -4039,7 +3779,7 @@ checksum = "395ae124c09f9e6918a2310af6038fba074bcf474ac352496d5910dd59a2226d" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -4051,12 +3791,6 @@ dependencies = [ "once_cell", ] -[[package]] -name = "try-lock" -version = "0.2.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b" - [[package]] name = "type-map" version = "0.5.0" @@ -4119,6 +3853,22 @@ version = "0.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" +[[package]] +name = "ureq" +version = "2.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "02d1a66277ed75f640d608235660df48c8e3c19f3b4edb6a263315626cc3c01d" +dependencies = [ + "base64", + "flate2", + "log", + "once_cell", + "rustls", + "rustls-pki-types", + "url", + "webpki-roots", +] + [[package]] name = "url" version = "2.5.4" @@ -4159,12 +3909,6 @@ version = "1.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3ef4c4aa54d5d05a279399bfa921ec387b7aba77caf7a682ae8d86785b8fdad2" -[[package]] -name = "vcpkg" -version = "0.2.15" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" - [[package]] name = "version-compare" version = "0.0.10" @@ -4199,15 +3943,6 @@ dependencies = [ "winapi-util", ] -[[package]] -name = "want" -version = "0.3.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e" -dependencies = [ - "try-lock", -] - [[package]] name = "wasi" version = "0.11.0+wasi-snapshot-preview1" @@ -4216,34 +3951,35 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.99" +version = "0.2.100" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a474f6281d1d70c17ae7aa6a613c87fce69a127e2624002df63dcb39d6cf6396" +checksum = "1edc8929d7499fc4e8f0be2262a241556cfc54a0bea223790e71446f2aab1ef5" dependencies = [ "cfg-if 1.0.0", "once_cell", + "rustversion", "wasm-bindgen-macro", ] [[package]] name = "wasm-bindgen-backend" -version = "0.2.99" +version = "0.2.100" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f89bb38646b4f81674e8f5c3fb81b562be1fd936d84320f3264486418519c79" +checksum = "2f0a0651a5c2bc21487bde11ee802ccaf4c51935d0d3d42a6101f98161700bc6" dependencies = [ "bumpalo", "log", "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-futures" -version = "0.4.49" +version = "0.4.50" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "38176d9b44ea84e9184eff0bc34cc167ed044f816accfe5922e54d84cf48eca2" +checksum = "555d470ec0bc3bb57890405e5d4322cc9ea83cebb085523ced7be4144dac1e61" dependencies = [ "cfg-if 1.0.0", "js-sys", @@ -4254,9 +3990,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro" -version = "0.2.99" +version = "0.2.100" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2cc6181fd9a7492eef6fef1f33961e3695e4579b9872a6f7c83aee556666d4fe" +checksum = "7fe63fc6d09ed3792bd0897b314f53de8e16568c2b3f7982f468c0bf9bd0b407" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -4264,22 +4000,25 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.99" +version = "0.2.100" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "30d7a95b763d3c45903ed6c81f156801839e5ee968bb07e534c44df0fcd330c2" +checksum = "8ae87ea40c9f689fc23f209965b6fb8a99ad69aeeb0231408be24920604395de" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.99" +version = "0.2.100" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "943aab3fdaaa029a6e0271b35ea10b72b943135afe9bffca82384098ad0e06a6" +checksum = "1a05d73b933a847d6cccdda8f838a22ff101ad9bf93e33684f39c1f5f0eece3d" +dependencies = [ + "unicode-ident", +] [[package]] name = "wayland-backend" @@ -4289,7 +4028,7 @@ checksum = "056535ced7a150d45159d3a8dc30f91a2e2d588ca0b23f70e56033622b8016f6" dependencies = [ "cc", "downcast-rs", - "rustix 0.38.42", + "rustix 0.38.43", "scoped-tls", "smallvec", "wayland-sys", @@ -4301,8 +4040,8 @@ version = "0.31.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b66249d3fc69f76fd74c82cc319300faa554e9d865dab1f7cd66cc20db10b280" dependencies = [ - "bitflags 2.6.0", - "rustix 0.38.42", + "bitflags 2.7.0", + "rustix 0.38.43", "wayland-backend", "wayland-scanner", ] @@ -4313,7 +4052,7 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "625c5029dbd43d25e6aa9615e88b829a5cad13b2819c4ae129fdbb7c31ab4c7e" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "cursor-icon", "wayland-backend", ] @@ -4324,7 +4063,7 @@ version = "0.31.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "32b08bc3aafdb0035e7fe0fdf17ba0c09c268732707dca4ae098f60cb28c9e4c" dependencies = [ - "rustix 0.38.42", + "rustix 0.38.43", "wayland-client", "xcursor", ] @@ -4335,7 +4074,7 @@ version = "0.31.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8f81f365b8b4a97f422ac0e8737c438024b5951734506b0e1d775c73030561f4" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "wayland-backend", "wayland-client", "wayland-scanner", @@ -4347,7 +4086,7 @@ version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ad1f61b76b6c2d8742e10f9ba5c3737f6530b4c243132c2a2ccc8aa96fe25cd6" dependencies = [ - "bitflags 2.6.0", + "bitflags 2.7.0", "wayland-backend", "wayland-client", "wayland-protocols", @@ -4378,14 +4117,23 @@ dependencies = [ [[package]] name = "web-sys" -version = "0.3.76" +version = "0.3.77" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "04dd7223427d52553d3702c004d3b2fe07c148165faa56313cb00211e31c12bc" +checksum = "33b6dd2ef9186f1f2072e409e99cd22a975331a6b3591b12c764e0e55c60d5d2" dependencies = [ "js-sys", "wasm-bindgen", ] +[[package]] +name = "webpki-roots" +version = "0.26.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5d642ff16b7e79272ae451b7322067cdc17cadf68c23264be9d94a32319efe7e" +dependencies = [ + "rustls-pki-types", +] + [[package]] name = "weezl" version = "0.1.8" @@ -4511,7 +4259,7 @@ checksum = "f6fc35f58ecd95a9b71c4f2329b911016e6bec66b3f2e6a4aad86bd2e99e2f9b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -4522,7 +4270,7 @@ checksum = "2bbd5b46c938e506ecbce286b6628a02171d56153ba733b6c741fc627ec9579b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -4533,7 +4281,7 @@ checksum = "08990546bf4edef8f431fa6326e032865f27138718c587dc21bc0265bbcb57cc" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -4544,18 +4292,7 @@ checksum = "053c4c462dc91d3b1504c6fe5a726dd15e216ba718e84a0e46a88fbe5ded3515" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", -] - -[[package]] -name = "windows-registry" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e400001bb720a623c1c69032f8e3e4cf09984deec740f007dd2b03ec864804b0" -dependencies = [ - "windows-result 0.2.0", - "windows-strings", - "windows-targets 0.52.6", + "syn 2.0.96", ] [[package]] @@ -4811,9 +4548,9 @@ dependencies = [ [[package]] name = "winnow" -version = "0.6.22" +version = "0.6.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39281189af81c07ec09db316b302a3e67bf9bd7cbf6c820b50e35fee9c2fa980" +checksum = "c8d71a593cc5c42ad7876e2c1fda56f314f3754c084128833e64f1345ff8a03a" dependencies = [ "memchr", ] @@ -4862,6 +4599,17 @@ dependencies = [ "zbus 1.9.3", ] +[[package]] +name = "xattr" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e105d177a3871454f754b33bb0ee637ecaaac997446375fd3e5d43a2ed00c909" +dependencies = [ + "libc", + "linux-raw-sys 0.4.15", + "rustix 0.38.43", +] + [[package]] name = "xcb" version = "1.5.0" @@ -4895,6 +4643,15 @@ version = "0.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b9cc00251562a284751c9973bace760d86c0276c471b4be569fe6b068ee97a56" +[[package]] +name = "xz2" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "388c44dc09d76f1536602ead6d325eb532f5c122f17782bd57fb47baeeb767e2" +dependencies = [ + "lzma-sys", +] + [[package]] name = "yoke" version = "0.7.5" @@ -4915,7 +4672,7 @@ checksum = "2380878cad4ac9aac1e2435f3eb4020e8374b5f13c296cb75b4620ff8e229154" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", "synstructure", ] @@ -4959,7 +4716,7 @@ dependencies = [ "async-trait", "blocking", "enumflags2 0.7.10", - "event-listener 5.3.1", + "event-listener 5.4.0", "futures-core", "futures-sink", "futures-util", @@ -5001,7 +4758,7 @@ dependencies = [ "proc-macro-crate 3.2.0", "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", "zvariant_utils", ] @@ -5034,7 +4791,7 @@ checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] [[package]] @@ -5054,7 +4811,7 @@ checksum = "595eed982f7d355beb85837f651fa22e90b3c044842dc7f2c2842c086f295808" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", "synstructure", ] @@ -5063,6 +4820,20 @@ name = "zeroize" version = "1.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ced3678a2879b30306d323f4542626697a464a97c0a07c9aebf7ebca65cd4dde" +dependencies = [ + "zeroize_derive", +] + +[[package]] +name = "zeroize_derive" +version = "1.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ce36e65b0d2999d2aafac989fb249189a141aee1f53c612c1f37d72631959f69" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.96", +] [[package]] name = "zerovec" @@ -5083,7 +4854,78 @@ checksum = "6eafa6dfb17584ea3e2bd6e76e0cc15ad7af12b09abdd1ca55961bed9b1063c6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", +] + +[[package]] +name = "zip" +version = "2.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ae9c1ea7b3a5e1f4b922ff856a129881167511563dc219869afe3787fc0c1a45" +dependencies = [ + "aes", + "arbitrary", + "bzip2", + "constant_time_eq", + "crc32fast", + "crossbeam-utils", + "deflate64", + "displaydoc", + "flate2", + "hmac", + "indexmap", + "lzma-rs", + "memchr", + "pbkdf2", + "rand", + "sha1", + "thiserror 2.0.11", + "time", + "zeroize", + "zopfli", + "zstd", +] + +[[package]] +name = "zopfli" +version = "0.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e5019f391bac5cf252e93bbcc53d039ffd62c7bfb7c150414d61369afe57e946" +dependencies = [ + "bumpalo", + "crc32fast", + "lockfree-object-pool", + "log", + "once_cell", + "simd-adler32", +] + +[[package]] +name = "zstd" +version = "0.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fcf2b778a664581e31e389454a7072dab1647606d44f7feea22cd5abb9c9f3f9" +dependencies = [ + "zstd-safe", +] + +[[package]] +name = "zstd-safe" +version = "7.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "54a3ab4db68cea366acc5c897c7b4d4d1b8994a9cd6e6f841f8964566a419059" +dependencies = [ + "zstd-sys", +] + +[[package]] +name = "zstd-sys" +version = "2.0.13+zstd.1.5.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "38ff0f21cfee8f97d94cef41359e0c89aa6113028ab0291aa8ca0038995a95aa" +dependencies = [ + "cc", + "pkg-config", ] [[package]] @@ -5158,7 +5000,7 @@ dependencies = [ "proc-macro-crate 3.2.0", "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", "zvariant_utils", ] @@ -5170,5 +5012,5 @@ checksum = "c51bcff7cc3dbb5055396bcf774748c3dab426b4b8659046963523cee4808340" dependencies = [ "proc-macro2", "quote", - "syn 2.0.95", + "syn 2.0.96", ] diff --git a/core/Cargo.toml b/core/Cargo.toml index 1ba1c21..5fe5dd6 100644 --- a/core/Cargo.toml +++ b/core/Cargo.toml @@ -4,14 +4,14 @@ version = "0.1.0" edition = "2021" [features] -cmd = [] +cmd = ["ffmpeg-sidecar"] gtk = ["adw", "chrono", "glib", "subprocess"] [dependencies] adw = { version = "0.2.1", package = "libadwaita", features = ["gtk_v4_6"], optional = true } anyhow = "1.0.86" chrono = { version = "0.4.19", optional = true } -ffmpeg-sidecar = "1.1.0" +ffmpeg-sidecar = { version = "2.0.5", optional = true } glib = { version = "0.10.3", optional = true } open = "5.1.4" subprocess = {version = "0.2.6", optional = true } diff --git a/core/src/ffmpeg_linux.rs b/core/src/ffmpeg_linux.rs index 50cabf3..ecd6894 100644 --- a/core/src/ffmpeg_linux.rs +++ b/core/src/ffmpeg_linux.rs @@ -2,21 +2,32 @@ use adw::gtk::{CheckButton, ComboBoxText, Entry, FileChooserNative, SpinButton}; #[cfg(feature = "gtk")] use adw::gtk::prelude::*; -use anyhow::{anyhow, Error, Result}; +use anyhow::{anyhow, Result}; +#[cfg(feature = "cmd")] +use anyhow::Error; #[cfg(feature = "gtk")] use chrono::Utc; +#[cfg(feature = "cmd")] use ffmpeg_sidecar::child::FfmpegChild; +#[cfg(feature = "cmd")] use ffmpeg_sidecar::command::FfmpegCommand; use tempfile; -use std::{cell::RefCell, time::Instant}; +use std::cell::RefCell; use std::path::Path; #[cfg(feature = "gtk")] use std::path::PathBuf; +use std::process::Command; +#[cfg(feature = "gtk")] +use std::process::Child; use std::rc::Rc; use std::thread::sleep; use std::time::Duration; +#[cfg(feature = "cmd")] +use std::time::Instant; -use crate::utils::{is_input_audio_record, is_output_audio_record, is_valide, is_video_record, RecordMode}; +use crate::utils::{is_input_audio_record, is_output_audio_record, is_video_record, RecordMode}; +#[cfg(feature = "cmd")] +use crate::utils::is_valide; #[cfg(feature = "cmd")] #[derive(Clone)] @@ -53,9 +64,9 @@ pub struct Ffmpeg { pub temp_video_filename: String, pub saved_filename: String, pub height: Option, - pub input_audio_process: Option>>, - pub output_audio_process: Option>>, - pub video_process: Option>>, + pub input_audio_process: Option>>, + pub output_audio_process: Option>>, + pub video_process: Option>>, pub audio_record_bitrate: SpinButton, pub record_delay: SpinButton, pub record_frames: SpinButton, @@ -330,7 +341,7 @@ impl Ffmpeg { (|| anyhow!("Unable to get height value"))?); let ffmpeg_convert = format!("ffmpeg -i file:{} -filter_complex '{}' \ -loop 0 {} -y", &self.temp_video_filename,filter,&self.filename); - std::process::Command::new("sh").arg("-c").arg(&ffmpeg_convert).output()?; + Command::new("sh").arg("-c").arg(&ffmpeg_convert).output()?; } } else if is_input_audio_record(&self.temp_input_audio_filename) { // Validate audio file integrity @@ -394,7 +405,7 @@ impl Ffmpeg { // Kill process pub fn kill(&mut self) -> Result<()> { if self.video_process.is_some() { - std::process::Command::new("kill") + Command::new("kill") .arg(format!( "{}", self.video_process @@ -405,7 +416,7 @@ impl Ffmpeg { )).output()?; } if self.input_audio_process.is_some() { - std::process::Command::new("kill") + Command::new("kill") .arg(format!( "{}", self.input_audio_process @@ -416,7 +427,7 @@ impl Ffmpeg { )).output()?; } if self.output_audio_process.is_some() { - std::process::Command::new("kill") + Command::new("kill") .arg(format!( "{}", self.output_audio_process @@ -467,7 +478,7 @@ impl Ffmpeg { x, y ); - let mut ffmpeg_command = FfmpegCommand::new(); + let mut ffmpeg_command = Command::new("ffmpeg"); let format = "x11grab"; self.height = Some(height); let filename = self.saved_filename.clone(); @@ -500,14 +511,14 @@ impl Ffmpeg { RecordMode::Screen => { let width = width as f32 * 0.95; let height = height as f32 * 0.95; - ffmpeg_command.size(width as u32, height as u32); + ffmpeg_command.args(["-s", &width.to_string(), &height.to_string()]); }, _=> { - ffmpeg_command.size(width.into(), height.into()); + ffmpeg_command.args(["-s", &width.to_string(), &height.to_string()]); } } } else { - ffmpeg_command.size(width.into(), height.into()); + ffmpeg_command.args(["-s", &width.to_string(), &height.to_string()]); } // Show grabbed area @@ -533,8 +544,8 @@ impl Ffmpeg { } // Video format && input - ffmpeg_command.format(format) - .input(display); + ffmpeg_command.args(["-f", format]) + .args(["-i", &display]); // Disable bitrate if value is zero if self.video_record_bitrate.value() as u16 > 0 { @@ -572,7 +583,7 @@ impl Ffmpeg { } }, ]); - ffmpeg_command.overwrite(); + ffmpeg_command.arg("-y"); // Sleep for delay sleep(Duration::from_secs(self.record_delay.value() as u64)); @@ -585,13 +596,23 @@ impl Ffmpeg { // Stop video recording pub fn stop_video(&mut self) -> Result<()> { - // Quit the process to stop recording + // Kill the process to stop recording if self.video_process.is_some() { + Command::new("kill") + .arg(format!( + "{}", + self.video_process + .clone() + .ok_or_else(|| anyhow!("Failed to get video_process ID."))? + .borrow_mut().id() + )) + .output()?; + self.video_process .clone() .ok_or_else(|| anyhow!("Not exiting the video recording process successfully."))? .borrow_mut() - .quit()?; + .wait()?; } Ok(()) } @@ -604,12 +625,12 @@ impl Ffmpeg { .keep()?; self.temp_input_audio_filename = Path::new(&input_audio_tempfile.1).to_string_lossy() .to_string(); - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("pulse") - .input(&self.audio_input_id.active_id() + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "pulse"]) + .args(["-i", &self.audio_input_id.active_id() .ok_or_else(|| anyhow!("Failed to get audio input ID."))? - ) - .format("ogg"); + ]) + .args(["-f", "ogg"]); // Disable bitrate if value is zero if self.audio_record_bitrate.value() as u16 > 0 { ffmpeg_command.args([ @@ -620,7 +641,7 @@ impl Ffmpeg { // Remove metadate ffmpeg_command.args(["-map_metadata", "-1"]); ffmpeg_command.arg(&self.temp_input_audio_filename); - ffmpeg_command.overwrite(); + ffmpeg_command.arg("-y"); // Sleep for delay if !is_video_record(&self.temp_video_filename) { @@ -634,13 +655,23 @@ impl Ffmpeg { // Stop audio input recording pub fn stop_input_audio(&mut self) -> Result<()> { - // Quit the process to stop recording + // Kill the process to stop recording if self.input_audio_process.is_some() { + Command::new("kill") + .arg(format!( + "{}", + self.input_audio_process + .clone() + .ok_or_else(|| anyhow!("Failed to get input_audio_process ID."))? + .borrow_mut().id() + )) + .output()?; + self.input_audio_process .clone() .ok_or_else(|| anyhow!("Not exiting the input audio recording process successfully."))? .borrow_mut() - .quit()?; + .wait()?; } Ok(()) } @@ -653,14 +684,14 @@ impl Ffmpeg { .keep()?; self.temp_output_audio_filename = Path::new(&output_audio_tempfile.1).to_string_lossy() .to_string(); - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("pulse") - .input(&self.audio_output_id) - .format("ogg"); + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "pulse"]) + .args(["-i", &self.audio_output_id]) + .args(["-f", "ogg"]); // Remove metadate ffmpeg_command.args(["-map_metadata", "-1"]); ffmpeg_command.arg(&self.temp_output_audio_filename); - ffmpeg_command.overwrite(); + ffmpeg_command.arg("-y"); // Sleep for delay if !is_video_record(&self.temp_video_filename) && !is_input_audio_record(&self.temp_input_audio_filename) { @@ -674,13 +705,23 @@ impl Ffmpeg { // Stop audio output recording pub fn stop_output_audio(&mut self) -> Result<()> { - // Quit the process to stop recording + // Kill the process to stop recording if self.output_audio_process.is_some() { + Command::new("kill") + .arg(format!( + "{}", + self.output_audio_process + .clone() + .ok_or_else(|| anyhow!("Failed to get output_audio_process ID."))? + .borrow_mut().id() + )) + .output()?; + self.output_audio_process .clone() .ok_or_else(|| anyhow!("Not exiting the output audio recording process successfully."))? .borrow_mut() - .quit()?; + .wait()?; } Ok(()) } @@ -689,44 +730,29 @@ impl Ffmpeg { pub fn merge(&mut self) -> Result<()> { if is_video_record(&self.temp_video_filename) { if self.output != "gif" { - // Validate video file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_video_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } - } - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.input(&self.temp_video_filename); - ffmpeg_command.format("ogg"); + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-i", &self.temp_video_filename]); + ffmpeg_command.args(["-f", "ogg"]); if is_input_audio_record(&self.temp_input_audio_filename) { - ffmpeg_command.input(&self.temp_input_audio_filename); + ffmpeg_command.args(["-i", &self.temp_input_audio_filename]); } if is_output_audio_record(&self.temp_output_audio_filename) { - ffmpeg_command.input(&self.temp_output_audio_filename); + ffmpeg_command.args(["-i", &self.temp_output_audio_filename]); } ffmpeg_command.args([ "-c:a", "aac", &self.saved_filename.clone() ]); - ffmpeg_command.overwrite() - .spawn()? - .wait()?; - } else { - // Validate video file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_video_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } + ffmpeg_command.arg("-y"); + let program = ffmpeg_command.get_program().to_string_lossy().to_string(); + let args: Vec = ffmpeg_command.get_args().map(|arg| arg.to_string_lossy().into_owned()).collect(); + let mut merge_command = program; + for arg in args { + merge_command.push_str(&format!(" {}", arg)); } + adw::glib::spawn_command_line_async(merge_command)?; + } else { // Convert MP4 to GIF let filter = format!("fps={},scale={}:-1:flags=lanczos,split[s0][s1];[s0]palettegen[p];[s1][p]paletteuse", self.record_frames.value() as u16, @@ -736,54 +762,44 @@ impl Ffmpeg { -loop 0 {} -y", &self.temp_video_filename,filter, &self.saved_filename .clone()); - std::process::Command::new("sh").arg("-c").arg(&ffmpeg_convert).output()?; + adw::glib::spawn_command_line_async(ffmpeg_convert)?; } } else if is_input_audio_record(&self.temp_input_audio_filename) { - // Validate audio file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_input_audio_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } - } // If only audio is recording then convert it to chosen format - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("ogg"); - ffmpeg_command.input(&self.temp_input_audio_filename); + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "ogg"]); + ffmpeg_command.args(["-i", &self.temp_input_audio_filename]); if is_output_audio_record(&self.temp_output_audio_filename) { - ffmpeg_command.input(&self.temp_output_audio_filename); + ffmpeg_command.args(["-i", &self.temp_output_audio_filename]); } ffmpeg_command.args([ "-c:a", "aac", &self.saved_filename - .clone() - ]).overwrite() - .spawn()? - .wait()?; - } else { - // Validate audio file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_output_audio_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } + .clone(), + "-y" + ]); + let program = ffmpeg_command.get_program().to_string_lossy().to_string(); + let args: Vec = ffmpeg_command.get_args().map(|arg| arg.to_string_lossy().into_owned()).collect(); + let mut merge_command = program; + for arg in args { + merge_command.push_str(&format!(" {}", arg)); } + adw::glib::spawn_command_line_async(merge_command)?; + } else { // If only output audio is recording then convert it to chosen format - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("ogg"); - ffmpeg_command.input(&self.temp_output_audio_filename); - ffmpeg_command.arg(&self.saved_filename - .clone()) - .overwrite() - .spawn()? - .wait()?; + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "ogg"]); + ffmpeg_command.args(["-i", &self.temp_output_audio_filename]); + ffmpeg_command.arg(&self.saved_filename.clone()); + ffmpeg_command.arg("-y"); + let program = ffmpeg_command.get_program().to_string_lossy().to_string(); + let args: Vec = ffmpeg_command.get_args().map(|arg| arg.to_string_lossy().into_owned()).collect(); + let mut merge_command = program; + for arg in args { + merge_command.push_str(&format!(" {}", arg)); + } + adw::glib::spawn_command_line_async(merge_command)?; } Ok(()) } @@ -802,36 +818,33 @@ impl Ffmpeg { // Kill process pub fn kill(&mut self) -> Result<()> { if self.video_process.is_some() { - std::process::Command::new("kill") + Command::new("kill") .arg(format!( "{}", self.video_process .clone() .ok_or_else(|| anyhow!("Unable to kill the video recording process successfully."))? - .borrow_mut() - .as_inner().id() + .borrow_mut().id() )).output()?; } if self.input_audio_process.is_some() { - std::process::Command::new("kill") + Command::new("kill") .arg(format!( "{}", self.input_audio_process .clone() .ok_or_else(|| anyhow!("Unable to kill the intput audio recording process successfully."))? - .borrow_mut() - .as_inner().id() + .borrow_mut().id() )).output()?; } if self.output_audio_process.is_some() { - std::process::Command::new("kill") + Command::new("kill") .arg(format!( "{}", self.output_audio_process .clone() .ok_or_else(|| anyhow!("Unable to kill the output audio recording process successfully."))? - .borrow_mut() - .as_inner().id() + .borrow_mut().id() )).output()?; } Ok(()) diff --git a/core/src/ffmpeg_windows.rs b/core/src/ffmpeg_windows.rs index 494c86b..a4d3f35 100644 --- a/core/src/ffmpeg_windows.rs +++ b/core/src/ffmpeg_windows.rs @@ -2,21 +2,32 @@ use adw::gtk::{CheckButton, ComboBoxText, Entry, FileChooserNative, SpinButton}; #[cfg(feature = "gtk")] use adw::gtk::prelude::*; -use anyhow::{anyhow, Error, Result}; +use anyhow::{anyhow, Result}; +#[cfg(feature = "cmd")] +use anyhow::Error; #[cfg(feature = "gtk")] use chrono::Utc; +#[cfg(feature = "cmd")] use ffmpeg_sidecar::child::FfmpegChild; +#[cfg(feature = "cmd")] use ffmpeg_sidecar::command::FfmpegCommand; use tempfile; -use std::{cell::RefCell, time::Instant}; +use std::cell::RefCell; use std::path::Path; #[cfg(feature = "gtk")] use std::path::PathBuf; +use std::process::Command; +#[cfg(feature = "gtk")] +use std::process::Child; use std::rc::Rc; use std::thread::sleep; use std::time::Duration; +#[cfg(feature = "cmd")] +use std::time::Instant; -use crate::utils::{is_input_audio_record, is_output_audio_record, is_valide, is_video_record, RecordMode}; +use crate::utils::{is_input_audio_record, is_output_audio_record, is_video_record, RecordMode}; +#[cfg(feature = "cmd")] +use crate::utils::is_valide; #[cfg(feature = "cmd")] #[derive(Clone)] @@ -55,9 +66,9 @@ pub struct Ffmpeg { pub window_title: String, pub saved_filename: String, pub height: Option, - pub input_audio_process: Option>>, - pub output_audio_process: Option>>, - pub video_process: Option>>, + pub input_audio_process: Option>>, + pub output_audio_process: Option>>, + pub video_process: Option>>, pub audio_record_bitrate: SpinButton, pub record_delay: SpinButton, pub record_frames: SpinButton, @@ -318,7 +329,7 @@ impl Ffmpeg { (|| anyhow!("Unable to get height value"))?); let ffmpeg_convert = format!("ffmpeg -i file:{} -filter_complex '{}' \ -loop 0 {} -y", &self.temp_video_filename,filter,&self.filename); - std::process::Command::new("sh").arg("-c").arg(&ffmpeg_convert).output()?; + Command::new("sh").arg("-c").arg(&ffmpeg_convert).output()?; } } else if is_input_audio_record(&self.temp_input_audio_filename) { // Validate audio file integrity @@ -387,7 +398,7 @@ impl Ffmpeg { .ok_or_else(|| anyhow!("Unable to kill the video recording process successfully."))? .borrow_mut() .as_inner().id(); - std::process::Command::new("taskkill") + Command::new("taskkill") .arg("/PID") .arg(pid.to_string()) .arg("/F") @@ -399,7 +410,7 @@ impl Ffmpeg { .ok_or_else(|| anyhow!("Unable to kill the input audio recording process successfully."))? .borrow_mut() .as_inner().id(); - std::process::Command::new("taskkill") + Command::new("taskkill") .arg("/PID") .arg(pid.to_string()) .arg("/F") @@ -411,7 +422,7 @@ impl Ffmpeg { .ok_or_else(|| anyhow!("Unable to kill the output audio recording process successfully."))? .borrow_mut() .as_inner().id(); - std::process::Command::new("taskkill") + Command::new("taskkill") .arg("/PID") .arg(pid.to_string()) .arg("/F") @@ -454,7 +465,7 @@ impl Ffmpeg { RecordMode::Screen => "desktop", RecordMode::Window => &format!("title={}", &self.window_title), }; - let mut ffmpeg_command = FfmpegCommand::new(); + let mut ffmpeg_command = Command::new("ffmpeg"); let format = "gdigrab"; let filename = self.saved_filename.clone(); self.output = Path::new(&filename).extension() @@ -480,7 +491,7 @@ impl Ffmpeg { .to_string(); } // Video format - ffmpeg_command.format(format); + ffmpeg_command.arg(format); // Show grabbed area if self.show_area.is_active() { @@ -501,14 +512,14 @@ impl Ffmpeg { // Record video with specified width and hight if let RecordMode::Area = mode { - ffmpeg_command.size(width.into(), height.into()).args([ + ffmpeg_command.args(["-s", &width.to_string(), &height.to_string()]).args([ "-offset_x", &x.to_string(), "-offset_y", &y.to_string() ]); } // input - ffmpeg_command.input(display); + ffmpeg_command.args(["-i", display]); // Disable bitrate if value is zero if self.video_record_bitrate.value() as u16 > 0 { @@ -545,7 +556,7 @@ impl Ffmpeg { } }, ]); - ffmpeg_command.overwrite(); + ffmpeg_command.arg("-y"); // Sleep for delay sleep(Duration::from_secs(self.record_delay.value() as u64)); @@ -558,13 +569,23 @@ impl Ffmpeg { // Stop video recording pub fn stop_video(&mut self) -> Result<()> { - // Quit the process to stop recording + // Kill the process to stop recording if self.video_process.is_some() { + Command::new("kill") + .arg(format!( + "{}", + self.video_process + .clone() + .ok_or_else(|| anyhow!("Failed to get video_process ID."))? + .borrow_mut().id() + )) + .output()?; + self.video_process .clone() .ok_or_else(|| anyhow!("Not exiting the video recording process successfully."))? .borrow_mut() - .quit()?; + .wait()?; } Ok(()) } @@ -577,12 +598,12 @@ impl Ffmpeg { .keep()?; self.temp_input_audio_filename = Path::new(&input_audio_tempfile.1).to_string_lossy() .to_string(); - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("dshow") - .input(format!("audio=\"{}\"", &self.audio_input_id.active_text() + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "dshow"]) + .args(["-i", &format!("audio=\"{}\"", &self.audio_input_id.active_text() .ok_or_else(|| anyhow!("Failed to get audio input source."))?) - ) - .format("ogg"); + ]) + .args(["-f", "ogg"]); // Disable bitrate if value is zero if self.audio_record_bitrate.value() as u16 > 0 { ffmpeg_command.args([ @@ -593,7 +614,7 @@ impl Ffmpeg { // Remove metadate ffmpeg_command.args(["-map_metadata", "-1"]); ffmpeg_command.arg(&self.temp_input_audio_filename); - ffmpeg_command.overwrite(); + ffmpeg_command.arg("-y"); // Sleep for delay if !is_video_record(&self.temp_video_filename) { @@ -607,13 +628,23 @@ impl Ffmpeg { // Stop audio input recording pub fn stop_input_audio(&mut self) -> Result<()> { - // Quit the process to stop recording + // Kill the process to stop recording if self.input_audio_process.is_some() { + Command::new("kill") + .arg(format!( + "{}", + self.input_audio_process + .clone() + .ok_or_else(|| anyhow!("Failed to get input_audio_process ID."))? + .borrow_mut().id() + )) + .output()?; + self.input_audio_process .clone() .ok_or_else(|| anyhow!("Not exiting the input audio recording process successfully."))? .borrow_mut() - .quit()?; + .wait()?; } Ok(()) } @@ -626,14 +657,14 @@ impl Ffmpeg { .keep()?; self.temp_output_audio_filename = Path::new(&output_audio_tempfile.1).to_string_lossy() .to_string(); - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("dshow") - .input(format!("audio=\"{}\"", &self.audio_output_id)) - .format("ogg"); + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "dshow"]) + .args(["-i", &format!("audio=\"{}\"", &self.audio_output_id)]) + .args(["-f", "ogg"]); // Remove metadate ffmpeg_command.args(["-map_metadata", "-1"]); ffmpeg_command.arg(&self.temp_output_audio_filename); - ffmpeg_command.overwrite(); + ffmpeg_command.arg("-y"); // Sleep for delay if !is_video_record(&self.temp_video_filename) && !is_input_audio_record(&self.temp_input_audio_filename) { @@ -647,13 +678,23 @@ impl Ffmpeg { // Stop audio output recording pub fn stop_output_audio(&mut self) -> Result<()> { - // Quit the process to stop recording + // Kill the process to stop recording if self.output_audio_process.is_some() { + Command::new("kill") + .arg(format!( + "{}", + self.output_audio_process + .clone() + .ok_or_else(|| anyhow!("Failed to get output_audio_process ID."))? + .borrow_mut().id() + )) + .output()?; + self.output_audio_process .clone() .ok_or_else(|| anyhow!("Not exiting the output audio recording process successfully."))? .borrow_mut() - .quit()?; + .wait()?; } Ok(()) } @@ -662,45 +703,29 @@ impl Ffmpeg { pub fn merge(&mut self) -> Result<()> { if is_video_record(&self.temp_video_filename) { if self.output != "gif" { - // Validate video file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_video_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } - } - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.input(&self.temp_video_filename); - ffmpeg_command.format("ogg"); + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-i", &self.temp_video_filename]); + ffmpeg_command.args(["-f", "ogg"]); if is_input_audio_record(&self.temp_input_audio_filename) { - ffmpeg_command.input(&self.temp_input_audio_filename); + ffmpeg_command.args(["-i", &self.temp_input_audio_filename]); } if is_output_audio_record(&self.temp_output_audio_filename) { - ffmpeg_command.input(&self.temp_output_audio_filename); + ffmpeg_command.args(["-i", &self.temp_output_audio_filename]); } ffmpeg_command.args([ "-c:a", "aac", - &self.saved_filename - .clone() + &self.saved_filename.clone() ]); - ffmpeg_command.overwrite() - .spawn()? - .wait()?; - } else { - // Validate video file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_video_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } + ffmpeg_command.arg("-y"); + let program = ffmpeg_command.get_program().to_string_lossy().to_string(); + let args: Vec = ffmpeg_command.get_args().map(|arg| arg.to_string_lossy().into_owned()).collect(); + let mut merge_command = program; + for arg in args { + merge_command.push_str(&format!(" {}", arg)); } + adw::glib::spawn_command_line_async(merge_command)?; + } else { // Convert MP4 to GIF let filter = format!("fps={},scale={}:-1:flags=lanczos,split[s0][s1];[s0]palettegen[p];[s1][p]paletteuse", self.record_frames.value() as u16, @@ -710,54 +735,44 @@ impl Ffmpeg { -loop 0 {} -y", &self.temp_video_filename,filter, &self.saved_filename .clone()); - std::process::Command::new("sh").arg("-c").arg(&ffmpeg_convert).output()?; + adw::glib::spawn_command_line_async(ffmpeg_convert)?; } } else if is_input_audio_record(&self.temp_input_audio_filename) { - // Validate audio file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_input_audio_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } - } // If only audio is recording then convert it to chosen format - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("ogg"); - ffmpeg_command.input(&self.temp_input_audio_filename); + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "ogg"]); + ffmpeg_command.args(["-i", &self.temp_input_audio_filename]); if is_output_audio_record(&self.temp_output_audio_filename) { - ffmpeg_command.input(&self.temp_output_audio_filename); + ffmpeg_command.args(["-i", &self.temp_output_audio_filename]); } ffmpeg_command.args([ "-c:a", "aac", &self.saved_filename - .clone() - ]).overwrite() - .spawn()? - .wait()?; - } else { - // Validate audio file integrity - let start_time = Instant::now(); - let duration = Duration::from_secs(60); - loop { - if is_valide(&self.temp_output_audio_filename)? { - break; - } else if Instant::now().duration_since(start_time) >= duration { - return Err(Error::msg("Unable to validate tmp video file.")); - } + .clone(), + "-y" + ]); + let program = ffmpeg_command.get_program().to_string_lossy().to_string(); + let args: Vec = ffmpeg_command.get_args().map(|arg| arg.to_string_lossy().into_owned()).collect(); + let mut merge_command = program; + for arg in args { + merge_command.push_str(&format!(" {}", arg)); } + adw::glib::spawn_command_line_async(merge_command)?; + } else { // If only output audio is recording then convert it to chosen format - let mut ffmpeg_command = FfmpegCommand::new(); - ffmpeg_command.format("ogg"); - ffmpeg_command.input(&self.temp_output_audio_filename); - ffmpeg_command.arg(&self.saved_filename - .clone()) - .overwrite() - .spawn()? - .wait()?; + let mut ffmpeg_command = Command::new("ffmpeg"); + ffmpeg_command.args(["-f", "ogg"]); + ffmpeg_command.args(["-i", &self.temp_output_audio_filename]); + ffmpeg_command.arg(&self.saved_filename.clone()); + ffmpeg_command.arg("-y"); + let program = ffmpeg_command.get_program().to_string_lossy().to_string(); + let args: Vec = ffmpeg_command.get_args().map(|arg| arg.to_string_lossy().into_owned()).collect(); + let mut merge_command = program; + for arg in args { + merge_command.push_str(&format!(" {}", arg)); + } + adw::glib::spawn_command_line_async(merge_command)?; } Ok(()) } @@ -779,9 +794,8 @@ impl Ffmpeg { let pid = self.video_process .clone() .ok_or_else(|| anyhow!("Unable to kill the video recording process successfully."))? - .borrow_mut() - .as_inner().id(); - std::process::Command::new("taskkill") + .borrow_mut().id(); + Command::new("taskkill") .arg("/PID") .arg(pid.to_string()) .arg("/F") @@ -791,9 +805,8 @@ impl Ffmpeg { let pid = self.input_audio_process .clone() .ok_or_else(|| anyhow!("Unable to kill the input audio recording process successfully."))? - .borrow_mut() - .as_inner().id(); - std::process::Command::new("taskkill") + .borrow_mut().id(); + Command::new("taskkill") .arg("/PID") .arg(pid.to_string()) .arg("/F") @@ -803,9 +816,8 @@ impl Ffmpeg { let pid = self.output_audio_process .clone() .ok_or_else(|| anyhow!("Unable to kill the output audio recording process successfully."))? - .borrow_mut() - .as_inner().id(); - std::process::Command::new("taskkill") + .borrow_mut().id(); + Command::new("taskkill") .arg("/PID") .arg(pid.to_string()) .arg("/F") diff --git a/gui/Cargo.toml b/gui/Cargo.toml index 69eca2a..aa9eaef 100644 --- a/gui/Cargo.toml +++ b/gui/Cargo.toml @@ -4,6 +4,7 @@ version = "0.1.0" edition = "2021" [dependencies] +adw = { version = "0.2.1", package = "libadwaita", features = ["gtk_v4_6"] } anyhow = "1.0.86" async-std = {version = "1.12.0", features = ["attributes"]} blue-recorder-core = { path = "../core", features = ["gtk"] } @@ -11,7 +12,6 @@ dark-light = "1.0.0" dirs = "4.0.0" fluent-bundle = "0.15.3" glib = "0.10.3" -adw = { version = "0.2.1", package = "libadwaita", features = ["gtk_v4_6"] } regex = "1.4.3" rust-ini = "0.16" secfmt = "0.1.1" diff --git a/gui/src/ui.rs b/gui/src/ui.rs index 95cff3b..f510810 100644 --- a/gui/src/ui.rs +++ b/gui/src/ui.rs @@ -994,8 +994,7 @@ fn build_ui(application: &Application, error_dialog: MessageDialog, error_messag if _audio_input_switch.is_active() { match _ffmpeg_record_interface.borrow_mut().stop_input_audio() { Ok(_) => { - _play_button.set_sensitive(false); - _play_button.set_tooltip_text(Some(&get_bundle("play-inactive-tooltip", None))); + // Continue }, Err(error) => { if _video_switch.is_active() { @@ -1016,8 +1015,7 @@ fn build_ui(application: &Application, error_dialog: MessageDialog, error_messag if _audio_output_switch.is_active() { match _ffmpeg_record_interface.borrow_mut().stop_output_audio() { Ok(_) => { - _play_button.set_sensitive(false); - _play_button.set_tooltip_text(Some(&get_bundle("play-inactive-tooltip", None))); + // Continue }, Err(error) => { if _video_switch.is_active() { @@ -1038,8 +1036,7 @@ fn build_ui(application: &Application, error_dialog: MessageDialog, error_messag if _video_switch.is_active() { match _ffmpeg_record_interface.borrow_mut().stop_video() { Ok(_) => { - _play_button.set_sensitive(false); - _play_button.set_tooltip_text(Some(&get_bundle("play-inactive-tooltip", None))); + // Continue }, Err(error) => { if _video_switch.is_active() { @@ -1057,6 +1054,19 @@ fn build_ui(application: &Application, error_dialog: MessageDialog, error_messag }, } } + // Save tmp files + match _ffmpeg_record_interface.borrow_mut().merge() { + Ok(_) => { + // Continue + }, + Err(error) => { + show_play = false; + let text_buffer = TextBuffer::new(None); + text_buffer.set_text(&format!("{}", error)); + _error_message.set_buffer(Some(&text_buffer)); + _error_dialog.show(); + }, + }; if _video_switch.is_active() { _mouse_switch.set_sensitive(true); _follow_mouse_switch.set_sensitive(true); @@ -1064,32 +1074,12 @@ fn build_ui(application: &Application, error_dialog: MessageDialog, error_messag enable_input_widgets(input_widgets.clone()); _stop_button.hide(); if show_play { + _play_button.set_tooltip_text(Some(&get_bundle("play-tooltip", None))); _play_button.show(); } _record_button.show(); }); - // Save tmp files - let _error_dialog = error_dialog.clone(); - let _error_message = error_message.clone(); - let _play_button = play_button.clone(); - let mut _ffmpeg_record_interface = ffmpeg_record_interface.clone(); - play_button.connect_show(move |_| { - match _ffmpeg_record_interface.borrow_mut().merge() { - Ok(_) => { - _play_button.set_sensitive(true); - _play_button.set_tooltip_text(Some(&get_bundle("play-tooltip", None))); - }, - Err(error) => { - _play_button.hide(); - let text_buffer = TextBuffer::new(None); - text_buffer.set_text(&format!("{}", error)); - _error_message.set_buffer(Some(&text_buffer)); - _error_dialog.show(); - }, - } - }); - // Delay window button let _delay_window_button = delay_window_button.clone(); delay_window_button.connect_clicked(move |_| {}); diff --git a/locales/ar.ftl b/locales/ar.ftl index c74409e..bc3013b 100644 --- a/locales/ar.ftl +++ b/locales/ar.ftl @@ -173,7 +173,6 @@ frames-tooltip = خصص عدد الصور في الثانية hide-tooltip = اطوِ نافذة المسجل الأزرق عند بدء التسجيل mouse-tooltip = يظهر مؤشر الفأرة عند التسجيل play-tooltip = انقر لمشاهدة ما سُجِّل -play-inactive-tooltip = ترقَّب ريثما يتم حفظ ما سُجِّل record-tooltip = يشرع في التسجيل screen-tooltip = يحدد الشاشة كاملة ليسجلها show-area-tooltip = يُظهر البقعة المنتقاة أثناء التسجيل diff --git a/locales/ar_YE.ftl b/locales/ar_YE.ftl index c74409e..bc3013b 100644 --- a/locales/ar_YE.ftl +++ b/locales/ar_YE.ftl @@ -173,7 +173,6 @@ frames-tooltip = خصص عدد الصور في الثانية hide-tooltip = اطوِ نافذة المسجل الأزرق عند بدء التسجيل mouse-tooltip = يظهر مؤشر الفأرة عند التسجيل play-tooltip = انقر لمشاهدة ما سُجِّل -play-inactive-tooltip = ترقَّب ريثما يتم حفظ ما سُجِّل record-tooltip = يشرع في التسجيل screen-tooltip = يحدد الشاشة كاملة ليسجلها show-area-tooltip = يُظهر البقعة المنتقاة أثناء التسجيل diff --git a/locales/en.ftl b/locales/en.ftl index ff9c2ac..60ca5d1 100644 --- a/locales/en.ftl +++ b/locales/en.ftl @@ -173,7 +173,6 @@ frames-tooltip = Set frames rate hide-tooltip = Hide window when start recording mouse-tooltip = Mouse appears in video recording play-tooltip = Click to play video -play-inactive-tooltip = Please wait until the file is saved record-tooltip = Start screen record screen-tooltip = Select screen to record show-area-tooltip = Show selected area during record diff --git a/locales/en_US.ftl b/locales/en_US.ftl index ff9c2ac..60ca5d1 100644 --- a/locales/en_US.ftl +++ b/locales/en_US.ftl @@ -173,7 +173,6 @@ frames-tooltip = Set frames rate hide-tooltip = Hide window when start recording mouse-tooltip = Mouse appears in video recording play-tooltip = Click to play video -play-inactive-tooltip = Please wait until the file is saved record-tooltip = Start screen record screen-tooltip = Select screen to record show-area-tooltip = Show selected area during record