aboutsummaryrefslogtreecommitdiff
path: root/platform/platform.h (unfollow)
Commit message (Collapse)AuthorFilesLines
2023-08-15Initial refactor of plugin system (darwin only)plugin-refactorNicholas Tay1-1/+1
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.
2022-05-17Add Linux supportNicholas Tay1-2/+2
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.
2022-05-11Improve plugin loading architectureNicholas Tay1-1/+4
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.
2022-05-10Dynamic load boards as DLL (windows only for now)Nicholas Tay1-0/+5
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.
2022-05-07Split out platform-specific code for WindowsNicholas Tay1-0/+10
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.