src/doc.c
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 |
#ifndef HEX_H #include "hex.h" #endif //////////////////////////////////////// // Help System // //////////////////////////////////////// void hex_set_doc(hex_doc_dictionary_t *dict, const char *name, const char *input, const char *output, const char *description) { hex_doc_entry_t doc = {.name = name, .description = description, .input = input, .output = output}; // No overflow check as the dictionary is fixed size dict->entries[dict->size] = doc; dict->size++; } int hex_get_doc(hex_doc_dictionary_t *docs, const char *key, hex_doc_entry_t *result) { for (size_t i = 0; i < docs->size; i++) { if (strcmp(docs->entries[i].name, key) == 0) { *result = docs->entries[i]; return 1; } } return 0; } void hex_create_docs(hex_doc_dictionary_t *docs) { // Memory hex_set_doc(docs, ":", "a s", "", "Stores 'a' as the literal symbol 's'."); hex_set_doc(docs, "::", "a s", "", "Defines 'a' as the operator symbol 's'."); hex_set_doc(docs, "#", "s", "", "Deletes user symbol 's'."); hex_set_doc(docs, "symbols", "", "q", "Pushes a quotation containing all registered symbols on the stack."); // Control flow hex_set_doc(docs, "if", "q q q", "*", "If 'q1' is not 0x0, executes 'q2', else 'q3'."); hex_set_doc(docs, "when", "q1 q2", "*", "If 'q1' is not 0x0, executes 'q2'."); hex_set_doc(docs, "while", "q1 q2", "*", "While 'q1' is not 0x0, executes 'q2'."); hex_set_doc(docs, "error", "", "s", "Returns the last error message."); hex_set_doc(docs, "try", "q1 q2", "*", "If 'q1' fails, executes 'q2'."); hex_set_doc(docs, "throw", "s", "", "Throws error 's'."); // Stack hex_set_doc(docs, "dup", "a", "a a", "Duplicates 'a'."); hex_set_doc(docs, "pop", "a", "", "Removes the top item from the stack."); hex_set_doc(docs, "swap", "a1 a2", "a2 a1", "Swaps 'a2' with 'a1'."); hex_set_doc(docs, "stack", "", "q", "Returns the contents of the stack."); // Evaluation hex_set_doc(docs, ".", "q", "*", "Pushes each item of 'q' on the stack."); hex_set_doc(docs, "!", "(s|q)", "*", "Evaluates 's' as a hex program or 'q' as hex bytecode."); hex_set_doc(docs, "'", "a", "q", "Wraps 'a' in a quotation."); // Arithmetic hex_set_doc(docs, "+", "i1 12", "i", "Adds two integers."); hex_set_doc(docs, "-", "i1 12", "i", "Subtracts 'i2' from 'i1'."); hex_set_doc(docs, "*", "i1 12", "i", "Multiplies two integers."); hex_set_doc(docs, "/", "i1 12", "i", "Divides 'i1' by 'i2'."); hex_set_doc(docs, "%", "i1 12", "i", "Calculates the modulo of 'i1' divided by 'i2'."); // Bitwise hex_set_doc(docs, "&", "i1 12", "i", "Calculates the bitwise AND of two integers."); hex_set_doc(docs, "|", "i1 12", "i", "Calculates the bitwise OR of two integers."); hex_set_doc(docs, "^", "i1 12", "i", "Calculates the bitwise XOR of two integers."); hex_set_doc(docs, "~", "i", "i", "Calculates the bitwise NOT of an integer."); hex_set_doc(docs, "<<", "i1 12", "i", "Shifts 'i1' by 'i2' bytes to the left."); hex_set_doc(docs, ">>", "i1 12", "i", "Shifts 'i1' by 'i2' bytes to the right."); // Comparison hex_set_doc(docs, "==", "a1 a2", "i", "Returns 0x1 if 'a1' == 'a2', 0x0 otherwise."); hex_set_doc(docs, "!=", "a1 a2", "i", "Returns 0x1 if 'a1' != 'a2', 0x0 otherwise."); hex_set_doc(docs, ">", "a1 a2", "i", "Returns 0x1 if 'a1' > 'a2', 0x0 otherwise."); hex_set_doc(docs, "<", "a1 a2", "i", "Returns 0x1 if 'a1' < 'a2', 0x0 otherwise."); hex_set_doc(docs, ">=", "a1 a2", "i", "Returns 0x1 if 'a1' >= 'a2', 0x0 otherwise."); hex_set_doc(docs, "<=", "a1 a2", "i", "Returns 0x1 if 'a1' <= 'a2', 0x0 otherwise."); // Logical hex_set_doc(docs, "and", "i1 i2", "i", "Returns 0x1 if both 'i1' and 'i2' are not 0x0."); hex_set_doc(docs, "or", "i1 i2", "i", "Returns 0x1 if either 'i1' or 'i2' are not 0x0."); hex_set_doc(docs, "not", "i", "i", "Returns 0x1 if 'i' is 0x0, 0x0 otherwise."); hex_set_doc(docs, "xor", "i1 i2", "i", "Returns 0x1 if only one item is not 0x0."); // Type hex_set_doc(docs, "int", "s", "i", "Converts a string to a hex integer."); hex_set_doc(docs, "str", "i", "s", "Converts a hex integer to a string."); hex_set_doc(docs, "dec", "i", "s", "Converts a hex integer to a decimal string."); hex_set_doc(docs, "hex", "s", "i", "Converter a decimal string to a hex integer."); hex_set_doc(docs, "chr", "i", "s", "Converts an integer to a single-character."); hex_set_doc(docs, "ord", "s", "i", "Converts a single-character to an integer."); hex_set_doc(docs, "type", "a", "s", "Pushes the data type of 'a' on the stack."); // List hex_set_doc(docs, "cat", "(s1 s2|q1 q2) ", "(s3|q3)", "Concatenates two quotations or two strings."); hex_set_doc(docs, "len", "(s|q)", "i ", "Returns the length of 's' or 'q'."); hex_set_doc(docs, "get", "(s|q)", "a", "Gets the item at position 'i' in 's' or 'q'."); hex_set_doc(docs, "index", "(s a|q a)", "i", "Returns the index of 'a' within 's' or 'q'."); hex_set_doc(docs, "join", "q s", "s", "Joins the strings in 'q' using separator 's'."); hex_set_doc(docs, "split", "s1 s2", "q", "Splits 's1' using separator 's2'."); hex_set_doc(docs, "replace", "s1 s2 s3", "s", "Replaces 's2' with 's3' within 's1'."); hex_set_doc(docs, "map", "q1 q2", "q3", "Applies 'q2' to 'q1' items and returns results."); // I/O hex_set_doc(docs, "puts", "a", "", "Prints 'a' and a new line to standard output."); hex_set_doc(docs, "warn", "a", "", "Prints 'a' and a new line to standard error."); hex_set_doc(docs, "print", "a", "", "Prints 'a' to standard output."); hex_set_doc(docs, "gets", "", "s", "Gets a string from standard input."); // File hex_set_doc(docs, "read", "s1", "(s2|q)", "Returns the contents of the specified file."); hex_set_doc(docs, "write", "(s1|q) s2", "", "Writes 's1' or 'q' to the file 's2'."); hex_set_doc(docs, "append", "(s1|q) s2", "", "Appends 's1' or 'q' to the file 's2'."); // Shell hex_set_doc(docs, "args", "", "q", "Returns the program arguments."); hex_set_doc(docs, "exit", "i", "", "Exits the program with exit code 'i'."); hex_set_doc(docs, "exec", "s", "i", "Executes the command 's'."); hex_set_doc(docs, "run", "s", "q", "Executes 's' and returns code, stdout, stderr."); } |