summaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
Diffstat (limited to 'main.c')
-rw-r--r--main.c58
1 files changed, 58 insertions, 0 deletions
diff --git a/main.c b/main.c
new file mode 100644
index 0000000..cafd0c9
--- /dev/null
+++ b/main.c
@@ -0,0 +1,58 @@
+#include <mach.h>
+#include <error.h>
+#include <argp.h>
+#include <hurd/netfs.h>
+#include "procfs.h"
+
+static error_t get_contents (void *hook, void **contents, size_t *contents_len)
+{
+ static const char hello[] = "Hello, World!\n";
+ *contents = (void *) hello;
+ *contents_len = sizeof hello - 1;
+ return 0;
+}
+
+static error_t get_entries (void *hook, void **contents, size_t *contents_len)
+{
+ static const char entries[] = "hello";
+ *contents = (void *) entries;
+ *contents_len = sizeof entries;
+ return 0;
+}
+
+static error_t lookup (void *hook, const char *name, struct node **np)
+{
+ static const struct procfs_node_ops ops = { .get_contents = get_contents };
+
+ if (strcmp (name, "hello"))
+ return ENOENT;
+
+ *np = procfs_make_node (&ops, NULL);
+ if (! *np)
+ return ENOMEM;
+
+ return 0;
+}
+
+int main (int argc, char **argv)
+{
+ static const struct procfs_node_ops ops = {
+ .get_contents = get_entries,
+ .lookup = lookup,
+ };
+ mach_port_t bootstrap;
+
+ argp_parse (&netfs_std_startup_argp, argc, argv, 0, 0, 0);
+
+ task_get_bootstrap_port (mach_task_self (), &bootstrap);
+ if (bootstrap == MACH_PORT_NULL)
+ error (1, 0, "Must be started as a translator");
+
+ netfs_init ();
+ netfs_root_node = procfs_make_node (&ops, NULL);
+
+ netfs_startup (bootstrap, 0);
+ for (;;)
+ netfs_server_loop ();
+}
+