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

[WIP] C++ port Proof of Concept #3

Closed
wants to merge 42 commits into from

Conversation

Nekotekina
Copy link

@Nekotekina Nekotekina commented Dec 15, 2024

Not for merge.
Fixes issues with capslock indicator being reset (in Wayland, for example) (feel free to cherry-pick).
Fixes cursed issues with C fixed arrays by using C++ (partially).
The fact these issues exist is infuriating. Fixing this in pure C will only waste a lot of time.

@Nekotekina Nekotekina force-pushed the master branch 4 times, most recently from b57afba to 78f83a5 Compare December 15, 2024 11:35
@Nekotekina Nekotekina force-pushed the master branch 20 times, most recently from 1496ffb to f50af0e Compare December 18, 2024 06:44
@rhansen rhansen marked this pull request as draft December 18, 2024 09:19
@rhansen rhansen changed the base branch from main to reintegrate-v2 December 18, 2024 09:21
@rhansen
Copy link
Contributor

rhansen commented Dec 18, 2024

I haven't looked at the commits but in general I'm a fan of the idea of switching to C++. It doesn't look like upstream is willing to switch, so this would have to be done in a permanent fork.

@Nekotekina
Copy link
Author

I don't really see any reason against. Maybe I was too rude after all. If it's memory usage on some embedded system, dynamic allocations in C++ only work in favor on C++. I have already significantly reduced static memory usage. Because with dynamic alloc you only pay more memory as your config grows bigger.

Command is made std::string as well (virtually unlimited).
Limit is INT16_MAX for now due to index encoding.
There is no such path limitation as PATH_MAX.
See: https://stackoverflow.com/questions/9449241/where-is-path-max-defined-in-linux
One shall not use this historical constant for anything.
Also optimize `chord` struct size a bit.
Looping over small array should be easily unrolled/vectorized.
Also allow includes to have non-.conf extensions.
Also split table to reduce memory size.
Improve indicator on Wayland (resist forced changes).
Optimize layer_indicator performance.
Fix previous unnecessary LED setting.
Compatible with previous settings because CAPS_LOCK equals 1.
Based on pull-request initially proposed by @plague-spreader
Macro no longer allowes "words" (char sequences without delimiters).
In order to write "Hello" it must be written as macro(H e l l o).
Alternatively, it can be t(Hello) or type(Hello).
Shell commands can't execute via `keyd do`.
Example: macro(cmd(echo 1))
Also allow implicit layer creation on bindings.
Add leftctrl/leftsuper-alike key aliases.
Allow ctrl as layer name equal to control.
Allow multiname aliases in alias section.
Refactor config_backup class.
Also use C++20 'using enum class'.
`keyd do` or `keyd bind` will copy user's credentials.
Loaded .conf file will use keyd process credentials.
Don't kill child processes in systemd config.
Allow a train of IPC messages for optimization.
Remove full `*` wildcard support.
Initially `m:*` was proposed by @jyn514
Additional wildcard `a:` to include abs pointer devices.
When using `m:` those devices are excluded.
These commands may be useful to execute at user session startup.
User bindings are loaded by explicit calling `keyd reload` from user.
User bindings are located at `~/.config/keyd/bindings.conf`.
Implement file_reader class (simple fd->container).
Implement concat class for simple formatting strings.
Some options allow significantly reduce executable size.
Static part of libstdc++ now is only 130~150 Kb.
Remove some strange mutex code.
Restore __libc_single_threaded after joining threads.
@Nekotekina
Copy link
Author

Closing as rvaiya wishes neither C++ nor org.
I created another org, https://github.com/keyd-cpp/keyd, for C++.

@Nekotekina Nekotekina closed this Dec 28, 2024
@Nekotekina
Copy link
Author

Now he banned me from his repository because I suggested my fork to people struggling with various issues which he is unable/unwilling to fix. Note I just want to make better software. Software without weird hacks and limitations, software that isn't a timebomb. He seems to be offended by that.

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.

6 participants