Files
jsix/src/user/6s/main.cpp
Justin C. Miller eb62588b79 [6s] Allow 6s to know about filesystems
Added a j6_proto_vfs_tag/_get_tag pair of messages to the VFS protocol
to allow filesystems to label themselves, and gave 6s the concept of
current fs and current working directory.
2024-04-30 22:23:04 -07:00

120 lines
2.8 KiB
C++

#include <string.h>
#include <j6/channel.hh>
#include <j6/init.h>
#include <j6/errors.h>
#include <j6/memutils.h>
#include <j6/protocols/service_locator.hh>
#include <j6/ring_buffer.hh>
#include <j6/syscalls.h>
#include <j6/syslog.hh>
#include <j6/types.h>
#include <edit/line.h>
#include "shell.h"
extern "C" {
int main(int, const char **);
}
//j6_handle_t g_handle_sys = j6_handle_invalid;
const char prompt[] = "\x1b[1;32mj6> \x1b[0m";
static constexpr size_t prompt_len = sizeof(prompt) - 1;
const char greeting[] = "\x1b[2J\x1b[H\x1b[1;30m\
\r\n Welcome to the \x1b[34mjsix\x1b[30m Operating System!\
\r\n \
\r\n This is the \x1b[34m6s\x1b[30m command shell, type `\x1b[4;33mhelp\x1b[0;1;30m`\
\r\n for a list of commands.\
\r\n\r\n\x1b[0m";
static constexpr size_t greeting_len = sizeof(greeting) - 1;
class channel_source :
public edit::source
{
public:
channel_source(j6::channel &chan) : m_chan {chan} {}
size_t read(char const **data) override {
return m_chan.get_block(reinterpret_cast<uint8_t const**>(data));
}
void consume(size_t size) override { return m_chan.consume(size); }
void write(char const *data, size_t len) override {
uint8_t *outp;
while (len) {
size_t size = m_chan.reserve(len, &outp);
size_t n = len < size ? len : size;
memcpy(outp, data, n);
m_chan.commit(n);
len -= n;
}
}
private:
j6::channel &m_chan;
};
int
main(int argc, const char **argv)
{
j6_handle_t event = j6_handle_invalid;
j6_status_t result = j6_status_ok;
/*
g_handle_sys = j6_find_init_handle(0);
if (g_handle_sys == j6_handle_invalid)
return 1;
*/
j6_handle_t slp = j6_find_init_handle(j6::proto::sl::id);
if (slp == j6_handle_invalid)
return 3;
j6_handle_t vfs = j6_find_init_handle(j6::proto::vfs::id);
if (vfs == j6_handle_invalid)
return 4;
uint64_t proto_id = "jsix.protocol.stream.ouput"_id;
j6::proto::sl::client slp_client {slp};
j6_handle_t chan_handles[2];
util::counted<j6_handle_t> handles {chan_handles, 2};
for (unsigned i = 0; i < 100; ++i) {
j6_status_t s = slp_client.lookup_service(proto_id, handles);
if (s == j6_status_ok && handles.count)
break;
j6_thread_sleep(10000); // 10ms
}
if (!handles.count)
return 4;
j6::channel *cout = j6::channel::open({chan_handles[0], chan_handles[1]});
if (!cout)
return 5;
channel_source source {*cout};
edit::line editor {source};
shell sh { source };
sh.add_filesystem(vfs);
static constexpr size_t bufsize = 256;
char buffer [bufsize];
source.write(greeting, greeting_len);
while (true) {
size_t len = editor.read(buffer, bufsize, prompt, prompt_len);
sh.handle_command(buffer, len);
}
}