case Parsing:
longjmp(ctrlc_, 1);
case Running:
+#ifndef __ANDROID__
CYCancel();
+#endif
return;
case Sending:
return;
if (*character == '\x01') *character = '\n';
}
- ~History() {
+ ~History() { try {
for (HIST_ENTRY *history((history_set_pos(0), current_history())); history; history = next_history())
for (char *character(history->line); *character; ++character)
if (*character == '\n') *character = '\x01';
} else {
_assert(write_history(histfile_.c_str()) == 0);
}
- }
+ } catch (const CYException &error) {
+ CYPool pool;
+ std::cout << error.PoolCString(pool) << std::endl;
+ } }
void operator +=(std::string command) {
add_history(command.c_str());
CYConsoleRemapKeys(vi_movement_keymap);
}
+static void CYOutputRun(const std::string &code, bool expand = false) {
+ CYPool pool;
+ Output(Run(pool, client_, code), &std::cout, expand);
+}
+
static void Console(CYOptions &options) {
std::string basedir;
+#ifdef __ANDROID__
+ basedir = "/data/local/tmp";
+#else
if (const char *home = getenv("HOME"))
basedir = home;
else {
passwd = getpwuid(getuid());
basedir = passwd->pw_dir;
}
+#endif
basedir += "/.cycript";
mkdir(basedir.c_str(), 0700);
rl_completer_word_break_characters = break_;
rl_attempted_completion_function = &Complete;
- rl_redisplay_function = CYDisplayUpdate;
- rl_prep_term_function = CYConsolePrepTerm;
+ if (cur_term != NULL) {
+ rl_redisplay_function = CYDisplayUpdate;
+ rl_prep_term_function = CYConsolePrepTerm;
+ }
+
+ CYOutputRun("");
struct sigaction action;
sigemptyset(&action.sa_mask);
std::cout << std::endl;
}
- CYPool pool;
- Output(Run(pool, client_, code), &std::cout, expand);
+ CYOutputRun(code, expand);
}
}
}
} file(address.sun_path);
- _syscall(bind(server, reinterpret_cast<sockaddr *>(&address), SUN_LEN(&address)));
+ _syscall(bind(server, reinterpret_cast<sockaddr *>(&address), sizeof(address)));
_syscall(chmod(address.sun_path, 0777));
_syscall(listen(server, 1));
return 0;
}
-int main(int argc, char * const argv[], char const * const envp[]) {
+_visible int main(int argc, char * const argv[], char const * const envp[]) {
try {
return Main(argc, argv, envp);
} catch (const CYException &error) {