Fixed bundle bugs.

This commit is contained in:
2021-09-25 23:22:05 -07:00
parent c3fcddee72
commit 8022fbadaa
7 changed files with 130 additions and 26 deletions

View File

@ -8,10 +8,20 @@ const FILE_MAIN = 'main.js';
let doneFiles = [];
let full = `
var exports = {};
function __extends(d,b) {
d.prototype = b.prototype;
}
`;
const CRUMMY_EXTENDS = /var __extends =([\S\s]*?)\}\)\(\)\;/gm;
const ES5_DEFINED = /Object\.defineProperty\(exports, \"__esModule\", \{ value\: true \}\)\;/gm
const outputFix = (output, dir) => {
let out = output.replace(/exports\.\_\_esModule\ =\ true\;/gm, '');
let out = output
.replace(CRUMMY_EXTENDS, '')
.replace(/exports\.\_\_esModule\ =\ true\;/gm, '')
;
// Replace requires with exports.
const reg = /var\ (.*?)\ \= require\("(.*?)"\)\;/gm;
@ -23,8 +33,13 @@ const outputFix = (output, dir) => {
out = out.replace(match.value[0], '').replace(exp, 'exports.');
}
// Remove exports.whatever = void 0;
out = out.replace(/exports\.(.*?) \= void 0\;/gm, '');
out = out
.replace(CRUMMY_EXTENDS, '')
.replace(ES5_DEFINED, '')
.replace(/exports\.(.*?) \= void 0\;/gm, '')
.replace(/\ \ \ \ /gm, ' ')
;
return out;
}

View File

@ -139,16 +139,15 @@ void assetXmlLoad(xml_t *xml, char *assetName) {
}
void assetScripterAppend(scripter_t *scripter, char *fileName) {
assetbuffer_t *asset = assetBufferOpen(fileName);
int32_t read;
char buffer[2048];
duk_push_global_object(scripter->context);
while(read = assetBufferRead(asset, buffer, 2048)) {
duk_push_lstring(scripter->context, buffer, (duk_size_t)read);
}
char *data;
duk_peval(scripter->context);
assetBufferClose(asset);
data = assetStringLoad(fileName);
duk_push_global_object(scripter->context);
duk_push_lstring(scripter->context, data, strlen(data));
if(duk_peval(scripter->context) != 0) {
printf("Error running: %s\n", duk_safe_to_string(scripter->context, -1));
}
free(data);
}

View File

@ -28,9 +28,9 @@ bool sandboxSceneInit(sandboxscene_t *game) {
}
void sandboxSceneUpdate(sandboxscene_t *game) {
scripterInvokeMethodSimple(&game->scripter, "update");
// scripterInvokeMethodSimple(&game->scripter, "update");
}
void sandboxSceneDispose(sandboxscene_t *game) {
scripterInvokeMethodSimple(&game->scripter, "dispose");
// scripterInvokeMethodSimple(&game->scripter, "dispose");
}

View File

@ -1,39 +1,74 @@
import { Scene } from "../scene/Scene";
type Time = {
delta:number;
current:number;
last:number;
}
export class Game {
public time:Time;
private scene:Scene|null;
export abstract class Game {
constructor() {
this.time = { delta: 0, current: 0, last: 0 };
this.scene = null;
}
public setScene(scene:Scene) { this.scene = scene; }
private timeUpdate() {
this.time.delta = epochGetDelta();
this.time.current = epochGetCurrent();
this.time.last = epochGetLast();
}
init() {
print("init");
this.timeUpdate();
}
update() {
print("update");
this.timeUpdate();
if(this.scene) this.scene.update();
}
dispose() {
print("Disposed");
if(this.scene) this.scene.dispose();
}
}
// Main Game Instance
let GAME_MAIN:Game|null = null;
/**
* Set the main game instance.
* @param game Game to become the main game instance.
*/
export const gameSetMain = (game:Game) => {
print("setting", game);
GAME_MAIN = game;
}
/**
* Method that is invoked by C when the game needs to intialize.
*/
const init = () => {
if(!GAME_MAIN) return;
GAME_MAIN.init();
print("init");
// if(!GAME_MAIN) return;
// GAME_MAIN.init();
}
/**
* Method that is invoked by C every single frame.
*/
const update = () => {
if(!GAME_MAIN) return;
GAME_MAIN.update();
}
/**
* Method that is invoked by C when the game needs to stop and clean up.
*/
const dispose = () => {
if(!GAME_MAIN) return;
GAME_MAIN.dispose();

View File

@ -1,7 +1,49 @@
import { Game, gameSetMain } from "./game/Game";
import { Scene } from "./scene/Scene";
class TestScene extends Scene {
private quad:Primitive;
private camera:Camera;
private shader:Shader;
private texture:Texture;
init() {
this.quad = primitiveCreate();
quadInit(this.quad, 0,
-1, -1, 0, 0,
1, 1, 1, 1
);
this.shader = shaderCreate();
assetShaderLoad(this.shader,
"shaders/textured.vert",
"shaders/textured.frag"
);
this.camera = cameraCreate();
cameraLookAt(this.camera, 3,3,3, 0,0,0);
cameraPerspective(this.camera, 45, 16/9, 0.01, 1000);
this.texture = textureCreate();
assetTextureLoad(this.texture, "test_texture.png");
}
update() {
shaderUse(this.shader);
shaderUseCamera(this.shader, this.camera);
shaderUsePosition(this.shader, 0,0,0, 0,this.game.time.current,0);
primitiveDraw(this.quad, 0, -1);
}
dispose() {
}
}
class MainGame extends Game {
constructor() {
super();
this.setScene(new TestScene(this));
}
}
gameSetMain(new MainGame());

13
ts/scene/Scene.ts Normal file
View File

@ -0,0 +1,13 @@
import { Game } from "../game/Game";
export abstract class Scene {
public readonly game:Game;
constructor(game:Game) {
this.game = game;
}
abstract init():void;
abstract update():void;
abstract dispose():void;
}

View File

@ -1,6 +1,6 @@
{
"compilerOptions": {
"target": "es3",
"target": "ES5",
"noImplicitAny": true,
"removeComments": true,
"preserveConstEnums": true,