Removed extra directories
This commit is contained in:
parent
edd6e82c2c
commit
c2f857fc88
@ -1,40 +0,0 @@
|
||||
#include "../common/common.h"
|
||||
|
||||
void readline(int count, char* buffer) {
|
||||
int index = 0;
|
||||
char c;
|
||||
while (index < count) {
|
||||
if (read(1, 1, &c)) {
|
||||
if (c == '\n')
|
||||
break;
|
||||
if (c == '\b') {
|
||||
if (index == 0)
|
||||
continue;
|
||||
else {
|
||||
index--;
|
||||
buffer[index] = 0;
|
||||
write(1, 0, &c);
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
buffer[index++] = c;
|
||||
write(1, 0, &c);
|
||||
}
|
||||
}
|
||||
print("\n");
|
||||
}
|
||||
|
||||
int main() {
|
||||
print("Hello, World!\n");
|
||||
char buffer[32];
|
||||
while (1) {
|
||||
for (int i=0; i<32; i++)
|
||||
buffer[i] = 0;
|
||||
print(">>> ");
|
||||
readline(32, buffer);
|
||||
print("You said: ");
|
||||
print(buffer);
|
||||
print("\n\n");
|
||||
}
|
||||
}
|
@ -1,14 +0,0 @@
|
||||
OUTPUT_FORMAT(binary)
|
||||
OUTPUT_ARCH(i386:i386)
|
||||
|
||||
OUTPUT(build/hello/hello.bin)
|
||||
|
||||
SECTIONS {
|
||||
. = 0x20;
|
||||
|
||||
.text : {
|
||||
build/program_code_entry.o(.text)
|
||||
build/hello/hello.o(.text)
|
||||
build/common/common.o(.text)
|
||||
}
|
||||
}
|
@ -1,20 +0,0 @@
|
||||
#include "../kernel/types.h"
|
||||
#include "../common/common.h"
|
||||
|
||||
int main() {
|
||||
print("Testing C code program\n");
|
||||
print("My strings are messed up for some reason...\n");
|
||||
|
||||
uint32_t alpha_size = filesize("HELLO TXT");
|
||||
char sizebuf[32];
|
||||
uint32_t index = int_to_decimal(alpha_size, sizebuf);
|
||||
print(sizebuf+index);
|
||||
print("\n");
|
||||
uint8_t* alpha_buffer = (uint8_t*)localalloc(alpha_size + 32);
|
||||
print("alpha_buffer: ");
|
||||
index = int_to_hex(alpha_buffer, sizebuf);
|
||||
print(sizebuf+index);
|
||||
print("\n");
|
||||
readfile("HELLO TXT", alpha_buffer);
|
||||
print(alpha_buffer);
|
||||
}
|
@ -1,14 +0,0 @@
|
||||
OUTPUT_FORMAT(binary)
|
||||
OUTPUT_ARCH(i386:i386)
|
||||
|
||||
OUTPUT(build/program/program.bin)
|
||||
|
||||
SECTIONS {
|
||||
. = 0x20;
|
||||
|
||||
.text : {
|
||||
build/program_code_entry.o(.text)
|
||||
build/program/program.o(.text)
|
||||
build/common/common.o(.text)
|
||||
}
|
||||
}
|
@ -1,283 +0,0 @@
|
||||
#include "../common/common.h"
|
||||
#include <stdbool.h>
|
||||
|
||||
typedef struct {
|
||||
char* buffer;
|
||||
int x;
|
||||
int y;
|
||||
uint32_t process;
|
||||
uint32_t stdin;
|
||||
uint32_t stdout;
|
||||
} procbuffer;
|
||||
|
||||
void scrollBuffer(char* buf) {
|
||||
for (int y=0; y<56; y++)
|
||||
for (int x=0; x<43; x++)
|
||||
if (y != 55)
|
||||
buf[y*43+x] = buf[(y+1)*43+x];
|
||||
else
|
||||
buf[y*43+x] = ' ';
|
||||
}
|
||||
|
||||
void writeToBuf(char c, procbuffer* buf) {
|
||||
switch (c) {
|
||||
case '\n':
|
||||
buf->x = 0;
|
||||
buf->y++;
|
||||
break;
|
||||
|
||||
case '\b':
|
||||
if (buf->x > 0)
|
||||
buf->x--;
|
||||
else if (buf->y > 0) {
|
||||
buf->x = 42;
|
||||
buf->y--;
|
||||
}
|
||||
buf->buffer[buf->y*43+buf->x] = ' ';
|
||||
break;
|
||||
|
||||
default:
|
||||
buf->buffer[buf->y*43+buf->x++] = c;
|
||||
}
|
||||
if (buf->x == 43) {
|
||||
buf->x = 0;
|
||||
buf->y++;
|
||||
}
|
||||
if (buf->y == 56) {
|
||||
buf->y--;
|
||||
scrollBuffer(buf->buffer);
|
||||
}
|
||||
}
|
||||
|
||||
void writeCountToBuf(int count, char* c, procbuffer* buf) {
|
||||
while (count--) {
|
||||
writeToBuf(*(c++), buf);
|
||||
}
|
||||
}
|
||||
|
||||
void clearBuf(procbuffer* buf) {
|
||||
for (int i=0; i<56*43;i++) {
|
||||
buf->buffer[i] = ' ';
|
||||
}
|
||||
buf->x = 0;
|
||||
buf->y = 0;
|
||||
}
|
||||
|
||||
void writeStrToBuf(char* c, procbuffer* b) {
|
||||
char* s = c;
|
||||
while(*s)
|
||||
writeToBuf(*(s++), b);
|
||||
}
|
||||
|
||||
void displayBuf(procbuffer* b, int dx, int dy) {
|
||||
char pset[9] = "\x1b[00;00H";
|
||||
for (int i=0; i<dy;i++) {
|
||||
pset[3]++;
|
||||
if (pset[3] == 0x3a) {
|
||||
pset[3] = 0x30;
|
||||
pset[2]++;
|
||||
}
|
||||
}
|
||||
for (int i=0; i<dx;i++) {
|
||||
pset[6]++;
|
||||
if (pset[6] == 0x3a) {
|
||||
pset[6] = 0x30;
|
||||
pset[5]++;
|
||||
}
|
||||
}
|
||||
for (int i=0; i<56; i++) {
|
||||
print(pset);
|
||||
write(43, 0, b->buffer+(43*i));
|
||||
pset[3]++;
|
||||
if (pset[3] == 0x3a) {
|
||||
pset[3] = 0x30;
|
||||
pset[2]++;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void setCurPos(int x, int y) {
|
||||
char pset[9] = "\x1b[00;00H";
|
||||
for (int i=0; i<y;i++) {
|
||||
pset[3]++;
|
||||
if (pset[3] == 0x3a) {
|
||||
pset[3] = 0x30;
|
||||
pset[2]++;
|
||||
}
|
||||
}
|
||||
for (int i=0; i<x;i++) {
|
||||
pset[6]++;
|
||||
if (pset[6] == 0x3a) {
|
||||
pset[6] = 0x30;
|
||||
pset[5]++;
|
||||
}
|
||||
}
|
||||
print(pset);
|
||||
}
|
||||
|
||||
void readline(int count, char* buffer) {
|
||||
int index = 0;
|
||||
char c;
|
||||
while (index < count) {
|
||||
if (read(1, 1, &c)) {
|
||||
if (c == '\n')
|
||||
break;
|
||||
if (c == '\b') {
|
||||
if (index == 0)
|
||||
continue;
|
||||
else {
|
||||
index--;
|
||||
buffer[index] = 0;
|
||||
write(1, 0, &c);
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
buffer[index++] = c;
|
||||
write(1, 0, &c);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
bool strcmp(char* a, char* b) {
|
||||
int index=0;
|
||||
while (a[index])
|
||||
if (a[index] == b[index])
|
||||
index++;
|
||||
else
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool strcmpcnt(int count, char* a, char* b) {
|
||||
int index=0;
|
||||
while (index < count)
|
||||
if (a[index] == b[index])
|
||||
index++;
|
||||
else
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
int main() {
|
||||
bindToKeyboard();
|
||||
|
||||
char space = ' ';
|
||||
char plus = '+';
|
||||
|
||||
print("\x1b[1;1H");
|
||||
for (int i=0; i < 1000; i++)
|
||||
write(1, 0, &space);
|
||||
print("\x1b[1;1H");
|
||||
|
||||
char* mid = "+ ++ +";
|
||||
char* bottom = "+ +";
|
||||
for (int i=0; i<90;i++)
|
||||
write(1, 0, &plus);
|
||||
for (int i=0; i<56;i++)
|
||||
write(90, 0, mid);
|
||||
for (int i=0; i<90;i++)
|
||||
write(1, 0, &plus);
|
||||
write(90, 0, bottom);
|
||||
for (int i=0; i<90;i++)
|
||||
write(1, 0, &plus);
|
||||
|
||||
uint32_t program = fopen("hello.bin");
|
||||
uint32_t p1 = fork(program);
|
||||
uint32_t p1out = bindStdout(p1);
|
||||
uint32_t p1in = bindStdin(p1);
|
||||
fclose(program);
|
||||
program = fopen("hello.bin");
|
||||
uint32_t p2 = fork(program);
|
||||
uint32_t p2out = bindStdout(p2);
|
||||
uint32_t p2in = bindStdin(p2);
|
||||
fclose(program);
|
||||
|
||||
procbuffer b1 = {
|
||||
.buffer = localalloc(56 * 43),
|
||||
.x = 0,
|
||||
.y = 0,
|
||||
.process = p1,
|
||||
.stdin = p1in,
|
||||
.stdout = p1out
|
||||
};
|
||||
|
||||
procbuffer b2 = {
|
||||
.buffer = localalloc(56 * 43),
|
||||
.x = 0,
|
||||
.y = 0,
|
||||
.process = p2,
|
||||
.stdin = p2in,
|
||||
.stdout = p2out
|
||||
};
|
||||
|
||||
procbuffer* selectedBuf = &b1;
|
||||
|
||||
writeStrToBuf("XoSH (XOS SHell) v0.0.1\nPress : to use commands.\n :help for help.\n", &b1);
|
||||
|
||||
while (1) {
|
||||
char c[128];
|
||||
int succ = 0;
|
||||
if (b1.process)
|
||||
if (succ = read(128, b1.stdout, c))
|
||||
writeCountToBuf(succ, c, &b1);
|
||||
if (b2.process)
|
||||
if (succ = read(128, b2.stdout, c))
|
||||
writeCountToBuf(succ, c, &b2);
|
||||
if (read(1, 1, c)) {
|
||||
if (c[0] == ':') {
|
||||
char buf[32] = {0};
|
||||
print("\x1b[59;2H");
|
||||
print(": ");
|
||||
print("\x1b[59;3H");
|
||||
readline(32, buf);
|
||||
if (strcmpcnt(6, buf, "switch")) {
|
||||
if (selectedBuf == &b1) {
|
||||
selectedBuf = &b2;
|
||||
} else {
|
||||
selectedBuf = &b1;
|
||||
}
|
||||
} else if (strcmpcnt(4, buf, "help")) {
|
||||
writeStrToBuf("\n--------\n", selectedBuf);
|
||||
writeStrToBuf(":help\n", selectedBuf);
|
||||
writeStrToBuf(" Displays this message.\n", selectedBuf);
|
||||
writeStrToBuf(":switch\n", selectedBuf);
|
||||
writeStrToBuf(" Switches which process you're using\n", selectedBuf);
|
||||
writeStrToBuf(":kill\n", selectedBuf);
|
||||
writeStrToBuf(" Kills the current process\n", selectedBuf);
|
||||
writeStrToBuf(":load <filename>\n", selectedBuf);
|
||||
writeStrToBuf(" Loads and executes the program <filename>\n", selectedBuf);
|
||||
writeStrToBuf("--------\n", selectedBuf);
|
||||
} else if (strcmpcnt(4, buf, "kill")) {
|
||||
if (selectedBuf->process) {
|
||||
kill(selectedBuf->process);
|
||||
clearBuf(selectedBuf);
|
||||
selectedBuf->process = 0;
|
||||
selectedBuf->stdin = 0;
|
||||
selectedBuf->stdout = 0;
|
||||
if (selectedBuf == &b1) {
|
||||
selectedBuf = &b2;
|
||||
} else {
|
||||
selectedBuf = &b1;
|
||||
}
|
||||
}
|
||||
} else if (strcmpcnt(4, buf, "load")) {
|
||||
if (!selectedBuf->process) {
|
||||
char* potFn = buf+5;
|
||||
uint32_t fh = fopen(potFn);
|
||||
selectedBuf->process = fork(fh);
|
||||
selectedBuf->stdout = bindStdout(selectedBuf->process);
|
||||
selectedBuf->stdin = bindStdin(selectedBuf->process);
|
||||
fclose(fh);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if (selectedBuf->process)
|
||||
write(1, selectedBuf->stdin, c);
|
||||
}
|
||||
}
|
||||
|
||||
displayBuf(&b1, 2, 2);
|
||||
displayBuf(&b2, 47, 2);
|
||||
}
|
||||
}
|
@ -1,14 +0,0 @@
|
||||
OUTPUT_FORMAT(binary)
|
||||
OUTPUT_ARCH(i386:i386)
|
||||
|
||||
OUTPUT(build/world/world.bin)
|
||||
|
||||
SECTIONS {
|
||||
. = 0x20;
|
||||
|
||||
.text : {
|
||||
build/program_code_entry.o(.text)
|
||||
build/world/world.o(.text)
|
||||
build/common/common.o(.text)
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user