mirror of
https://github.com/HeyPuter/puter.git
synced 2025-01-24 06:50:22 +08:00
Changes to module imports for parity between the browser and node, fixed browser and node examples
This commit is contained in:
parent
a6b7ec5c66
commit
2b28388fa7
@ -1,4 +1,4 @@
|
|||||||
import * as libv86 from '../third-party/libv86.js';
|
import { V86 } from "./V86Wrapper.mjs";
|
||||||
/**
|
/**
|
||||||
* Class representing an Instance of an emulator machine.
|
* Class representing an Instance of an emulator machine.
|
||||||
*/
|
*/
|
||||||
@ -17,7 +17,7 @@ class Instance {
|
|||||||
*/
|
*/
|
||||||
constructor(options) {
|
constructor(options) {
|
||||||
const defaultOptions = {
|
const defaultOptions = {
|
||||||
term: true,
|
term: false,
|
||||||
screen: false,
|
screen: false,
|
||||||
memory: 1024,
|
memory: 1024,
|
||||||
spawnRoot: undefined,
|
spawnRoot: undefined,
|
||||||
@ -29,7 +29,7 @@ class Instance {
|
|||||||
const instanceOptions = { ...defaultOptions, ...options };
|
const instanceOptions = { ...defaultOptions, ...options };
|
||||||
|
|
||||||
if (!instanceOptions.remote.endsWith('/'))
|
if (!instanceOptions.remote.endsWith('/'))
|
||||||
throw new Error("Remote URL must end with a slash");
|
throw new Error("Instance ctor: Remote URL must end with a slash");
|
||||||
if (typeof self !== 'undefined' && self.crypto) {
|
if (typeof self !== 'undefined' && self.crypto) {
|
||||||
this.instanceID = self.crypto.randomUUID();
|
this.instanceID = self.crypto.randomUUID();
|
||||||
} else {
|
} else {
|
||||||
@ -48,8 +48,10 @@ class Instance {
|
|||||||
if (!(instanceOptions.wsUrl === ""))
|
if (!(instanceOptions.wsUrl === ""))
|
||||||
v86Options.network_relay_url = instanceOptions.wsUrl;
|
v86Options.network_relay_url = instanceOptions.wsUrl;
|
||||||
if (!((Math.log(v86Options.memory_size) / Math.log(2)) % 1 === 0))
|
if (!((Math.log(v86Options.memory_size) / Math.log(2)) % 1 === 0))
|
||||||
throw new Error("Amount of memory provided isn't a power of two");
|
throw new Error("Instance ctor: Amount of memory provided isn't a power of two");
|
||||||
if (instanceOptions.screen === true) {
|
if (instanceOptions.screen === true) {
|
||||||
|
if (instanceOptions.spawnRoot === undefined)
|
||||||
|
throw new Error("Instance ctor: spawnRoot is undefined, cannot continue")
|
||||||
instanceOptions.spawnRoot.appendChild((() => {
|
instanceOptions.spawnRoot.appendChild((() => {
|
||||||
const div = document.createElement("div");
|
const div = document.createElement("div");
|
||||||
div.setAttribute("id", instanceOptions.instanceName + '-screen');
|
div.setAttribute("id", instanceOptions.instanceName + '-screen');
|
||||||
@ -66,7 +68,36 @@ class Instance {
|
|||||||
})());
|
})());
|
||||||
v86Options.screen_container = document.getElementById(instanceOptions.instanceName + '-screen');
|
v86Options.screen_container = document.getElementById(instanceOptions.instanceName + '-screen');
|
||||||
}
|
}
|
||||||
this.vm = new libv86.V86(v86Options);
|
this.vm = new V86(v86Options);
|
||||||
|
if (instanceOptions.term === true) {
|
||||||
|
if (instanceOptions.spawnRoot === undefined)
|
||||||
|
throw new Error("Instance ctor: spawnRoot is undefined, cannot continue")
|
||||||
|
var term = new Terminal({
|
||||||
|
allowTransparency: true,
|
||||||
|
});
|
||||||
|
instanceOptions.spawnRoot.appendChild((() => {
|
||||||
|
const div = document.createElement("div");
|
||||||
|
div.setAttribute("id", instanceOptions.instanceName + '-terminal');
|
||||||
|
return div;
|
||||||
|
})());
|
||||||
|
term.open(document.getElementById(instanceOptions.instanceName + '-terminal'));
|
||||||
|
term.write("Now booting emu, please stand by ...");
|
||||||
|
this.vm.add_listener("emulator-started", () => {
|
||||||
|
// emulator.serial0_send("\nsh networking.sh > /dev/null 2>&1 &\n\n");
|
||||||
|
// emulator.serial0_send("clear\n");
|
||||||
|
term.write("Welcome to psl!");
|
||||||
|
this.vm.serial0_send("\n");
|
||||||
|
});
|
||||||
|
this.vm.add_listener("serial0-output-byte", (byte) => {
|
||||||
|
var chr = String.fromCharCode(byte);
|
||||||
|
if (chr <= "~") {
|
||||||
|
term.write(chr);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
term.onData(data => {
|
||||||
|
this.vm.serial0_send(data);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ class InstanceManager {
|
|||||||
*/
|
*/
|
||||||
constructor(options) {
|
constructor(options) {
|
||||||
const defaultOptions = {
|
const defaultOptions = {
|
||||||
term: true,
|
term: false,
|
||||||
screen: false,
|
screen: false,
|
||||||
instanceName: "Host",
|
instanceName: "Host",
|
||||||
memory: 1024,
|
memory: 1024,
|
||||||
@ -32,15 +32,18 @@ class InstanceManager {
|
|||||||
this.instanceNames = [];
|
this.instanceNames = [];
|
||||||
this.curr_inst = 0;
|
this.curr_inst = 0;
|
||||||
this.instanceNames.push(instanceOptions.instanceName);
|
this.instanceNames.push(instanceOptions.instanceName);
|
||||||
this.instances[instanceOptions.instanceName] = this.initInstance(instanceOptions);
|
this.instances[instanceOptions.instanceName] = new Instance(instanceOptions);
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Initialize an instance with given options.
|
* Create an instance with given options and adds it to the pool of instances.
|
||||||
* @param {Object} options - Options for configuring the instance.
|
* @param {Object} options - Options for configuring the instance.
|
||||||
* @returns {Promise<Object>} - Resolves with the initialized instance.
|
* @returns {Promise<Object>} - Resolves with the initialized instance.
|
||||||
*/
|
*/
|
||||||
initInstance(options) {
|
async createInstance(options) {
|
||||||
return new Instance(options);
|
const instance = new Instance(options);
|
||||||
|
this.instanceNames.push(instance.instanceName);
|
||||||
|
this.instances[instance.instanceName] = instance;
|
||||||
|
return instance;
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Continue running a suspended instance.
|
* Continue running a suspended instance.
|
||||||
|
16
incubator/x86emu/www/js/V86Wrapper.mjs
Normal file
16
incubator/x86emu/www/js/V86Wrapper.mjs
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
let V86;
|
||||||
|
|
||||||
|
if (typeof window !== 'undefined') {
|
||||||
|
V86 = window.V86;
|
||||||
|
} else {
|
||||||
|
try {
|
||||||
|
const { createRequire } = await import('module');
|
||||||
|
const require = createRequire(import.meta.url);
|
||||||
|
const NodeV86 = require("../third-party/libv86.js");
|
||||||
|
V86 = NodeV86.V86;
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Failed to load V86 in Node.js environment:', error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export { V86 };
|
@ -14,19 +14,19 @@ import('./js/InstanceManager.mjs').then(module => {
|
|||||||
manager.getInstanceByinstName("Host").then(result => {
|
manager.getInstanceByinstName("Host").then(result => {
|
||||||
const hostvm = result.vm;
|
const hostvm = result.vm;
|
||||||
|
|
||||||
hostvm.add_listener("emulator-started", function() {
|
hostvm.add_listener("emulator-started", () => {
|
||||||
process.stdout.write("Welcome to psl!");
|
process.stdout.write("Welcome to psl!");
|
||||||
|
hostvm.serial0_send("\n");
|
||||||
});
|
});
|
||||||
|
|
||||||
hostvm.add_listener("serial0-output-byte", function(byte) {
|
hostvm.add_listener("serial0-output-byte", (byte) => {
|
||||||
var chr = String.fromCharCode(byte);
|
var chr = String.fromCharCode(byte);
|
||||||
if (chr <= "~") {
|
if (chr <= "~") {
|
||||||
process.stdout.write(chr);
|
process.stdout.write(chr);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
process.stdin.on("data", function(c) {
|
process.stdin.on("data", (c) => {
|
||||||
// ctrl d
|
|
||||||
if (c === "\u0004") {
|
if (c === "\u0004") {
|
||||||
hostvm.stop();
|
hostvm.stop();
|
||||||
process.stdin.pause();
|
process.stdin.pause();
|
||||||
@ -36,7 +36,7 @@ import('./js/InstanceManager.mjs').then(module => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}).catch(error => {
|
}).catch(error => {
|
||||||
console.log(error);
|
console.error(error);
|
||||||
throw Error("Error in getting host inastance, quitting");
|
throw Error("Error in getting host inastance, quitting");
|
||||||
});
|
});
|
||||||
}).catch(error => {
|
}).catch(error => {
|
||||||
|
Loading…
Reference in New Issue
Block a user