Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Safe mediacodec bindings #216

Merged
merged 4 commits into from
Mar 12, 2022
Merged

Conversation

zmerp
Copy link
Contributor

@zmerp zmerp commented Jan 14, 2022

Add MediaCodec and MediaFormat bindings with most of their methods. Crypto and DRM support is not implemented.

Testing
Only the decoder code path is tested. sample

Note: This PR needs to be rebased after #213 is merged

@zmerp zmerp force-pushed the safe-mediacodec-bindings branch from b6a72f1 to d1f5e46 Compare January 15, 2022 18:59
@zmerp zmerp force-pushed the safe-mediacodec-bindings branch from d1f5e46 to 0a547b5 Compare January 15, 2022 19:06
Copy link
Member

@MarijnS95 MarijnS95 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For starters, there are a lot of unnecessary as _ casts and typed initializations. Please either be explicit about a cast or remove it altogether.

Adding #![warn(trivial_casts)] at the top of this file (hopefully we can do that repo-wide at some point) will help you track these down.

ndk/src/media/media_codec.rs Outdated Show resolved Hide resolved
ndk/src/media/media_codec.rs Outdated Show resolved Hide resolved
ndk/src/media/media_codec.rs Outdated Show resolved Hide resolved
@zmerp
Copy link
Contributor Author

zmerp commented Jan 24, 2022

@MarijnS95 Ok, I should have addressed all your suggestions. I used:

cargo clippy -p ndk --target armv7-linux-androideabi --features api-level-30 --features media
cargo clippy -p ndk --target aarch64-linux-android --features api-level-30 --features media

@MarijnS95
Copy link
Member

Fwiw feel free to leave the warning at the top of the file for the meantime. I'll work out to combine that with #219.

@MarijnS95
Copy link
Member

cargo clippy -p ndk --target armv7-linux-androideabi --features api-level-30 --features media
cargo clippy -p ndk --target aarch64-linux-android --features api-level-30 --features media

You may also use x86_64/i686 as those have a different pointer type for c_char (u8), afaik armv7 also has i8 like aarch64?

@zmerp
Copy link
Contributor Author

zmerp commented Jan 24, 2022

You may also use x86_64/i686 as those have a different pointer type for c_char (u8), afaik armv7 also has i8 like aarch64?

Ok, tried and no extra warnings or errors.

@zmerp
Copy link
Contributor Author

zmerp commented Jan 24, 2022

There are still some warnings because of unused imports when using api-level-24, not only from my code

@MarijnS95
Copy link
Member

There are still some warnings because of unused imports when using api-level-24, not only from my code

That is something we should perhaps build-test in the CI and fix? Mind opening a separate PR for that (or issue if nontrivial)?

@zmerp
Copy link
Contributor Author

zmerp commented Mar 11, 2022

Can this PR be merged? The warnings can be addressed in a second moment.

@dvc94ch
Copy link
Contributor

dvc94ch commented Mar 12, 2022

LGTM, thanks @zarik5

@dvc94ch dvc94ch merged commit f0be2c5 into rust-mobile:master Mar 12, 2022
@MarijnS95
Copy link
Member

I wasn't actually okay with this yet, but that's what I get for being on holiday. Doc comments with double instead of triple slashes, get_ prefixes, changelog in the past tense and no reference to this PR, inconsistent use statements that are unused when certain features are not enabled, enum that doesn't derive common traits like Eq but instead has a strange matches! (why aren't the flags modeled directly with a #[repr(u32)] enum?), and that's just the stylistic nits.

@dvc94ch
Copy link
Contributor

dvc94ch commented Mar 16, 2022

Sometimes things are good enough. But agree that it would be better with the changes you mentioned.

@MarijnS95
Copy link
Member

If crates are going to be maintained (or at least PRs merged) with a "good is good enough" mentality I'll have to step down as a maintainer, as I can't be cleaning up behind peoples back to uphold an acceptable feeling of responsibility towards said project.

That is, unless there's clear agreement and documentation that a PR is dragging on too long (in terms of discussions, not silence), and is best merged in preparation for followup changes to land through separate PRs.

@zmerp zmerp deleted the safe-mediacodec-bindings branch March 17, 2022 08:41
@zmerp
Copy link
Contributor Author

zmerp commented Mar 17, 2022

I'm sorry @MarijnS95, I realize that things were rushed. I tried picking up the style around but I did a poor job. The wrong doc comments were the most glaring mistake for me. I think it would really help a PR checklist (not necessarily in this repo, you could link to a good one in another repo or website).

@MarijnS95
Copy link
Member

I don't think a checklist for standard style errors really exists or make sense; it should all be caught by (locally runnable) CI tools like clippy. In the grand scheme of things I'd like to fail on many more default-allow (rustc or clippy) lint warnings, but it takes a ginormous effort to get this project to pass stricter lints initially 😶

We could however use a checklist for obvious things like requiring a changelog entry if a PR modifies public-facing API/behaviour.

@MarijnS95
Copy link
Member

In any case, my post above links at least twice to https://rust-lang.github.io/api-guidelines/ - that's a good starting place if you're looking for more guidance.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants