shithub: libmujs

ref: 7228ec51c423cd57413c2c1c9b65b288d0189f5b
dir: /jsload.c/

View raw version
#include "js.h"
#include "jsparse.h"
#include "jscompile.h"
#include "jsobject.h"
#include "jsrun.h"

static int jsP_loadstring(js_State *J, const char *filename, const char *source)
{
	js_Ast *prog = jsP_parse(J, filename, source);
	if (prog) {
		js_Function *fun;
		//jsP_optimize(J, prog);
		//jsP_dumpsyntax(J, prog);
		jsP_dumplist(J, prog);
		fun = jsC_compile(J, prog);
		if (fun) {
			jsC_dumpfunction(J, fun);
			jsR_runfunction(J, fun);
		}
		jsC_freecompile(J);
		jsP_freeparse(J);
		return 0;
	}
	return 1;
}

int js_loadstring(js_State *J, const char *source)
{
	return jsP_loadstring(J, "(string)", source);
}

int js_loadfile(js_State *J, const char *filename)
{
	FILE *f;
	char *s;
	int n, t;

	f = fopen(filename, "r");
	if (!f) {
		return js_error(J, "cannot open file: '%s'", filename);
	}

	if (fseek(f, 0, SEEK_END) < 0) {
		fclose(f);
		return js_error(J, "cannot seek in file: '%s'", filename);
	}
	n = ftell(f);
	fseek(f, 0, SEEK_SET);

	s = malloc(n + 1); /* add space for string terminator */
	if (!s) {
		fclose(f);
		return js_error(J, "cannot allocate storage for file contents: '%s'", filename);
	}

	t = fread(s, 1, n, f);
	if (t != n) {
		free(s);
		fclose(f);
		return js_error(J, "cannot read data from file: '%s'", filename);
	}

	s[n] = 0; /* zero-terminate string containing file data */

	t = jsP_loadstring(J, filename, s);

	free(s);
	fclose(f);
	return t;
}