1
0
mirror of https://github.com/sehugg/8bitworkshop.git synced 2025-01-18 09:30:11 +00:00

isProbablyBinary() used for uploading files

This commit is contained in:
Steven Hugg 2018-12-07 17:24:27 -05:00
parent c6f2382f26
commit 4b8d7406b0
5 changed files with 62 additions and 29 deletions

View File

@ -84,6 +84,7 @@ TODO:
- resize memory browser when split resize (any div resize) - resize memory browser when split resize (any div resize)
- preroll the emulator so optimizer does its thing before loading rom - preroll the emulator so optimizer does its thing before loading rom
- wasm dynamic linking of emulators (https://github.com/WebAssembly/tool-conventions/blob/master/DynamicLinking.md) - wasm dynamic linking of emulators (https://github.com/WebAssembly/tool-conventions/blob/master/DynamicLinking.md)
- upload text/binary detection
WEB WORKER FORMAT WEB WORKER FORMAT
@ -165,4 +166,4 @@ PIXEL EDITOR
everything is an editor everything is an editor
back/forward propogation back/forward propogation
encoded <-> raw + spec + palette(s) <-> bitmap <-> tile/sprite preview(s) encoded <-> raw + spec + palette(s) <-> full tilemap <-> selected tile/sprite/metasprite

View File

@ -26,9 +26,6 @@ void flip_sprite_patterns(word dest, const byte* patterns, word len) {
} }
} }
char cursor_x;
char cursor_y;
void clrscr() { void clrscr() {
cvu_vmemset(IMAGE, 0, COLS*ROWS); cvu_vmemset(IMAGE, 0, COLS*ROWS);
} }

View File

@ -11,7 +11,8 @@ import { Platform, Preset, DebugSymbols, DebugEvalCondition } from "./baseplatfo
import { PLATFORMS } from "./emu"; import { PLATFORMS } from "./emu";
import * as Views from "./views"; import * as Views from "./views";
import { createNewPersistentStore } from "./store"; import { createNewPersistentStore } from "./store";
import { getFilenameForPath, getFilenamePrefix, highlightDifferences, invertMap, byteArrayToString, compressLZG, byteArrayToUTF8 } from "./util"; import { getFilenameForPath, getFilenamePrefix, highlightDifferences, invertMap, byteArrayToString, compressLZG,
byteArrayToUTF8, isProbablyBinary } from "./util";
import { StateRecorderImpl } from "./recorder"; import { StateRecorderImpl } from "./recorder";
// external libs (TODO) // external libs (TODO)
@ -283,8 +284,8 @@ function handleFileUpload(files: File[]) {
reader.onload = function(e) { reader.onload = function(e) {
var arrbuf = (<any>e.target).result as ArrayBuffer; var arrbuf = (<any>e.target).result as ArrayBuffer;
var data : FileData = new Uint8Array(arrbuf); var data : FileData = new Uint8Array(arrbuf);
// convert to UTF8, unless it's a binary file (TODO) // convert to UTF8, unless it's a binary file
if (path.endsWith("bin")) { if (isProbablyBinary(data)) { // path.endsWith("bin")) {
gotoMainFile = false; gotoMainFile = false;
} else { } else {
data = byteArrayToUTF8(data); data = byteArrayToUTF8(data);

View File

@ -270,42 +270,35 @@ export function stringToByteArray(s:string) : Uint8Array {
return a; return a;
} }
export function byteArrayToString(outdata : number[] | Uint8Array) : string { export function byteArrayToString(data : number[] | Uint8Array) : string {
var str = ""; var str = "";
if (outdata != null) { if (data != null) {
var charLUT = new Array(); var charLUT = new Array();
for (var i = 0; i < 256; ++i) for (var i = 0; i < 256; ++i)
charLUT[i] = String.fromCharCode(i); charLUT[i] = String.fromCharCode(i);
var outlen = outdata.length; var len = data.length;
for (var i = 0; i < outlen; i++) for (var i = 0; i < len; i++)
str += charLUT[outdata[i]]; str += charLUT[data[i]];
} }
return str; return str;
} }
export function byteArrayToUTF8(outdata : number[] | Uint8Array) : string { export function byteArrayToUTF8(data : number[] | Uint8Array) : string {
var str = ""; var str = "";
var charLUT = new Array(); var charLUT = new Array();
for (var i = 0; i < 128; ++i) for (var i = 0; i < 128; ++i)
charLUT[i] = String.fromCharCode(i); charLUT[i] = String.fromCharCode(i);
var c; var c;
var outlen = outdata.length; var len = data.length;
for (var i = 0; i < outlen;) for (var i = 0; i < len;) {
{ c = data[i++];
c = outdata[i++]; if (c < 128) {
if (c < 128)
{
str += charLUT[c]; str += charLUT[c];
} } else {
else if ((c >= 192) && (c < 224)) {
{ c = ((c & 31) << 6) | (data[i++] & 63);
if ((c > 191) && (c < 224)) } else {
{ c = ((c & 15) << 12) | ((data[i] & 63) << 6) | (data[i+1] & 63);
c = ((c & 31) << 6) | (outdata[i++] & 63);
}
else
{
c = ((c & 15) << 12) | ((outdata[i] & 63) << 6) | (outdata[i+1] & 63);
i += 2; i += 2;
if (c == 0xfeff) continue; // ignore BOM if (c == 0xfeff) continue; // ignore BOM
} }
@ -322,6 +315,38 @@ export function removeBOM(s:string) {
return s; return s;
} }
export function isProbablyBinary(data : number[] | Uint8Array) : boolean {
var score = 0;
// decode as UTF-8
for (var i = 0; i < data.length;) {
let c = data[i++];
if ((c & 0x80) == 0) {
// more likely binary if we see a NUL or obscure control character
if (c < 9 || (c >= 14 && c < 26) || c == 0x7f) {
score++;
break;
}
} else {
// look for invalid unicode sequences
var nextra = 0;
if ((c & 0xe0) == 0xc0) nextra = 1;
else if ((c & 0xf0) == 0xe0) nextra = 2;
else if ((c & 0xf8) == 0xf0) nextra = 3;
else {
score++;
break;
}
while (nextra--) {
if ((data[i++] & 0xc0) != 0x80) {
score++;
break;
}
}
}
}
return score > 0;
}
// need to load liblzg.js first // need to load liblzg.js first
export function compressLZG(em_module, inBuffer:number[], levelArg?:boolean) : Uint8Array { export function compressLZG(em_module, inBuffer:number[], levelArg?:boolean) : Uint8Array {
var level = levelArg || 9; var level = levelArg || 9;

View File

@ -110,3 +110,12 @@ describe('LZG', function() {
assert.equal(40976, rom.length); assert.equal(40976, rom.length);
}); });
}); });
describe('string functions', function() {
it('Should detect binary', function() {
assert.ok(!util.isProbablyBinary([32,32,10,13,9,32,32,10,13]));
assert.ok(util.isProbablyBinary([32,32,0x80]));
assert.ok(!util.isProbablyBinary([32,32,0xc1,0x81,32,32,10,13]));
assert.ok(util.isProbablyBinary(NES_CONIO_ROM_LZG));
});
});