sh.cpp 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #include <LibC/stdio.h>
  2. #include <LibC/unistd.h>
  3. #include <LibC/process.h>
  4. static void prompt()
  5. {
  6. if (getuid() == 0)
  7. printf("# ");
  8. else
  9. printf("$ ");
  10. }
  11. static int runcmd(char* cmd)
  12. {
  13. //printf("command: '%s'\n", cmd);
  14. char buf[128];
  15. sprintf(buf, "/bin/%s", cmd);
  16. int ret = spawn(buf);
  17. if (ret == -1) {
  18. printf("spawn failed: %s\n", cmd);
  19. }
  20. return 0;
  21. }
  22. int main(int c, char** v)
  23. {
  24. char linebuf[128];
  25. int linedx = 0;
  26. linebuf[0] = '\0';
  27. int fd = open("/dev/keyboard");
  28. if (fd == -1) {
  29. printf("failed to open /dev/keyboard :(\n");
  30. return 1;
  31. }
  32. prompt();
  33. for (;;) {
  34. char keybuf[16];
  35. ssize_t nread = read(fd, keybuf, sizeof(keybuf));
  36. if (nread < 0) {
  37. printf("failed to read :(\n");
  38. return 2;
  39. }
  40. if (nread > 2)
  41. printf("read %u bytes\n", nread);
  42. if (nread > (ssize_t)sizeof(keybuf)) {
  43. printf("read() overran the buffer i gave it!\n");
  44. return 3;
  45. }
  46. for (ssize_t i = 0; i < nread; ++i) {
  47. putchar(keybuf[i]);
  48. if (keybuf[i] != '\n') {
  49. linebuf[linedx++] = keybuf[i];
  50. linebuf[linedx] = '\0';
  51. } else {
  52. runcmd(linebuf);
  53. linebuf[0] = '\0';
  54. linedx = 0;
  55. prompt();
  56. }
  57. }
  58. }
  59. return 0;
  60. }