Commit Graph

160 Commits

Author SHA1 Message Date
June Tate-Gans
577865c69e g13gui: Make stick regions and stick modes enums
This simplifies quite a bit, and reduces coding errors by using symbols instead
of "stringified" types.
2021-04-27 18:04:51 -05:00
June Tate-Gans
91d88b3a83 g13gui: Tests for BindingProfile and a bunch of code cleanups
The BindingProfile class had a bunch of untested code that was assigning to
things by the wrong name, or making logic errors all throughout. With the added
unit tests, that cleans it up considerably.
2021-04-27 18:03:50 -05:00
June Tate-Gans
8f46071239 g13gui: Make observers capable of subscribing to keys
This reduces some of the notifications during changes by reducing the scope of
changes that are monitored by other components in the system. IOW, this allows
keys to only care about their particular changes, rather than all key binding
changes in a BindingProfile.
2021-04-27 18:02:24 -05:00
June Tate-Gans
3183ae8b2b g13gui: Fix param names and migrate ObserverTestCase
ObserverTestCase is code, not test stuff, so migrate that into the observer
module properly.
2021-04-27 14:57:19 -05:00
June Tate-Gans
d5b4957916 gitignore: Stop committing pyc files 2021-04-27 13:46:58 -05:00
June Tate-Gans
eb816c8acb g13gui: Add in an observer pattern
We'll need this as complexity of the GUI grows. This allows us to queue up
change notifications and pass them to observing objects more cleanly.
2021-04-27 13:45:57 -05:00
June Tate-Gans
bac31a772a g13gui: Major functionality additions
This gets us nearly to a proper profile manager and keybinding tool! Very very
close, despite the messiness of the codebase. There's lots of low hanging fruit
for those who are interested in contributing.

  - Made BindingProfile serializable to a python dict
  - Fixed a bug in BindingProfile that named keys in the g13d command stream
    incorrectly.
  - Made ButtonMenu attempt to grab the keyboard when it shows so we can get
    more correct keypresses. This is only half the battle -- need to stop GTK's
    event loop for other widgets from catching events and handling them.
  - Added a g13d communications worker thread, including saving of profiles to
    disk as well as uploading profile configurations to g13d. This uses a Queue
    for incoming tasks from the GUI thread, and dispatches results back by way
    of GObject signals. Could use some work to make this less clunky.
  - Made MainWindow load the profiles from disk. This is done on the GUI thread,
    which isn't ideal.
  - Added an Upload button to push changes over to g13d. This reacts to the
    worker thread's connected/disconnected signals.
2021-04-27 00:00:16 -05:00
June Tate-Gans
cdc8fe5139 g13gui: First rough draft
This represents a full day of work just to get the binding behaviors correct and
the profile behaviors correct. At this point, this should be possible to turn
into something useful for controlling g13d with.

Things left to do:

  - Setup a thread for communicating with g13d with
  - Setup a worker queue to send profile changes or updates to the g13d daemon

Once those are in there, we can consider this to be feature complete for 1.0.
Additional functionality, such as LED colors, drawing to the LCD, and things
like supporting dbus IPC so we can handle applets on the LCD will come later.
2021-04-26 19:13:19 -05:00
June Tate-Gans
e97cb2c6c3 stick: Fix a logic error I introduced
Late night hacking causes all kinds of silliness. We only want to stop running
an action when the key is not pressed now, but was prior pressed. My logic
caused it to fire when not pressed and not prior pressed, erroneously, leading
to stuck keys.
2021-04-25 23:16:03 -05:00
June Tate-Gans
4d964dd0c0 device: Revert another warning "fix" due to lack of sleep
Totally misunderstood what I was doing here and broke stickzone additions.
2021-04-25 22:31:13 -05:00
June Tate-Gans
390995bf03 action: Revert my unsigned vs. signed "fix"
Totally misread the code in the Action_keys::act method -- the code actually
reverse sends events in an up condition. Still, keeping the C++11 iteration and
improving by using boost::adaptors::reverse.
2021-04-25 22:28:22 -05:00
June Tate-Gans
b81ec75c82 g13d: More cleanups
Double underbars are reserved for the compiler and system, so we shouldn't use
them for header guards. Additionally, remove a bunch of these line breaks.
2021-04-25 21:12:26 -05:00
June Tate-Gans
22cd1c9351 g13d: Get rid of some of the G13_ prefixing for classes 2021-04-25 21:04:01 -05:00
June Tate-Gans
1918d6875c g13d: Reformat all the files to Google style
This is closer to what I'm looking for, and gives us a style guide to boot.
2021-04-25 20:30:56 -05:00
June Tate-Gans
234b5aac7f tools: Add a small reformatting tool to ease the burden 2021-04-25 20:13:25 -05:00
June Tate-Gans
73f10be688 g13d: Migrate string_repr_out into a cc file and fix the deps
This was a mistake I made accidentally -- meant to have the function in the C++
file, not in the header.
2021-04-25 17:27:07 -05:00
June Tate-Gans
073860faad g13d: Fix build dependendies 2021-04-25 17:24:47 -05:00
June Tate-Gans
dee05bc790 license: Clarifying original licenses and copyrights 2021-04-25 17:23:47 -05:00
June Tate-Gans
358fb509db g13d: Final-final cleanups to the codebase
- Removing a bunch of silly star comment separates
  - Moving font8x8 back into its own header
  - Move string_repr_out into repr.cc
2021-04-25 17:22:34 -05:00
June Tate-Gans
a05dcb04c8 g13d: More symbol relocations and cleanups
Lots of cross-translation unit messes in here cleaned up finally. This should be
the last change necessary to clean up these refs between translation units.
2021-04-25 17:09:19 -05:00
June Tate-Gans
95b137f3db g13d: Fix the font translation unit name 2021-04-25 16:53:50 -05:00
June Tate-Gans
648c14690f g13d: More cleanups and migrations
Second part of the big refactor. Migrating all of the relevant method bodies to
their respective translation units.
2021-04-25 16:51:41 -05:00
June Tate-Gans
ae6cf5084a g13d: Rework and cleanup namespaces and files
This is the first half of some major rework of the g13d codebase to make things
a bit more manageable. This splits out a great deal of stuff from helper.h into
separate translation units, and also breaks out a great deal of the g13.h header
into separate translation units as well.

Doing this saves in compilation time as we make changes to the system, and also
helps to clean up a whole bunch of leaking symbols.
2021-04-25 16:35:44 -05:00
June Tate-Gans
efe01fb850 g13d: Remove switch and handle all switch cases 2021-04-25 14:40:31 -05:00
June Tate-Gans
9c15e935a7 g13d: Add a blank line 2021-04-25 14:40:16 -05:00
June Tate-Gans
b7f784563c g13d: Fix initialization order 2021-04-25 14:39:54 -05:00
June Tate-Gans
47d876b4cb g13d: Fix a bunch of sign comparisons 2021-04-25 14:39:40 -05:00
June Tate-Gans
9bf95336cc g13d: Remove a bunch of unused vars and definitions 2021-04-25 14:38:41 -05:00
June Tate-Gans
8e14f1f853 g13d: Clean up initialization order 2021-04-25 14:38:08 -05:00
June Tate-Gans
f289bdf850 g13d: Style fixes and remove an unused variable 2021-04-25 14:37:00 -05:00
June Tate-Gans
366e3c0f24 g13d: Remove an unused block of code
We don't actually do anything with an add operation in
G13_Device::_init_commands, so fix up the if block.
2021-04-25 14:36:07 -05:00
June Tate-Gans
cb916e4d24 g13d: Fix a comparison with signed vs. unsigned 2021-04-25 14:35:49 -05:00
June Tate-Gans
d910829930 g13d: More C++11 iteration and exit on no more managed devices
Since we start from udev/systemd these days, we should exit when we don't have
any more devices to manage, and let udev/systemd manage things when a new one is
connected.
2021-04-25 14:33:48 -05:00
June Tate-Gans
d391b647b6 g13d: Fix a bunch of initialization order errors
The initializers were in the wrong order.
2021-04-25 14:33:12 -05:00
June Tate-Gans
65ab987a87 g13d: Simplify G13_Action_Keys::act
Migrate to C++11 iteration and clean up the mess of code that this was
originally with a single call to send_event and a proper use of a ternary for
logging.
2021-04-25 14:32:24 -05:00
June Tate-Gans
bbb3104eaf g13d: Use C++11 iterator instead of a raw C loop
Signed vs. unsigned types throwing all kinds of errors.
2021-04-25 14:31:45 -05:00
June Tate-Gans
19faa21256 g13d: Fix horribly broken strncpy usage
The sizeof was actually using the size of the statically allocated name instead
of the size of the destination. In practice, it's not a problem, but still, it
should be fixed.
2021-04-25 14:30:46 -05:00
June Tate-Gans
ae055495cc g13d: Handle errors in writes
The original code was just throwing away error conditions for write calls to an
fd. Obviously this is bad, but really, we should probably be using an ostream
instead of a raw file handle here. For now, deal with the warning by checking
the result for errors, at least, and later we'll refactor to use ostream
properly.
2021-04-25 14:29:40 -05:00
June Tate-Gans
516423ae16 g13d: Run clang-format to clean things up a bit 2021-04-25 14:04:12 -05:00
June Tate-Gans
70e77c2b3b udev: Actually set the right group
Forgot to set the group for the nodes to input so that the user can manage it if
needed.
2021-04-25 14:01:53 -05:00
June Tate-Gans
cf1caf7c7a g13d: Fix include path for config.h 2021-04-25 13:43:16 -05:00
June Tate-Gans
0cf69f92d2 clangformat: Indent case labels 2021-04-25 13:43:02 -05:00
June Tate-Gans
709f088d8c gitignore: Ignore GNU global tags 2021-04-25 13:42:46 -05:00
June Tate-Gans
c7992d52b5 g13d: Reformat all the files using clang-format
This should help with maintainability.
2021-04-25 12:51:26 -05:00
June Tate-Gans
c32950bfcb g13d: Build with warnings and correct C++ standard 2021-04-25 12:45:25 -05:00
June Tate-Gans
e17abaddf2 g13d: Add a config header 2021-04-25 12:44:58 -05:00
June Tate-Gans
6ea11f3d58 cmake: Install udev and systemd services 2021-04-25 12:20:19 -05:00
June Tate-Gans
b04a8d6152 udev: Match attributes correctly and trigger systemd unit
This starts to make g13d more automatic. Instead of requiring manual
intervention or automatic starts on system start, this will allow udevd to
automatically trigger g13d when a g13 is plugged in.

There's still a bug in g13d where if the device falls off the USB chain g13d
won't exit, though, but this is a good start.
2021-04-25 12:18:07 -05:00
June Tate-Gans
eba5f77a88 g13d.service: Fix the fifo locations
Apparently /var/run is the old, deprecated pathname for /run these days.
2021-04-25 12:17:28 -05:00
June Tate-Gans
05c64f62ed cmake: Make install create /run/g13d
CMake still doesn't have a way to set mode and owner/group at install time
atomically, so we have to fall back and call install directly in a script.
2021-04-25 12:16:47 -05:00