commit: 1099963760637b553dc7fc0b1815c801c0a6b600
parent 358353a223b8bab635e49fb1d0073e2849d2c3b4
Author: Drew DeVault <sir@cmpwn.com>
Date: Thu, 15 Apr 2021 09:22:21 -0400
Status update
Diffstat:
2 files changed, 100 insertions(+), 0 deletions(-)
diff --git a/content/blog/Status-update-April-2021.gmi b/content/blog/Status-update-April-2021.gmi
@@ -0,0 +1,40 @@
+Another month goes by! I’m afraid that I have very little to share this month. You can check out the sourcehut “what’s cooking” post for sourcehut news, but outside of that I have focused almost entirely on the programming language project this month, for which the details are kept private.
+
+The post calling for contributors led to a lot of answers and we’ve brought several new people on board — thanks for answering the call! I’d like to narrow the range of problems we still need help with. If you’re interested in (and experienced in) the following problems, we need your help:
+
+* Cryptography
+* Date/time support
+* Networking (DNS is up next)
+
+Shoot me an email (sir@cmpwn.com) if you want to help. We don’t have the bandwidth to mentor inexperienced programmers right now, so please only reach out if you have an established background in systems programming.
+
+Here’s a teaser of one of the stdlib APIs written by our new contributors, unix::passwd:
+
+```
+// A Unix-like group file entry.
+export type grent = struct {
+ // Name of the group
+ name: str,
+ // Optional encrypted password
+ password: str,
+ // Numerical group ID
+ gid: uint,
+ // List of usernames that are members of this group, comma separated
+ userlist: str,
+};
+
+// Reads a Unix-like group entry from a stream. The caller must free the result
+// using [grent_finish].
+export fn nextgr(stream: *io::stream) (grent | io::EOF | io::error | invalid);
+
+// Frees resources associated with [grent].
+export fn grent_finish(ent: grent) void;
+
+// Looks up a group by name in a Unix-like group file. It expects a such file at
+// /etc/group. Aborts if that file doesn't exist or is not properly formatted.
+//
+// See [nextgr] for low-level parsing API.
+export fn getgroup(name: str) (grent | void);
+```
+
+That’s all for now. These updates might be light on details for a while as we work on this project. See you next time!
diff --git a/content/blog/Status-update-April-2021.md b/content/blog/Status-update-April-2021.md
@@ -0,0 +1,60 @@
+---
+title: Status update, April 2021
+date: 2021-04-15
+outputs: [html, gemtext]
+---
+
+Another month goes by! I'm afraid that I have very little to share this month.
+You can check out the [sourcehut "what's cooking" post][0] for sourcehut news,
+but outside of that I have focused almost entirely on the programming language
+project this month, for which the details are kept private.
+
+[0]: https://sourcehut.org/blog/2021-04-15-whats-cooking-april-2021/
+
+The post [calling for contributors][1] led to a lot of answers and we've brought
+several new people on board — thanks for answering the call! I'd like to
+narrow the range of problems we still need help with. If you're interested in
+(and experienced in) the following problems, we need your help:
+
+[1]: https://drewdevault.com/2021/03/19/A-new-systems-language.html
+
+- Cryptography
+- Date/time support
+- Networking (DNS is up next)
+
+[Shoot me an email](mailto:sir@cmpwn.com) if you want to help. We don't have the
+bandwidth to mentor inexperienced programmers right now, so please only reach
+out if you have an established background in systems programming.
+
+Here's a teaser of one of the stdlib APIs written by our new contributors,
+unix::passwd:
+
+```hare
+// A Unix-like group file entry.
+export type grent = struct {
+ // Name of the group
+ name: str,
+ // Optional encrypted password
+ password: str,
+ // Numerical group ID
+ gid: uint,
+ // List of usernames that are members of this group, comma separated
+ userlist: str,
+};
+
+// Reads a Unix-like group entry from a stream. The caller must free the result
+// using [grent_finish].
+export fn nextgr(stream: *io::stream) (grent | io::EOF | io::error | invalid);
+
+// Frees resources associated with [grent].
+export fn grent_finish(ent: grent) void;
+
+// Looks up a group by name in a Unix-like group file. It expects a such file at
+// /etc/group. Aborts if that file doesn't exist or is not properly formatted.
+//
+// See [nextgr] for low-level parsing API.
+export fn getgroup(name: str) (grent | void);
+```
+
+That's all for now. These updates might be light on details for a while as we
+work on this project. See you next time!