* Change pchar to dynamic array of ansichar

This commit is contained in:
Michaël Van Canneyt 2025-03-17 15:34:15 +01:00
parent b5e2003392
commit b58469a7bd
8 changed files with 132 additions and 41 deletions

View File

@ -727,25 +727,30 @@ implementation
end; end;
procedure tai_aggregatetypedconst.add_to_string(strtai: tai_string; othertai: tai); procedure tai_aggregatetypedconst.add_to_string(strtai: tai_string; othertai: tai);
var
len1,len2,lent : Integer;
lother_string : tai_string absolute othertai;
begin begin
case othertai.typ of case othertai.typ of
ait_string: ait_string:
begin begin
strtai.str:=reallocmem(strtai.str,strtai.len+tai_string(othertai).len+1); // lengths without terminating 0
len1:=length(strtai.str)-1;
len2:=length(lother_string.str)-1;
lent:=len1+len2;
SetLength(strtai.str,lent+1);
{ also copy null terminator } { also copy null terminator }
move(tai_string(othertai).str[0],strtai.str[strtai.len],tai_string(othertai).len+1); move(lother_string.str[0],strtai.str[len1+1],len2+1);
{ the null terminator is not part of the string data }
strtai.len:=strtai.len+tai_string(othertai).len;
end; end;
ait_const: ait_const:
begin begin
if tai_const(othertai).size<>1 then if tai_const(othertai).size<>1 then
internalerror(2014070101); internalerror(2014070101);
{ it was already len+1 to hold the #0 -> realloc to len+2 } { it was already len+1 to hold the #0 -> realloc to len+2 }
strtai.str:=reallocmem(strtai.str,strtai.len+2); len1:=length(strtai.str);
strtai.str[strtai.len]:=ansichar(tai_const(othertai).value); SetLength(strtai.str,len1+1);
strtai.str[strtai.len+1]:=#0; strtai.str[len1]:=ansichar(tai_const(othertai).value);
inc(strtai.len); strtai.str[len1+1]:=#0;
end; end;
else else
internalerror(2014070102); internalerror(2014070102);
@ -826,6 +831,9 @@ implementation
procedure tai_aggregatetypedconst.finish; procedure tai_aggregatetypedconst.finish;
var
lString : tai_string;
len : integer;
begin begin
if fisstring then if fisstring then
begin begin
@ -833,9 +841,9 @@ implementation
data } data }
if fvalues.count<>1 then if fvalues.count<>1 then
internalerror(2014070105); internalerror(2014070105);
tai_simpletypedconst(fvalues[0]).fdef:= lString:=tai_string(tai_simpletypedconst(fvalues[0]).val);
carraydef.getreusable(cansichartype, len:=length(lString.str)-1;
tai_string(tai_simpletypedconst(fvalues[0]).val).len); tai_simpletypedconst(fvalues[0]).fdef:=carraydef.getreusable(cansichartype,len);
end; end;
end; end;

View File

@ -604,10 +604,11 @@ interface
taiclassarray = array[taitype] of taiclass; taiclassarray = array[taitype] of taiclass;
{ Generates an assembler string } { Generates an assembler string }
{ tai_string }
tai_string = class(tailineinfo) tai_string = class(tailineinfo)
str : pchar; str : TAnsiCharDynArray;
{ extra len so the string can contain an \0 }
len : longint;
constructor Create(const _str : string); constructor Create(const _str : string);
constructor Create(const _str : ansistring); constructor Create(const _str : ansistring);
constructor Create_pchar(_str : pchar;length : longint); constructor Create_pchar(_str : pchar;length : longint);
@ -615,6 +616,7 @@ interface
constructor ppuload(t:taitype;ppufile:tcompilerppufile);override; constructor ppuload(t:taitype;ppufile:tcompilerppufile);override;
procedure ppuwrite(ppufile:tcompilerppufile);override; procedure ppuwrite(ppufile:tcompilerppufile);override;
function getcopy:tlinkedlistitem;override; function getcopy:tlinkedlistitem;override;
function len : integer; inline;
end; end;
{ Generates a common label } { Generates a common label }
@ -2416,26 +2418,30 @@ implementation
****************************************************************************} ****************************************************************************}
constructor tai_string.Create(const _str : string); constructor tai_string.Create(const _str : string);
var
lNewLen : Integer;
begin begin
inherited Create; inherited Create;
typ:=ait_string; typ:=ait_string;
len:=length(_str); lNewLen:=length(_str);
getmem(str,len+1); setlength(str,lNewLen+1);
if len>0 then if lNewLen>0 then
move(_str[1],str^,len); move(_str[1],str[0],lNewLen);
str[len]:=#0; str[lNewLen]:=#0;
end; end;
constructor tai_string.Create(const _str: ansistring); constructor tai_string.Create(const _str: ansistring);
var
lNewLen : Integer;
begin begin
inherited Create; inherited Create;
typ:=ait_string; typ:=ait_string;
len:=length(_str); lNewLen:=length(_str);
getmem(str,len+1); setlength(str,lNewlen+1);
if len>0 then if lNewLen>0 then
move(_str[1],str^,len); move(_str[1],str[0],lNewLen);
str[len]:=#0; str[lNewLen]:=#0;
end; end;
@ -2443,47 +2449,61 @@ implementation
begin begin
inherited Create; inherited Create;
typ:=ait_string; typ:=ait_string;
str:=_str; setlength(str,length+1);
len:=length; move(_str^,str[0],length);
str[length]:=#0;
end; end;
destructor tai_string.destroy; destructor tai_string.Destroy;
begin begin
if str<>nil then
freemem(str);
inherited Destroy; inherited Destroy;
end; end;
constructor tai_string.ppuload(t:taitype;ppufile:tcompilerppufile); constructor tai_string.ppuload(t:taitype;ppufile:tcompilerppufile);
var
lNewLen : integer;
begin begin
inherited ppuload(t,ppufile); inherited ppuload(t,ppufile);
len:=ppufile.getlongint; lNewLen:=ppufile.getlongint;
getmem(str,len+1); setlength(str,lNewLen+1);
ppufile.getdata(str^,len); ppufile.getdata(str);
str[len]:=#0 str[lNewLen]:=#0;
end; end;
procedure tai_string.ppuwrite(ppufile:tcompilerppufile); procedure tai_string.ppuwrite(ppufile:tcompilerppufile);
var
lWriteLen : integer;
begin begin
inherited ppuwrite(ppufile); inherited ppuwrite(ppufile);
ppufile.putlongint(len); lWriteLen:=length(str);
ppufile.putdata(str^,len); ppufile.putlongint(lWriteLen);
ppufile.putdata(str[0],lWriteLen);
end; end;
function tai_string.getcopy : tlinkedlistitem; function tai_string.getcopy : tlinkedlistitem;
var var
p : tlinkedlistitem; p : tlinkedlistitem;
lWriteLen : integer;
begin begin
p:=inherited getcopy; p:=inherited getcopy;
getmem(tai_string(p).str,len); lWriteLen:=length(str);
move(str^,tai_string(p).str^,len); setlength(tai_string(p).str,lWriteLen);
// move #0 at the end too.
move(str[0],tai_string(p).str[0],lWriteLen);
getcopy:=p; getcopy:=p;
end; end;
function tai_string.len: integer;
begin
Result:=Length(str);
if Result>0 then
Result:=Result-1;
end;
{**************************************************************************** {****************************************************************************
TAI_LABEL TAI_LABEL

View File

@ -1303,7 +1303,7 @@ implementation
writer.AsmWrite(#9'.ascii'#9'"'); writer.AsmWrite(#9'.ascii'#9'"');
pos:=20; pos:=20;
end; end;
ch:=tai_string(hp).str[i-1]; ch:=AnsiChar(tai_string(hp).str[i-1]);
case ch of case ch of
#0, {This can't be done by range, because a bug in FPC} #0, {This can't be done by range, because a bug in FPC}
#1..#31, #1..#31,

View File

@ -2384,7 +2384,7 @@ Implementation
end; end;
end; end;
ait_string : ait_string :
ObjData.writebytes(Tai_string(hp).str^,Tai_string(hp).len); ObjData.writebytes(Tai_string(hp).str,Tai_string(hp).len);
ait_const : ait_const :
begin begin
{ Recalculate relative symbols, addresses of forward references { Recalculate relative symbols, addresses of forward references

View File

@ -295,6 +295,8 @@ type
function openstream(strm:TCStream):boolean; function openstream(strm:TCStream):boolean;
procedure reloadbuf; procedure reloadbuf;
procedure readdata(out b;len:integer); procedure readdata(out b;len:integer);
procedure readdata(const b : TByteDynArray);
procedure readdata(const b : TAnsiCharDynArray);
procedure skipdata(len:integer); procedure skipdata(len:integer);
function readentry:byte; function readentry:byte;
function EndOfEntry:boolean; {$ifdef USEINLINE}inline;{$endif} function EndOfEntry:boolean; {$ifdef USEINLINE}inline;{$endif}
@ -302,6 +304,8 @@ type
function entryleft:longint; {$ifdef USEINLINE}inline;{$endif} function entryleft:longint; {$ifdef USEINLINE}inline;{$endif}
procedure getdatabuf(out b;len:integer;out res:integer); procedure getdatabuf(out b;len:integer;out res:integer);
procedure getdata(out b;len:integer); procedure getdata(out b;len:integer);
procedure getdata(b : TByteDynArray);
procedure getdata(b : TAnsiCharDynArray);
function getbyte:byte; function getbyte:byte;
function getword:word; function getword:word;
function getdword:dword; function getdword:dword;
@ -736,6 +740,16 @@ begin
inc(bufidx,len); inc(bufidx,len);
end; end;
procedure tentryfile.readdata(const b: TByteDynArray);
begin
ReadData(B[0],Length(B));
end;
procedure tentryfile.readdata(const b: TAnsiCharDynArray);
begin
ReadData(B[0],Length(B));
end;
procedure tentryfile.skipdata(len:integer); procedure tentryfile.skipdata(len:integer);
var var
@ -800,7 +814,7 @@ begin
end; end;
function tentryfile.endofentry:boolean; function tentryfile.endofentry: boolean;
begin begin
{$ifdef generic_cpu} {$ifdef generic_cpu}
endofentry:=(entryidx=entry.size); endofentry:=(entryidx=entry.size);
@ -843,6 +857,28 @@ begin
inc(entryidx,len); inc(entryidx,len);
end; end;
procedure tentryfile.getdata(b: TByteDynArray);
begin
if entryidx+Length(b)>entry.size then
begin
error:=true;
exit;
end;
readdata(b);
inc(entryidx,length(b));
end;
procedure tentryfile.getdata(b: TAnsiCharDynArray);
begin
if entryidx+Length(b)>entry.size then
begin
error:=true;
exit;
end;
readdata(b);
inc(entryidx,length(b));
end;
function tentryfile.getbyte:byte; function tentryfile.getbyte:byte;
begin begin

View File

@ -41,6 +41,9 @@ interface
{$endif symansistr} {$endif symansistr}
PSymStr = ^TSymStr; PSymStr = ^TSymStr;
TByteDynArray = array of byte;
TAnsiCharDynArray = array of ansichar;
Int32 = Longint; Int32 = Longint;
{ Integer type corresponding to pointer size } { Integer type corresponding to pointer size }

View File

@ -458,6 +458,8 @@ interface
procedure alloc(len:TObjSectionOfs); procedure alloc(len:TObjSectionOfs);
procedure allocalign(len:longint); procedure allocalign(len:longint);
procedure writebytes(const Data;len:TObjSectionOfs); procedure writebytes(const Data;len:TObjSectionOfs);
procedure writebytes(const Data : TByteDynArray;len:TObjSectionOfs);
procedure writebytes(const Data : TAnsiCharDynArray;len:TObjSectionOfs);
procedure writeInt8(v: int8); procedure writeInt8(v: int8);
procedure writeInt16LE(v: int16); procedure writeInt16LE(v: int16);
procedure writeInt16BE(v: int16); procedure writeInt16BE(v: int16);
@ -1601,7 +1603,7 @@ implementation
end; end;
function TObjData.FindSection(const aname:string):TObjSection; function TObjData.Findsection(const aname:string):TObjSection;
begin begin
result:=TObjSection(FObjSectionList.Find(aname)); result:=TObjSection(FObjSectionList.Find(aname));
end; end;
@ -1724,6 +1726,16 @@ implementation
CurrObjSec.write(Data,len); CurrObjSec.write(Data,len);
end; end;
procedure TObjData.writebytes(const Data: TByteDynArray; len: TObjSectionOfs);
begin
WriteBytes(Data[0],len);
end;
procedure TObjData.writebytes(const Data: TAnsiCharDynArray; len: TObjSectionOfs);
begin
WriteBytes(Data[0],len);
end;
procedure TObjData.writeInt8(v: int8); procedure TObjData.writeInt8(v: int8);
begin begin

View File

@ -69,6 +69,8 @@ interface
procedure WriteImports; procedure WriteImports;
procedure WriteOutPChar(p: pchar; ofs, len: integer); procedure WriteOutPChar(p: pchar; ofs, len: integer);
procedure WriteOutPChar(p: TByteDynArray; ofs, len: integer);
procedure WriteOutPChar(p: TAnsicharDynArray; ofs, len: integer);
procedure WriteConstString(lbl: tai_label; str: tai_string); procedure WriteConstString(lbl: tai_label; str: tai_string);
procedure WriteConstants(p: TAsmList); procedure WriteConstants(p: TAsmList);
public public
@ -1025,6 +1027,16 @@ implementation
end; end;
end; end;
procedure TWasaTextAssembler.WriteOutPChar(p: TByteDynArray; ofs, len: integer);
begin
WriteOutPChar(PAnsiChar(p),ofs,len);
end;
procedure TWasaTextAssembler.WriteOutPChar(p: TAnsicharDynArray; ofs, len: integer);
begin
WriteOutPChar(PAnsiChar(p),ofs,len);
end;
procedure TWasaTextAssembler.WriteConstString(lbl: tai_label; procedure TWasaTextAssembler.WriteConstString(lbl: tai_label;
str: tai_string); str: tai_string);
var var