aboutsummaryrefslogtreecommitdiff
path: root/clak.c (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Initial refactor of plugin system (darwin only)plugin-refactorNicholas Tay2023-08-151-7/+12
| | | | | | | | | | | Darwin only for now since that's what I'm on, will migrate the others a bit later. Trying out a different plugin system that probably makes more sense as an interface to each other. Might shuffle things around even more later. This is based somewhat on Tsoding's audio visualiser plugin system, I thought that was way more elegant (the 'state' object), as opposed to whatever the hell we were doing.
* Add Linux supportNicholas Tay2022-05-171-1/+3
| | | | | | | | Oh boy this was a bit of a hassle lol - dynamic loading was the easiest part... but then came both sound and x11 Using SDL for now but I'd really like to change it for even lower layer, but then I might have to make my own mixer... oh no.
* Improve plugin loading architectureNicholas Tay2022-05-111-8/+10
| | | | | | | | | | | | | This should be better, maybe the variable names could be better though. Init is more extensible, we take in a 'board_data' struct on the plugin end that has everything it needs (mainly function pointers for now). Then, a 'board' struct is given back to the main Clak runtime, with everything it needs to know (again, mainly function pointers). It is a bit weird that the board is not stored with Clak but as a pointer to the dynamically loaded bit, but not sure.
* Dynamic load boards as DLL (windows only for now)Nicholas Tay2022-05-101-40/+18
| | | | | | The .h files are pretty weird, should look at other C projects to see how they load plugins. This function pointer business with typedefs is kinda weird, not sure where they should live.
* More messing around with plugin systemNicholas Tay2022-05-081-6/+8
| | | | | Just more attempts, but I think I'm gonna switch over to dynamic .so/.dll loading. That would be pretty fun to check out.
* Split out platform-specific code for WindowsNicholas Tay2022-05-071-72/+14
| | | | | Not sure if I'm really doing it in the best way possible. Feels a bit weird that some place assumes the existence of other functions.
* Windows low-level hook workingNicholas Tay2022-05-071-5/+85
| | | | | | | | Had to do some stuff with the previous VK tracking, just like what I had to do in C# with Meccha, since it keeps firing events. GetMessage part also just blocks to ensure we keep receiving Windows events, but not sure what to do otherwise.
* Dynamically take in board nameNicholas Tay2022-05-071-7/+23
|
* Split out sound logic (for xplatform)Nicholas Tay2022-04-281-5/+17
|
* Iterate boards in CNicholas Tay2022-04-281-2/+16
|
* Initial working Windows playsoundNicholas Tay2022-04-281-0/+17