macschema
qmux
Our great sponsors
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
macschema
-
Towards the Personal Potential of Software
With the macschema toolchain, you can generate API schemas about any Apple framework, class, function, etc based on their documentation and header declarations. This is useful for us in generating framework bindings in macdriver, but it would be useful for any project doing similar work, such as bindings for other languages. This sort of approach will play a big part in how Tractor will integrate with "whatever we want" down the line.
-
Apple API schemas for code generation and more
If this is interesting, take a look at the tool I built, macschema, which is open source on GitHub. Right now it's just the toolchain, but in theory we could generate schemas for all of Apple's APIs and put them in a repo in such a way that can be updated by a combination of macschema and user contributed patches. I'll let somebody else do that though.
qmux
-
Making programs interact using qtalk
The connection multiplexing layer is based on qmux, a subset of SSH that I've written about previously. It was designed to optionally be swapped out with QUIC as needed. Either way, everything in qtalk happens over flow-controlled channels, which can be used like embedded TCP streams. Whatever you do with qtalk, you can also tunnel other connections and protocols on the same connection.
-
Towards the Personal Potential of Software
Unrelated to macdriver, I released a protocol called qmux with a post explaining why this (but really any) muxing protocol, including and especially QUIC, is such a great primitive for network programming. The project came with two implementations, Go and TypeScript, with more on the way. The post about it was the first explainer article I'd done in a while and people liked it. This was important because the idea behind it was really more valuable than the protocol itself, but regardless we still need implementations of it to exist. To show the idea in action, I built a 130 line version of Ngrok, which turned into a great post walking through how it works.
-
Building your own Ngrok in 130 lines
What qmux does is give us a subset of the SSH protocol to multiplex many connections over a single connection. It was the missing piece of my original Twisted prototype. You can read more about how there aren't a lot of these protocols (but perhaps with QUIC are also the future of the Internet) in my previous post.
-
The History and Future of Socket-level Multiplexing
If nothing else, I hope people use this story as inspiration to think about using multiplexing to design better, simpler application protocols. Even if for some reason QUIC isn't the future, you now have qmux!
What are some alternatives?
cool - Never let the heat slow your pre-2018 Mac down again.
localtunnel - Expose localhost servers to the Internet
vz - Create virtual machines and run Linux-based operating systems in Go using Apple Virtualization.framework.
topframe - Local webpage screen overlay for customizing your computing experience
macdriver - Native Mac APIs for Go. Soon to be renamed DarwinKit!
webtransport - WebTransport is a web API for flexible data transport
go-vhost - HTTP/TLS hostname multiplexing library for Go
schemata - Helper methods for creating test schemas in PostgreSQL databases with copies of tables from the live schema for unit testing.
qtalk-go - versatile stream IO and RPC based IPC stack for Go
supervillain - Converts Go structs to Zod schemas