Commit message (Collapse) | Author | Age | |
---|---|---|---|
* | chore(treewide): Assure that `nix fmt` and `reuse lint` are happy | Benedikt Peetz | 25 hours |
| | |||
* | refactor(yt_dlp): Split the big `lib.rs` file up | Benedikt Peetz | 26 hours |
| | |||
* | refactor(yt_dlp/progress_hook): Use public api via `__priv` module | Benedikt Peetz | 26 hours |
| | | | | | That makes it clear that these parts are only exposed to facilitate macro use and not as part of the public API. | ||
* | fix(yt_dlp/post_processing/dearrow): Correctly type the `CasualVote` field | Benedikt Peetz | 26 hours |
| | |||
* | refactor(yt_dlp/logging): Avoid adding to the `__all__` list | Benedikt Peetz | 26 hours |
| | | | | | This seems to have no apparent effect on anything. As such I went ahead and removed this dead code. | ||
* | fix(yt_dlp): Typos in strings | Benedikt Peetz | 26 hours |
| | |||
* | fix(yt_dlp/post_processors): Register in python | Benedikt Peetz | 26 hours |
| | | | | | | | | | | | We need to tell yt_dlp about our post processors, as they would otherwise not take full effect. For example, changing the title would previously only have changed the title in the *in-memory* info json, the actual file on disk (video and .info.json) would still have the old title, as yt_dlp did not know about our post processor. Registering it via their api also has the upside of being able to determine when to run. | ||
* | fix(yt_dlp/post_processors/dearrow): Migrate to curl for api requests | Benedikt Peetz | 26 hours |
| | | | | | | The reqwest crate will panic if it is blockingly run inside another executor. But we cannot make this function async, as the whole api is forced to be sync by python ffi. | ||
* | fix(yt_dlp/): Include the frozen python stdlib | Benedikt Peetz | 43 hours |
| | | | | | This avoids the dependency on a real std-library (i.e., python3) at runtime. | ||
* | style(treewide): Reformat | Benedikt Peetz | 44 hours |
| | |||
* | chore(treewide): Add missing copyright headers | Benedikt Peetz | 45 hours |
| | |||
* | style(yt/select): Apply clippy's suggestions | Benedikt Peetz | 45 hours |
| | |||
* | fix(yt/update): Also handle the newly introduced error conditions | Benedikt Peetz | 45 hours |
| | |||
* | feat(yt_dlp): Support a DeArrow post processor | Benedikt Peetz | 45 hours |
| | |||
* | refactor(yt_dlp/lib): De-duplicate the info json sanitize code | Benedikt Peetz | 45 hours |
| | |||
* | refactor(yt_dlp/lib): Explicitly convert python exceptions into an error | Benedikt Peetz | 45 hours |
| | | | | This avoids having to wrap all blocks into a `match` statement. | ||
* | refactor(yt/select/selection_file): Migrate from `trinitry` to `shlex` | Benedikt Peetz | 47 hours |
| | | | | shlex is better maintained, and _actually_ meant for this purpose . | ||
* | test(yt/cli): Test the CLI | Benedikt Peetz | 2 days |
| | |||
* | fix(libmpv2-sys): Avoid generating comments, that confuse rustdoc | Benedikt Peetz | 2 days |
| | |||
* | fix(yt/cli): Remove duplicated short flag key (help also uses 'h') | Benedikt Peetz | 2 days |
| | |||
* | feat(yt/cli): Add support for command line completions | Benedikt Peetz | 2 days |
| | |||
* | feat(yt/select/split): Make sorting configurable | Benedikt Peetz | 2 days |
| | | | | | I also moved that to a separate subcommand, as we would otherwise have too many `requires`/`conflicts_with` statements. | ||
* | feat(yt/videos/list): Replace the nucleo matcher with a simple `contains` | Benedikt Peetz | 2 days |
| | | | | | | The matching behaviour was not predictable at all (probably due to a bad config), which than led to using `yt videos ls | grep -i <query>` instead. | ||
* | fix(yt/download/get_file_size): Correct deal with `filesize_approx` = Null | Benedikt Peetz | 2 days |
| | |||
* | fix(yt_dlp/json_{cast,get}): Improve error reporting | Benedikt Peetz | 2 days |
| | |||
* | fix(yt/update): Correct the progress display in `--grouped` mode | Benedikt Peetz | 3 days |
| | |||
* | docs(yt/watch/playlist_handler/client_messages): Add TODO about `current_exe` | Benedikt Peetz | 3 days |
| | |||
* | docs(yt_dlp): Fix typo in `Cargo.toml`'s description | Benedikt Peetz | 3 days |
| | |||
* | fix(yt_dlp): Avoid writing the json output to disk | Benedikt Peetz | 3 days |
| | | | | | There is no point in doing this anymore, as we no longer need to deserialize it. | ||
* | fix(yt/update/video_entry_to_video): Cast the json objects | Benedikt Peetz | 3 days |
| | | | | | Otherwise, we might encounter very weird behaviour if yt_dlp ever changes the types of these keys. | ||
* | feat(yt/update): Print a nice progress number | Benedikt Peetz | 3 days |
| | | | | | | | This number obviously does not actually mean that we have finished updating (as it is incremented on staring). But it still provides some feedback, on how long the update will probably take. | ||
* | feat(yt/update): Support grouped updates | Benedikt Peetz | 3 days |
| | | | | | | | | | | Rustpython currently does not use a garbage collector. Thus, every cyclic reference between Python objects results in a memory leak of these objects (as Rustpython uses (A)RCs). The only real way to workaround the memory leaks, is by restarting the whole process, and this `--grouped` flag seems to be the best solution for that. | ||
* | perf(yt/update/updater): Acknowledge, that `yt_dlp` has a sync API | Benedikt Peetz | 3 days |
| | | | | | | | | | | | | | | | The previous code was written with the assumption, that `yt_dlp` had an async API (which means, that calls to it should never block). Unfortunately, the API is sync and all calls into it block. Therefore, all the parallelism in the previous code accounted for nothing; The actual update ran completely sequentially. The new version uses a local thread pool to avoid blocking the tokio runtime and as such achieves higher speed. Unfortunately, because the rustpython implementation is way slower than cpython, the whole update takes longer. But that is a problem for another day. | ||
* | feat(yt/select): Support a directory selection process | Benedikt Peetz | 3 days |
| | | | | The single file approach becomes unwieldy once one has more open videos. | ||
* | refactor(yt/select): Split the `select::select` function up | Benedikt Peetz | 3 days |
| | |||
* | feat(yt/update): Specify subscriptions to update as positional args | Benedikt Peetz | 4 days |
| | | | | | Having the `-s/--subscription` flag is pointless, as there are no other flags that could make a positional arg ambiguous. | ||
* | feat({yt/update,yt_dlp}): Use yt_dlp errors again | Benedikt Peetz | 4 days |
| | | | | | This code was temporarily commented out, as I had not migrated it in the pyo3 -> rustpython migration. | ||
* | docs(yt/update): Add comment about the `unsmuggle_url` invocation | Benedikt Peetz | 4 days |
| | |||
* | fix(yt/update): Avoid printing all the subscriptions that are not updated | Benedikt Peetz | 4 days |
| | | | | This is just too much noise. | ||
* | fix(yt/select/selection_file/duration): Improve the duration parser | Benedikt Peetz | 4 days |
| | | | | | | | | The previous parser was very brittle, it failed for (valid) outputs like `1d 10h 30m` (as it only expected two number unit pairs). On top of that, extending it was failure prone (as proven by the roundtrip failure in combination with the `d` unit). | ||
* | fix(yt/version): Use yt_dlp's native python version imply | Benedikt Peetz | 5 days |
| | | | | This is just cleaner, compared to running `yt-dlp --version` as command. | ||
* | build(treewide): Update | Benedikt Peetz | 5 days |
| | |||
* | refactor(yt): Move to `crates/yt` | Benedikt Peetz | 5 days |
| | | | | Having one crate outside the `crates` directory is just weird. | ||
* | feat({yt_dlp,yt}): Migrate from pyo3 to rustpython | Benedikt Peetz | 5 days |
| | | | | | | | | That allows us to avoid cpython's GIL and gives us full ability to leverage async/concurrent code to speed up python operations. I have also taken the opportunity to change the `InfoJson` struct to an untyped json value, as that is what it actually is. | ||
* | chore(yt_dlp/wrappers/info_json): Add additional missing field | Benedikt Peetz | 2025-03-21 |
| | |||
* | refactor(yt_dlp): Remove the unneeded `async` from the public functions | Benedikt Peetz | 2025-03-21 |
| | |||
* | chore(treewide): Migrate to rust edition 2024 | Benedikt Peetz | 2025-03-21 |
| | | | | | Even though the diff in the libmpv2 crate is quite big, it really only added `unsafe` blocks to the `unsafe` functions. | ||
* | build(treewide): Update | Benedikt Peetz | 2025-03-21 |
| | |||
* | chore(treewide): Add/Update the license headers | Benedikt Peetz | 2025-02-22 |
| | |||
* | fix(crates/libmpv2/mpv): Log the setting of properties | Benedikt Peetz | 2025-02-21 |
| |