-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
REFAC(client): Introduce and use AudioPreprocessor #6511
base: master
Are you sure you want to change the base?
REFAC(client): Introduce and use AudioPreprocessor #6511
Conversation
So the point of this is to rip the speex pre-processor code out of |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not a big fan of using fixed-width integers without need. Imo, all the integers in the interface should be of type int
(or unsigned int
) to let the compiler use the native integer size for the given architecture.
Explicitly encoding the integer's width only provides extra information to someone reading the code that they don't need because in this case here it is completely irrelevant as all integers that are expected to be passed around are well below the maximum possible value of an int
on all platforms that Mumble can be compiled on. This only causes head-scratching when someone has to refactor the code as they will start wondering where exactly the requirement for a 32-bit integer is coming from and why e.g. a 64-bit integer can't be used.
All-in-all though, LGTM
Correct. If in the future we want to implement another preprocessor, this new class is a good abstraction base.
Documentation for each function would also help understanding that. As for the use of |
That's not true in the general case but that's also not my point. My point is completely about readability of the code and how much information to put into tue source code. Ideally, we only want relevant information in the source code and if the exact size of an integer is not important, adding the size into the source code decreased the signal-to-noise ratio, making the code harder to parse and modify. |
Technically speaking the size of a variable is always important. Good practice generally consists in defaulting to the smallest size that can hold the biggest value you expect to be assigned to the variable. There are of course some exceptions, such as when designing a public API. In that case you have to consider the future proofing aspect and thus may want to go with a bigger size even if not required right now. |
51bffa0
to
c1337bb
Compare
I don't think always choosing the smallest possible size does any good (almost never do the logical range of valid inputs coincide with the range of possible values that can be encoded with an integer of a given size) and as long as you do that, the size loses importance for 99% of functions as arguments typically range in the order of 100s to maybe 1000s which fits into pretty much all integer sizes. |
If you're referring to the readability aspect then no, knowing the size of a variable doesn't tell you the actual value range that is expected. It's still a hint though. |
This looks wrong to me... can we update the |
Only if you find a way to not break existing PRs (aka: a way to automatically adapt PRs to new formatting standards). I wanted to look into a script/bot that can do this for a while but never actually came around to implementing it. I'm sure it wouldn't be too complicated given that clang-format can format diffs but it'd have to be implemented in a way that makes it easy to use on all existing open PRs. |
c1337bb
to
b183128
Compare
Formatted with clang-format 10, in order for CI to succeed. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Otherwise, I think this can be merged, no?
@@ -0,0 +1,178 @@ | |||
// Copyright 2024 The Mumble Developers. All rights reserved. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
// Copyright 2024 The Mumble Developers. All rights reserved. | |
// Copyright The Mumble Developers. All rights reserved. |
if (m_handle) { | ||
speex_preprocess_state_destroy(m_handle); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should probably also setm_handle
to nullptr
in case deinit
gets called twice in a row.
* | ||
* \return Whether the operation succeeded. | ||
*/ | ||
bool toggleAGC(bool enable); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All these functions don't toggle, they set the value. Imo they should be renamed appropriately.
@@ -0,0 +1,215 @@ | |||
// Copyright 2024 The Mumble Developers. All rights reserved. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
// Copyright 2024 The Mumble Developers. All rights reserved. | |
// Copyright The Mumble Developers. All rights reserved. |
No description provided.