X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/e818f0e07214ed24416c7aedf63d2972e42b9ca4..dfa452c24c8748686523f5bd40436815ba516d95:/Console.cpp?ds=inline diff --git a/Console.cpp b/Console.cpp index c377db2..503a3e8 100644 --- a/Console.cpp +++ b/Console.cpp @@ -37,9 +37,6 @@ */ /* }}} */ -#define _GNU_SOURCE - -#include #include "cycript.hpp" #include @@ -95,6 +92,7 @@ static void sigint(int) { static bool bison_; #endif static bool strict_; +static bool pretty_; void Setup(CYDriver &driver, cy::parser &parser) { #if YYDEBUG @@ -105,13 +103,24 @@ void Setup(CYDriver &driver, cy::parser &parser) { driver.strict_ = true; } +void Setup(CYOutput &out, CYDriver &driver) { + out.pretty_ = pretty_; + + CYContext context(driver.pool_); + driver.program_->Replace(context); +} + void Run(int socket, const char *data, size_t size, FILE *fout = NULL, bool expand = false) { CYPool pool; const char *json; if (socket == -1) { mode_ = Running; +#ifdef CY_EXECUTE json = CYExecute(pool, data); +#else + json = NULL; +#endif mode_ = Working; if (json != NULL) size = strlen(json); @@ -256,7 +265,7 @@ static void Console(int socket) { std::cerr << lines[begin.line - 1] << std::endl; } - std::cerr << " | "; + std::cerr << "...."; for (size_t i(0); i != begin.column - 1; ++i) std::cerr << '.'; if (begin.line != end.line || begin.column == end.column) @@ -288,7 +297,8 @@ static void Console(int socket) { else { std::ostringstream str; CYOutput out(str); - driver.program_->Multiple(out); + Setup(out, driver); + out << *driver.program_; code = str.str(); } } @@ -324,14 +334,27 @@ static void *Map(const char *path, size_t *psize) { int main(int argc, char *argv[]) { bool tty(isatty(STDIN_FILENO)); - pid_t pid(_not(pid_t)); bool compile(false); - for (;;) switch (getopt(argc, argv, "cg:p:s")) { +#ifdef CY_ATTACH + pid_t pid(_not(pid_t)); +#endif + + for (;;) switch (getopt(argc, argv, + "cg:n:" +#ifdef CY_ATTACH + "p:" +#endif + "s" + )) { case -1: goto getopt; case '?': - fprintf(stderr, "usage: cycript [-c] [-p ] [