mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-05 10:58:06 +02:00
* Change pchar to dynamic array of ansichar
This commit is contained in:
parent
b5e2003392
commit
b58469a7bd
@ -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;
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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,
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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 }
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user