aboutsummaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
2021-12-10Chore: merge main into laptopselfhostNicholas
2021-12-10Checkin: small sprawling updatesNicholas Noll
Small touches to multiple locations in base. Nothing major
2021-12-05Chore: updated fs·walk to use new data structuresNicholas Noll
Completes the port to our standard library (up to malloc).
2021-12-05Chore: updated fs·walk to use new data structuresNicholas Noll
Completes the port to our standard library (up to malloc).
2021-12-05Feat: added math libraryNicholas Noll
Used Plan9's libc as starting point. This cleans up dangling references due to loss of libc.
2021-12-05feat(huge): huge refactor (in progress).Nicholas Noll
Commented out libc includes to uncover all explicit dependencies. A large fraction has now been ported over (no testing). I did not port over the command line tools, such as the rc shell. These will be done independently - as of now I just want the library to stand independent. Compilation currently fails due to the lack of math functions.
2021-12-05Chore: simplified allocator interfaces.Nicholas Noll
I was never happy with the allocator/reallocator split. It was originally designed to accomodate things like arenas that don't free. But the majority of the time you don't care about this.
2021-12-05Chore: more explicit namespace for memory bufferNicholas Noll
2021-12-05Feat: basic string and memory functionsNicholas Noll
Continue filling out the basic standard lib functions. Included prototypes of the str* and mem* families. Plan to add e(str|mem) and n(str|mem) variants as well.
2021-12-05Feat: libbase partitioning. Cleaned up hash map macros.Nicholas Noll
Additionally, fixed varargs cleanup when done with fmt.write. Some system constants were added to allow for directory walking.
2021-12-04chore(rm): removed small os package. moved functions to filesystemNicholas Noll
2021-12-04Chore(REMOVE): finished deprecation of old io functions.Nicholas Noll
The old methods were simple wrappers of C standard library functions. We've moved (painfully) over to a new interface that allows for files to live on the stack. All users of the functionality are ported over.
2021-12-03Fix(fmt): incorrect, uninitialized variable usedNicholas Noll
2021-12-02many small updatesNicholas Noll
2021-12-02Chore(config): changed font sizes for desktopNicholas Noll
Also updated libraries in makefiles that were deprecated.
2021-12-01fix: group emailNicholas
2021-11-20Feat: added buffered io from plan9Nicholas
As we no longer have the FILE type, we need to buffer our reading and writing so that we don't have to make so many syscalls. The API is nice so that we can buffer other readers. We will update it so that it eats io·Readers/io·Writers.
2021-11-20Chore: cleaned up the exit code to cleanly interface with libcNicholas
We use weak linking to ensure we clean up at exit time correctly. If libc is linked, then we call our cleanup function by registering an atexit callback with the library. If libc is not linked, we have a weak symbol that results in a noop. Similarly, if we call rt·exit while linked with libc, this immediately calls libc's exit (which will call our cleanup as we registered it). If we are not linked to libc, exit() is given as a weak link to a noop function.
2021-11-20chore: simplify makefilesNicholas
2021-11-20Chore: reorganize libutf and libfmt into baseNicholas
I found the split to be arbitrary. Better to include the functionality in the standard library. I also split the headers to allow for more granular inclusion (but the library is still monolithic). The only ugliness is the circular dependency introduced with libutf's generated functions. We put explicit prereqs with the necessary object files instead.
2021-11-20Feature: self hosting prototype implementedNicholas Noll
This is a large change. In order to remove myself from libc's arcane interface, I implemented an independent runtime layer. It is based on musl's wonderful implementation mostly. Critically, if libc is linked to the program, then we cooperate. Namely, we call start main and let libc do all initialization. If not, then we have a noop defined in rt3.a. The general structure of the file is: 1. sys/$os/$arch contains all architecture dependent code 2. sys/$os/port contains all code that depends on the os, but is portable 3. rt/$arch contains all the runtime architecture dependent code 4. rt/* contains the portable runtime code. Obviously testing is needed. Specifically, while code is checked in for the most popular architectures, it only has been tested on one computer! Overall this is exciting and as been educational.
2021-11-19chore: make dependence on static syscalls explicitNicholas Noll
2021-11-18feat: continued filling out system layerNicholas Noll
2021-11-18feat: filling out system layer's interfaceNicholas Noll
2021-11-18filling out system layerNicholas Noll
2021-11-18added more syscallsNicholas
2021-11-17automated platform specific code parsingNicholas Noll
2021-11-17update: sysNicholas
2021-11-17fix: mkfile namesNicholas
2021-11-17checkinNicholas
2021-11-16checkinNicholas Noll
2021-11-16Feat: added fd duplicationsNicholas Noll
2021-11-16chore: integrated redir codeNicholas Noll
2021-11-16Feat: added heredocsNicholas Noll
Heredocs are simply strings written to tmp files. There was minimal bug testing here. Also, various bug fixes are included
2021-11-15Feat: added functionsNicholas
2021-11-15Feat: added match keywordNicholas
However, it is not tested in the slightest.
2021-11-15Feat: globbingNicholas
Introduced shell globbing
2021-11-15Fix: Qsort had bad macro captureNicholas
2021-11-15Feat: prototype of self-hosted libraryNicholas
This is very much a work in progress. Still ruminating on the structure of the library. It feels right but I want a more "social" presence - namely the ability to link to a libc seemlessly. The solution is most likely weak aliasing that musl uses - but musl itself weak aliases global symbols, e.g malloc. We would have to define weak internal symbols that musl defines as strong links but this knows too much about the internals of musl...
2021-11-15Feat: added if/else branching and switch statementNicholas
Unsure about my modification to the language. I found the parsing of the case body within switches to be odd - specifically that it parses liberally and then checks that it has case -> cmd structuring while it walks the code. This means the language is more permissive than the semantics. I modified it to be more explicit, but at the cost of having to end each case statement with a semicolon. I wanted a colon, but this is a valid word character and thus will be lexed as part of the word.
2021-11-15Chore: updated build pathsNicholas
2021-11-12chore: error->intNicholas
2021-11-12chore: simplified organizational structurelaptopNicholas
2021-11-11chore: merge master into laptopNicholas
2021-11-11chore: split up base library into individual files for smaller binariesNicholas Noll
2021-11-11feat: libfmt prototype added from plan9Nicholas Noll
2021-11-11chore: update desktopNicholas Noll
2021-11-11chore: updated old copy of mkrunewidthNicholas
2021-11-11chore: forgot to move old generatorsNicholas
2021-11-11feat: added libfmtNicholas