|
@@ -62,7 +62,7 @@ begin
|
|
|
end;
|
|
|
|
|
|
|
|
|
-function WriteStream(st: TStream): Boolean;
|
|
|
+function WriteStream(st: TStream; syms: TStrings): Boolean;
|
|
|
var
|
|
|
dw : LongWord;
|
|
|
ofs : int64;
|
|
@@ -92,7 +92,7 @@ begin
|
|
|
writeln(nm);
|
|
|
if nm = SectionName_Linking then begin
|
|
|
writeln('rewriting linking...');
|
|
|
- ProcessLinkingSection(st);
|
|
|
+ ProcessLinkingSection(st, syms);
|
|
|
break;
|
|
|
end;
|
|
|
//DumpLinking(st, sc.size - (st.Position - ofs));
|
|
@@ -107,27 +107,145 @@ begin
|
|
|
end;
|
|
|
end;
|
|
|
|
|
|
-procedure ProcessWasmFile(const fn: string);
|
|
|
+procedure ProcessWasmFile(const fn, symfn: string);
|
|
|
var
|
|
|
fs :TFileStream;
|
|
|
+ syms: TStringList;
|
|
|
begin
|
|
|
writeln('proc: ', fn);
|
|
|
+ syms:=TStringList.Create;
|
|
|
fs := TFileStream.Create(fn, fmOpenReadWrite or fmShareDenyNone);
|
|
|
try
|
|
|
+ if (symfn<>'') then
|
|
|
+ ReadSymbolsConf(symfn, syms);
|
|
|
writeln('size: ', fs.size);
|
|
|
- WriteStream(fs);
|
|
|
+ WriteStream(fs, syms);
|
|
|
finally
|
|
|
fs.Free;
|
|
|
+ syms.Free;
|
|
|
end;
|
|
|
end;
|
|
|
|
|
|
+procedure RenameExport(var x: TExportSection; syms: TStrings);
|
|
|
+var
|
|
|
+ i : integer;
|
|
|
+ v : string;
|
|
|
+begin
|
|
|
+ for i:=0 to length(x.entries)-1 do begin
|
|
|
+ v := syms.Values[x.entries[i].name];
|
|
|
+ if v <> '' then
|
|
|
+ x.entries[i].name := v;
|
|
|
+ end;
|
|
|
+end;
|
|
|
+
|
|
|
+function ProcessSections(st, dst: TStream; syms: TStrings): Boolean;
|
|
|
+var
|
|
|
+ dw : LongWord;
|
|
|
+ ofs : int64;
|
|
|
+ sc : TSection;
|
|
|
+ ps : int64;
|
|
|
+ x : TExportSection;
|
|
|
+ i : integer;
|
|
|
+ mem : TMemoryStream;
|
|
|
+begin
|
|
|
+ dw := st.ReadDWord;
|
|
|
+ Result := dw = WasmId_Int;
|
|
|
+ if not Result then begin
|
|
|
+ Exit;
|
|
|
+ end;
|
|
|
+ dw := st.ReadDWord;
|
|
|
+ while st.Position<st.Size do begin
|
|
|
+ ofs := st.Position;
|
|
|
+ sc.id := st.ReadByte;
|
|
|
+ sc.Size := ReadU(st);
|
|
|
+ writeln(ofs,': id=', sc.id,'(', SectionIdToStr(sc.id),') sz=', sc.size);
|
|
|
+
|
|
|
+ ps := st.Position+sc.size;
|
|
|
+
|
|
|
+ if sc.id = SECT_EXPORT then begin
|
|
|
+ ReadExport(st, x);
|
|
|
+ RenameExport(x, syms);
|
|
|
+
|
|
|
+ st.Position:=0;
|
|
|
+ dst.CopyFrom(st, ofs);
|
|
|
+ st.Position:=ps;
|
|
|
+
|
|
|
+ mem := TMemoryStream.Create;
|
|
|
+ WriteExport(x, mem);
|
|
|
+ mem.Position:=0;
|
|
|
+
|
|
|
+ dst.WriteByte(SECT_EXPORT);
|
|
|
+ WriteU32(dst, mem.Size);
|
|
|
+ dst.CopyFrom(mem, mem.Size);
|
|
|
+
|
|
|
+ writeln('entries = ', length(x.entries));
|
|
|
+ for i:=0 to length(x.entries)-1 do begin
|
|
|
+ writeln(x.entries[i].desc,' ', x.entries[i].name)
|
|
|
+ end;
|
|
|
+
|
|
|
+ dst.CopyFrom(st, st.Size-st.Position);
|
|
|
+ break; // done
|
|
|
+ end;
|
|
|
+ {if sc.id=0 then begin
|
|
|
+ nm := GetName(st);
|
|
|
+ writeln(nm);
|
|
|
+ if nm = SectionName_Linking then begin
|
|
|
+ writeln('rewriting linking...');
|
|
|
+ ProcessLinkingSection(st, syms);
|
|
|
+ break;
|
|
|
+ end;
|
|
|
+ //DumpLinking(st, sc.size - (st.Position - ofs));
|
|
|
+ end;}
|
|
|
+ //if sc.id= 1 then DumpTypes(st);
|
|
|
+
|
|
|
+ if st.Position <> ps then
|
|
|
+ begin
|
|
|
+ //writeln('adjust stream targ=',ps,' actual: ', st.position);
|
|
|
+ st.Position := ps;
|
|
|
+ end;
|
|
|
+ end;
|
|
|
+end;
|
|
|
+
|
|
|
+
|
|
|
+procedure ProcessWasmSection(const fn, {%H-}symfn: string);
|
|
|
+var
|
|
|
+ fs : TFileStream;
|
|
|
+ syms : TStringList;
|
|
|
+ dst : TMemoryStream;
|
|
|
+begin
|
|
|
+ writeln('proc: ', fn);
|
|
|
+ syms:=TStringList.Create;
|
|
|
+ fs := TFileStream.Create(fn, fmOpenReadWrite or fmShareDenyNone);
|
|
|
+ dst := TMemoryStream.Create;
|
|
|
+ try
|
|
|
+ if (symfn <> '') and fileExists(symfn) then
|
|
|
+ syms.LoadFromFile(symfn);
|
|
|
+
|
|
|
+ ProcessSections(fs, dst, syms);
|
|
|
+ fs.Position:=0;
|
|
|
+ dst.Position:=0;
|
|
|
+ fs.CopyFrom(dst, dst.Size);
|
|
|
+ fs.Size:=dst.Size;
|
|
|
+
|
|
|
+ finally
|
|
|
+ dst.Free;
|
|
|
+ fs.Free;
|
|
|
+ syms.Free;
|
|
|
+ end;
|
|
|
+end;
|
|
|
+
|
|
|
+var
|
|
|
+ symfn : string;
|
|
|
begin
|
|
|
if ParamCount=0 then begin
|
|
|
writeln('please specify .wasm file');
|
|
|
exit;
|
|
|
end;
|
|
|
+ symfn:='';
|
|
|
+ if ParamCount>1 then symfn:=ParamStr(2);
|
|
|
|
|
|
//ReadWasmFile(ParamStr(1));
|
|
|
- ProcessWasmFile(ParamStr(1));
|
|
|
+ //ProcessWasmFile(ParamStr(1), symfn);
|
|
|
+ ProcessWasmSection(ParamStr(1), symfn);
|
|
|
end.
|
|
|
|