#include "rust_internal.h" #include "rust_srv.h" rust_srv::rust_srv(rust_env *env) : env(env), local_region(this, false) { } rust_srv::~rust_srv() {} void rust_srv::free(void *p) { ::free(p); } void * rust_srv::malloc(size_t bytes) { return ::malloc(bytes); } void * rust_srv::realloc(void *p, size_t bytes) { return ::realloc(p, bytes); } void rust_srv::log(char const *msg) { printf("rust: %s\n", msg); // FIXME: flushing each time is expensive, but at the moment // necessary to get output through before a rust_task::fail // call. This should be changed. fflush(stdout); } void rust_srv::fatal(const char *expression, const char *file, size_t line, const char *format, ...) { char buf[BUF_BYTES]; va_list args; va_start(args, format); vsnprintf(buf, sizeof(buf), format, args); va_end(args); char msg[BUF_BYTES]; snprintf(msg, sizeof(msg), "fatal, '%s' failed, %s:%d %s", expression, file, (int)line, buf); log(msg); abort(); } void rust_srv::warning(char const *expression, char const *file, size_t line, const char *format, ...) { char buf[BUF_BYTES]; va_list args; va_start(args, format); vsnprintf(buf, sizeof(buf), format, args); va_end(args); char msg[BUF_BYTES]; snprintf(msg, sizeof(msg), "warning: '%s', at: %s:%d %s", expression, file, (int)line, buf); log(msg); } rust_srv * rust_srv::clone() { return new rust_srv(env); } // // Local Variables: // mode: C++ // fill-column: 78; // indent-tabs-mode: nil // c-basic-offset: 4 // buffer-file-coding-system: utf-8-unix // compile-command: "make -k -C $RBUILD 2>&1 | sed -e 's/\\/x\\//x:\\//g'"; // End: //