mirror of
https://github.com/vishapoberon/compiler.git
synced 2026-04-05 23:22:25 +00:00
Revert "now test server can listen on any ipv4 address."
This reverts commit afe5a2d824.
This commit is contained in:
parent
afe5a2d824
commit
e36e862c8c
3 changed files with 96 additions and 141 deletions
|
|
@ -6,7 +6,7 @@ MODULE OPV; (* J. Templ 16.2.95 / 3.7.96
|
||||||
various promotion rules changed (long) => (LONGINT), xxxL avoided
|
various promotion rules changed (long) => (LONGINT), xxxL avoided
|
||||||
*)
|
*)
|
||||||
|
|
||||||
IMPORT OPT, OPC, OPM, OPS, VT100, Strings, SYSTEM;
|
IMPORT OPT, OPC, OPM, OPS, SYSTEM;
|
||||||
|
|
||||||
CONST
|
CONST
|
||||||
UndefinedType = 0; (* named type not yet defined *)
|
UndefinedType = 0; (* named type not yet defined *)
|
||||||
|
|
@ -28,7 +28,6 @@ MODULE OPV; (* J. Templ 16.2.95 / 3.7.96
|
||||||
GuardPtrFunc = "__GUARDP(";
|
GuardPtrFunc = "__GUARDP(";
|
||||||
GuardRecFunc = "__GUARDR(";
|
GuardRecFunc = "__GUARDR(";
|
||||||
TypeFunc = "__TYPEOF(";
|
TypeFunc = "__TYPEOF(";
|
||||||
SetOfFunc = "__SETOF(";
|
|
||||||
CopyFunc = "__COPY(";
|
CopyFunc = "__COPY(";
|
||||||
MoveFunc = "__MOVE(";
|
MoveFunc = "__MOVE(";
|
||||||
GetFunc = "__GET(";
|
GetFunc = "__GET(";
|
||||||
|
|
@ -45,7 +44,7 @@ MODULE OPV; (* J. Templ 16.2.95 / 3.7.96
|
||||||
|
|
||||||
TYPE
|
TYPE
|
||||||
ExitInfo = RECORD level, label: INTEGER END ;
|
ExitInfo = RECORD level, label: INTEGER END ;
|
||||||
tmpName = POINTER TO ARRAY 32 OF CHAR;
|
|
||||||
|
|
||||||
VAR
|
VAR
|
||||||
stamp: INTEGER; (* unique number for nested objects *)
|
stamp: INTEGER; (* unique number for nested objects *)
|
||||||
|
|
@ -53,20 +52,6 @@ MODULE OPV; (* J. Templ 16.2.95 / 3.7.96
|
||||||
exit: ExitInfo; (* to check if EXIT is simply a break *)
|
exit: ExitInfo; (* to check if EXIT is simply a break *)
|
||||||
nofExitLabels: INTEGER;
|
nofExitLabels: INTEGER;
|
||||||
|
|
||||||
tempCounter: INTEGER; (* to generate unique temp names *)
|
|
||||||
|
|
||||||
PROCEDURE uniqueTempName(): tmpName;
|
|
||||||
VAR
|
|
||||||
num: ARRAY 8 OF CHAR;
|
|
||||||
tempName: tmpName;
|
|
||||||
BEGIN
|
|
||||||
INC(tempCounter);
|
|
||||||
NEW(tempName);
|
|
||||||
COPY("_voc_tmp_", tempName^);
|
|
||||||
VT100.IntToStr(tempCounter, num);
|
|
||||||
Strings.Append(num, tempName^);
|
|
||||||
RETURN tempName;
|
|
||||||
END uniqueTempName;
|
|
||||||
|
|
||||||
PROCEDURE Init*;
|
PROCEDURE Init*;
|
||||||
BEGIN
|
BEGIN
|
||||||
|
|
@ -211,7 +196,7 @@ MODULE OPV; (* J. Templ 16.2.95 / 3.7.96
|
||||||
OPT.bit,
|
OPT.bit,
|
||||||
OPT.lsh,
|
OPT.lsh,
|
||||||
OPT.rot: RETURN 10
|
OPT.rot: RETURN 10
|
||||||
ELSE OPM.LogWStr("unhandled case in OPV.Precedence OPT.Ndop, subclass = "); OPM.LogWNum(subclass, 0); OPM.LogWLn;
|
ELSE OPM.LogWStr("unhandled case in OPV.Precedence OPT.Ndop, subclass = "); OPM.LogWNum(subclass, 0); OPM.LogWLn;
|
||||||
END;
|
END;
|
||||||
| OPT.Nupto: RETURN 10
|
| OPT.Nupto: RETURN 10
|
||||||
| OPT.Ntype,
|
| OPT.Ntype,
|
||||||
|
|
@ -229,13 +214,13 @@ MODULE OPV; (* J. Templ 16.2.95 / 3.7.96
|
||||||
BEGIN
|
BEGIN
|
||||||
WHILE (n^.class = OPT.Nindex) & (n^.typ^.comp = OPT.DynArr(*26.7.2002*)) DO INC(dim); n := n^.left END ;
|
WHILE (n^.class = OPT.Nindex) & (n^.typ^.comp = OPT.DynArr(*26.7.2002*)) DO INC(dim); n := n^.left END ;
|
||||||
IF (n^.class = OPT.Nderef) & (n^.typ^.comp = OPT.DynArr) THEN
|
IF (n^.class = OPT.Nderef) & (n^.typ^.comp = OPT.DynArr) THEN
|
||||||
d := dim; array := n^.typ;
|
d := dim; array := n^.typ;
|
||||||
WHILE d > 0 DO array := array^.BaseTyp; DEC(d) END;
|
WHILE d > 0 DO array := array^.BaseTyp; DEC(d) END;
|
||||||
IF array^.comp = OPT.DynArr THEN
|
IF array^.comp = OPT.DynArr THEN
|
||||||
design(n^.left, 10); OPM.WriteString("->len["); OPM.WriteInt(dim); OPM.Write("]")
|
design(n^.left, 10); OPM.WriteString("->len["); OPM.WriteInt(dim); OPM.Write("]")
|
||||||
ELSE
|
ELSE
|
||||||
OPM.WriteInt(array^.n)
|
OPM.WriteInt(array^.n)
|
||||||
END
|
END
|
||||||
ELSE
|
ELSE
|
||||||
OPC.Len(n^.obj, n^.typ, dim)
|
OPC.Len(n^.obj, n^.typ, dim)
|
||||||
END
|
END
|
||||||
|
|
@ -270,39 +255,27 @@ MODULE OPV; (* J. Templ 16.2.95 / 3.7.96
|
||||||
END
|
END
|
||||||
END SizeCast;
|
END SizeCast;
|
||||||
|
|
||||||
PROCEDURE Convert(n: OPT.Node; newtype: OPT.Struct; prec: INTEGER);
|
PROCEDURE Convert(n: OPT.Node; newtype: OPT.Struct; prec: INTEGER);
|
||||||
VAR
|
VAR from, to: INTEGER;
|
||||||
from, to: INTEGER;
|
BEGIN from := n^.typ^.form; to := newtype.form;
|
||||||
tempName: tmpName;
|
IF to = OPT.Set THEN
|
||||||
tempIndex: INTEGER; (* New variable to manage temporary indexes *)
|
IF from = OPT.Set THEN (* Sets of different size *)
|
||||||
BEGIN
|
SizeCast(n, newtype.size);
|
||||||
from := n^.typ^.form;
|
ELSE (* Set from integer *)
|
||||||
to := newtype.form;
|
OPM.WriteString("__SETOF("); Entier(n, MinPrec);
|
||||||
|
OPM.WriteString(","); OPM.WriteInt(newtype.size*8); OPM.Write(CloseParen)
|
||||||
IF to = OPT.Set THEN
|
END
|
||||||
tempName := uniqueTempName();
|
ELSIF to = OPT.Int THEN (* integers of different size *)
|
||||||
tempIndex := 0; (* Initialize temp index *)
|
|
||||||
OPM.WriteString("UINT32 "); OPM.WriteString(tempName^); OPM.WriteString(" = 0;"); (* Correctly initialize variable *)
|
|
||||||
OPM.WriteLn;
|
|
||||||
|
|
||||||
IF from = OPT.Set THEN
|
|
||||||
SizeCast(n, newtype.size);
|
SizeCast(n, newtype.size);
|
||||||
ELSE
|
ELSIF to = OPT.Char THEN
|
||||||
OPM.WriteString(tempName^); OPM.WriteString(" = __SETOF(");
|
IF OPM.ranchk IN OPM.Options THEN OPM.WriteString("__CHR");
|
||||||
Entier(n, MinPrec);
|
IF SideEffects(n) THEN OPM.Write("F") END ;
|
||||||
OPM.WriteString(",");
|
OPM.Write(OpenParen); Entier(n, MinPrec); OPM.Write(CloseParen)
|
||||||
OPM.WriteInt(newtype.size * 8);
|
ELSE OPM.WriteString("(CHAR)"); Entier(n, 9)
|
||||||
OPM.WriteString(");");
|
END
|
||||||
OPM.WriteLn;
|
ELSE expr(n, prec)
|
||||||
OPM.WriteString("i |= "); OPM.WriteString(tempName^); OPM.WriteString(";"); (* Ensure 'i' is declared *)
|
|
||||||
END
|
END
|
||||||
ELSIF to = OPT.Int THEN
|
END Convert;
|
||||||
SizeCast(n, newtype.size);
|
|
||||||
ELSE
|
|
||||||
expr(n, prec);
|
|
||||||
END
|
|
||||||
END Convert;
|
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE TypeOf(n: OPT.Node);
|
PROCEDURE TypeOf(n: OPT.Node);
|
||||||
BEGIN
|
BEGIN
|
||||||
|
|
@ -603,7 +576,7 @@ END Convert;
|
||||||
IF SideEffects(n) THEN OPM.WriteString("__MODF(")
|
IF SideEffects(n) THEN OPM.WriteString("__MODF(")
|
||||||
ELSE OPM.WriteString("__MOD(")
|
ELSE OPM.WriteString("__MOD(")
|
||||||
END;
|
END;
|
||||||
ELSE OPM.LogWStr("unhandled case in OPV.expr, subclass = "); OPM.LogWNum(subclass, 0); OPM.LogWLn;
|
ELSE OPM.LogWStr("unhandled case in OPV.expr, subclass = "); OPM.LogWNum(subclass, 0); OPM.LogWLn;
|
||||||
END ;
|
END ;
|
||||||
expr(l, MinPrec);
|
expr(l, MinPrec);
|
||||||
OPM.WriteString(Comma);
|
OPM.WriteString(Comma);
|
||||||
|
|
@ -649,10 +622,10 @@ END Convert;
|
||||||
ELSE OPM.WriteString(" - ")
|
ELSE OPM.WriteString(" - ")
|
||||||
END;
|
END;
|
||||||
| OPS.or: OPM.WriteString(" || ");
|
| OPS.or: OPM.WriteString(" || ");
|
||||||
ELSE OPM.LogWStr("unhandled case in OPV.expr, subclass = "); OPM.LogWNum(subclass, 0); OPM.LogWLn;
|
ELSE OPM.LogWStr("unhandled case in OPV.expr, subclass = "); OPM.LogWNum(subclass, 0); OPM.LogWLn;
|
||||||
END;
|
END;
|
||||||
expr(r, exprPrec);
|
expr(r, exprPrec);
|
||||||
IF (subclass = OPS.and) OR ((form = OPT.Set) & ((subclass = OPS.times) OR (subclass = OPS.minus))) THEN OPM.Write(CloseParen) END; (* to silence clang warnings, -- noch*)
|
IF (subclass = OPS.and) OR ((form = OPT.Set) & ((subclass = OPS.times) OR (subclass = OPS.minus))) THEN OPM.Write(CloseParen) END; (* to silence clang warnings, -- noch*)
|
||||||
END
|
END
|
||||||
| OPT.Ncall: IF (l^.obj # NIL) & (l^.obj^.mode = OPT.TProc) THEN
|
| OPT.Ncall: IF (l^.obj # NIL) & (l^.obj^.mode = OPT.TProc) THEN
|
||||||
IF l^.subcl = OPT.super THEN proc := SuperProc(n)
|
IF l^.subcl = OPT.super THEN proc := SuperProc(n)
|
||||||
|
|
@ -796,7 +769,6 @@ END Convert;
|
||||||
|
|
||||||
PROCEDURE stat(n: OPT.Node; outerProc: OPT.Object);
|
PROCEDURE stat(n: OPT.Node; outerProc: OPT.Object);
|
||||||
VAR proc: OPT.Object; saved: ExitInfo; l, r: OPT.Node;
|
VAR proc: OPT.Object; saved: ExitInfo; l, r: OPT.Node;
|
||||||
tempName, tempVar: tmpName;
|
|
||||||
BEGIN
|
BEGIN
|
||||||
WHILE (n # NIL) & OPM.noerr DO
|
WHILE (n # NIL) & OPM.noerr DO
|
||||||
OPM.errpos := OPM.Longint(n^.conval^.intval);
|
OPM.errpos := OPM.Longint(n^.conval^.intval);
|
||||||
|
|
@ -861,17 +833,9 @@ END Convert;
|
||||||
| OPT.incfn,
|
| OPT.incfn,
|
||||||
OPT.decfn: expr(n^.left, MinPrec); OPC.Increment(n^.subcl = OPT.decfn); expr(n^.right, MinPrec)
|
OPT.decfn: expr(n^.left, MinPrec); OPC.Increment(n^.subcl = OPT.decfn); expr(n^.right, MinPrec)
|
||||||
| OPT.inclfn,
|
| OPT.inclfn,
|
||||||
OPT.exclfn:
|
OPT.exclfn: expr(n^.left, MinPrec); OPC.SetInclude(n^.subcl = OPT.exclfn);
|
||||||
tempName := uniqueTempName();
|
OPM.WriteString("__SETOF("); expr(n^.right, MinPrec);
|
||||||
OPM.WriteString("UINT32 "); OPM.WriteString(tempName^); OPM.WriteString(";");
|
OPM.WriteString(","); OPM.WriteInt(n.left.typ.size*8); OPM.Write(CloseParen)
|
||||||
OPM.WriteLn;
|
|
||||||
|
|
||||||
OPM.WriteString(tempName^); OPM.WriteString(" = __SETOF(");
|
|
||||||
expr(n^.right, MinPrec);
|
|
||||||
OPM.WriteString(","); OPM.WriteInt(n.left.typ.size * 8);
|
|
||||||
OPM.WriteString(");");
|
|
||||||
OPM.WriteLn;
|
|
||||||
OPM.WriteString("i |= "); OPM.WriteString(tempName^); OPM.WriteString(";");
|
|
||||||
| OPT.copyfn: OPM.WriteString(CopyFunc);
|
| OPT.copyfn: OPM.WriteString(CopyFunc);
|
||||||
expr(n^.right, MinPrec); OPM.WriteString(Comma); expr(n^.left, MinPrec); OPM.WriteString(Comma);
|
expr(n^.right, MinPrec); OPM.WriteString(Comma); expr(n^.left, MinPrec); OPM.WriteString(Comma);
|
||||||
Len(n^.left, 0); OPM.Write(CloseParen)
|
Len(n^.left, 0); OPM.Write(CloseParen)
|
||||||
|
|
@ -893,7 +857,7 @@ END Convert;
|
||||||
design(n^.left, MinPrec); OPM.WriteString(", ");
|
design(n^.left, MinPrec); OPM.WriteString(", ");
|
||||||
expr(n^.right, MinPrec);
|
expr(n^.right, MinPrec);
|
||||||
OPM.Write(")")
|
OPM.Write(")")
|
||||||
ELSE OPM.LogWStr("unhandled case in OPV.expr, n^.subcl = "); OPM.LogWNum(n^.subcl, 0); OPM.LogWLn;
|
ELSE OPM.LogWStr("unhandled case in OPV.expr, n^.subcl = "); OPM.LogWNum(n^.subcl, 0); OPM.LogWLn;
|
||||||
END
|
END
|
||||||
| OPT.Ncall: IF (n^.left^.obj # NIL) & (n^.left^.obj^.mode = OPT.TProc) THEN
|
| OPT.Ncall: IF (n^.left^.obj # NIL) & (n^.left^.obj^.mode = OPT.TProc) THEN
|
||||||
IF n^.left^.subcl = OPT.super THEN proc := SuperProc(n)
|
IF n^.left^.subcl = OPT.super THEN proc := SuperProc(n)
|
||||||
|
|
@ -967,7 +931,4 @@ END Convert;
|
||||||
OPC.GenBdy(prog^.right); stat(prog, NIL)
|
OPC.GenBdy(prog^.right); stat(prog, NIL)
|
||||||
END Module;
|
END Module;
|
||||||
|
|
||||||
BEGIN
|
|
||||||
tempCounter := 0
|
|
||||||
|
|
||||||
END OPV.
|
END OPV.
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ IMPORT sockets, types, Out := Console, SYSTEM, Platform, Strings;
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE DoSmth(sock: Platform.FileHandle);
|
PROCEDURE DoSmth(sock: Platform.FileHandle);
|
||||||
VAR
|
VAR
|
||||||
str, aff: ARRAY 256 OF CHAR;
|
str, aff: ARRAY 256 OF CHAR;
|
||||||
n: LONGINT;
|
n: LONGINT;
|
||||||
BEGIN
|
BEGIN
|
||||||
|
|
@ -15,7 +15,7 @@ BEGIN
|
||||||
ELSE
|
ELSE
|
||||||
str[n] := 0X; (* Make sure that received message is zero terminated *)
|
str[n] := 0X; (* Make sure that received message is zero terminated *)
|
||||||
Out.String("received message is "); Out.String(str); Out.Ln;
|
Out.String("received message is "); Out.String(str); Out.Ln;
|
||||||
|
|
||||||
IF Platform.Write(sock, SYSTEM.ADR(aff), Strings.Length(aff)) # 0 THEN
|
IF Platform.Write(sock, SYSTEM.ADR(aff), Strings.Length(aff)) # 0 THEN
|
||||||
Out.String("error writing to socket"); Out.Ln
|
Out.String("error writing to socket"); Out.Ln
|
||||||
END;
|
END;
|
||||||
|
|
@ -29,17 +29,16 @@ PROCEDURE -fork(): LONGINT "(LONGINT)fork()";
|
||||||
|
|
||||||
|
|
||||||
PROCEDURE serve;
|
PROCEDURE serve;
|
||||||
CONST
|
CONST
|
||||||
Port = 2055;
|
Port = 2055;
|
||||||
MaxQueue = 5;
|
MaxQueue = 5;
|
||||||
VAR
|
VAR
|
||||||
sockfd: LONGINT;
|
sockfd: LONGINT;
|
||||||
newsockfd: LONGINT;
|
newsockfd: LONGINT;
|
||||||
ServAddr: sockets.SockAddrIn;
|
ServAddr: sockets.SockAddrIn;
|
||||||
pid: LONGINT;
|
pid: LONGINT;
|
||||||
res: Platform.ErrorCode;
|
res: Platform.ErrorCode;
|
||||||
sockaddrlen: LONGINT;
|
sockaddrlen: LONGINT;
|
||||||
ipAddr: LONGINT; ip: ARRAY 16 OF CHAR;
|
|
||||||
BEGIN
|
BEGIN
|
||||||
sockfd := sockets.Socket(sockets.AfInet, sockets.SockStream, 0);
|
sockfd := sockets.Socket(sockets.AfInet, sockets.SockStream, 0);
|
||||||
IF sockfd < 0 THEN
|
IF sockfd < 0 THEN
|
||||||
|
|
@ -48,17 +47,15 @@ BEGIN
|
||||||
Out.String("socket created.")
|
Out.String("socket created.")
|
||||||
END;
|
END;
|
||||||
Out.Ln;
|
Out.Ln;
|
||||||
COPY("127.0.0.1", ip);
|
|
||||||
ipAddr := sockets.inetaddr(ip);
|
|
||||||
|
|
||||||
sockets.SetSockAddrIn(sockets.AfInet, Port, ipAddr, ServAddr);
|
sockets.SetSockAddrIn(sockets.AfInet, Port, 0, ServAddr);
|
||||||
IF sockets.Bind(sockfd, SYSTEM.VAL(sockets.SockAddr, ServAddr), SIZE(sockets.SockAddr)) < 0 THEN
|
IF sockets.Bind(sockfd, SYSTEM.VAL(sockets.SockAddr, ServAddr), SIZE(sockets.SockAddr)) < 0 THEN
|
||||||
Out.String("error on binding")
|
Out.String("error on binding")
|
||||||
ELSE
|
ELSE
|
||||||
Out.String("binding completed.")
|
Out.String("binding completed.")
|
||||||
END;
|
END;
|
||||||
Out.Ln;
|
Out.Ln;
|
||||||
|
|
||||||
IF sockets.Listen(sockfd, MaxQueue) # 0 THEN
|
IF sockets.Listen(sockfd, MaxQueue) # 0 THEN
|
||||||
Out.String("listen() failed");
|
Out.String("listen() failed");
|
||||||
ELSE
|
ELSE
|
||||||
|
|
|
||||||
|
|
@ -2,60 +2,60 @@ MODULE sockets;
|
||||||
|
|
||||||
IMPORT SYSTEM, oocC;
|
IMPORT SYSTEM, oocC;
|
||||||
|
|
||||||
CONST
|
CONST
|
||||||
SockStream* = 1;
|
SockStream* = 1;
|
||||||
SockDgram* = 2;
|
SockDgram* = 2;
|
||||||
SockRaw* = 3;
|
SockRaw* = 3;
|
||||||
SockRdm* = 4;
|
SockRdm* = 4;
|
||||||
SockSeqpacket* = 5;
|
SockSeqpacket* = 5;
|
||||||
SockDccp* = 6;
|
SockDccp* = 6;
|
||||||
SockPacket* = 10;
|
SockPacket* = 10;
|
||||||
|
|
||||||
AfUnscec* = 0; (* Unspecified. *)
|
AfUnscec* = 0; (* Unspecified. *)
|
||||||
AfLocal* = 1; (* Local to host (pipes and file-domain). *)
|
AfLocal* = 1; (* Local to host (pipes and file-domain). *)
|
||||||
AfUnix* = 1; (* POSIX name for PF_LOCAL. *)
|
AfUnix* = 1; (* POSIX name for PF_LOCAL. *)
|
||||||
AfFile* = 1; (* Another non-standard name for PF_LOCAL. *)
|
AfFile* = 1; (* Another non-standard name for PF_LOCAL. *)
|
||||||
AfInet* = 2; (* IP protocol family. *)
|
AfInet* = 2; (* IP protocol family. *)
|
||||||
AfAx25* = 3; (* Amateur Radio AX.25. *)
|
AfAx25* = 3; (* Amateur Radio AX.25. *)
|
||||||
AfIpx* = 4; (* Novell Internet Protocol. *)
|
AfIpx* = 4; (* Novell Internet Protocol. *)
|
||||||
AfAppletalk* = 5; (* Appletalk DDP. *)
|
AfAppletalk* = 5; (* Appletalk DDP. *)
|
||||||
AfNetrom* = 6; (* Amateur radio NetROM. *)
|
AfNetrom* = 6; (* Amateur radio NetROM. *)
|
||||||
AfBridge* = 7; (* Multiprotocol bridge. *)
|
AfBridge* = 7; (* Multiprotocol bridge. *)
|
||||||
AfAtmpvc* = 8; (* ATM PVCs. *)
|
AfAtmpvc* = 8; (* ATM PVCs. *)
|
||||||
AfX25* = 9; (* Reserved for X.25 project. *)
|
AfX25* = 9; (* Reserved for X.25 project. *)
|
||||||
AfInet6* = 10; (* IP version 6. *)
|
AfInet6* = 10; (* IP version 6. *)
|
||||||
AfRose* = 11; (* Amateur Radio X.25 PLP. *)
|
AfRose* = 11; (* Amateur Radio X.25 PLP. *)
|
||||||
AfDecnet* = 12; (* Reserved for DECnet project. *)
|
AfDecnet* = 12; (* Reserved for DECnet project. *)
|
||||||
AfNetbeui* = 13; (* Reserved for 802.2LLC project. *)
|
AfNetbeui* = 13; (* Reserved for 802.2LLC project. *)
|
||||||
AfSecurity* = 14; (* Security callback pseudo AF. *)
|
AfSecurity* = 14; (* Security callback pseudo AF. *)
|
||||||
AfKey* = 15; (* PF_KEY key management API. *)
|
AfKey* = 15; (* PF_KEY key management API. *)
|
||||||
AfNetlink* = 16;
|
AfNetlink* = 16;
|
||||||
AfRoute* = 16; (* Alias to emulate 4.4BSD. *)
|
AfRoute* = 16; (* Alias to emulate 4.4BSD. *)
|
||||||
AfPacket = 17; (* Packet family. *)
|
AfPacket = 17; (* Packet family. *)
|
||||||
AfAsh = 18; (* Ash. *)
|
AfAsh = 18; (* Ash. *)
|
||||||
AfEconet* = 19; (* Acorn Econet. *)
|
AfEconet* = 19; (* Acorn Econet. *)
|
||||||
AfAtmsvc* = 20; (* ATM SVCs. *)
|
AfAtmsvc* = 20; (* ATM SVCs. *)
|
||||||
AfRds* = 21; (* RDS sockets. *)
|
AfRds* = 21; (* RDS sockets. *)
|
||||||
AfSna = 22; (* Linux SNA Project *)
|
AfSna = 22; (* Linux SNA Project *)
|
||||||
AfIrda* = 23; (* IRDA sockets. *)
|
AfIrda* = 23; (* IRDA sockets. *)
|
||||||
AfPppox = 24; (* PPPoX sockets. *)
|
AfPppox = 24; (* PPPoX sockets. *)
|
||||||
AfWanpipe* = 25; (* Wanpipe API sockets. *)
|
AfWanpipe* = 25; (* Wanpipe API sockets. *)
|
||||||
AfLlc* = 26; (* Linux LLC. *)
|
AfLlc* = 26; (* Linux LLC. *)
|
||||||
AfCan* = 29; (* Controller Area Network. *)
|
AfCan* = 29; (* Controller Area Network. *)
|
||||||
AfTipc* = 30; (* TIPC sockets. *)
|
AfTipc* = 30; (* TIPC sockets. *)
|
||||||
AfBluetooth* = 31; (* Bluetooth sockets. *)
|
AfBluetooth* = 31; (* Bluetooth sockets. *)
|
||||||
AfIucv* = 32; (* IUCV sockets. *)
|
AfIucv* = 32; (* IUCV sockets. *)
|
||||||
AfRxrpc* = 33; (* RxRPC sockets. *)
|
AfRxrpc* = 33; (* RxRPC sockets. *)
|
||||||
AfIsdn* = 34; (* mISDN sockets. *)
|
AfIsdn* = 34; (* mISDN sockets. *)
|
||||||
AfPhonet* = 35; (* Phonet sockets. *)
|
AfPhonet* = 35; (* Phonet sockets. *)
|
||||||
AfIeee802154* = 36; (* IEEE 802.15.4 sockets. *)
|
AfIeee802154* = 36; (* IEEE 802.15.4 sockets. *)
|
||||||
AfCaif* = 37; (* CAIF sockets. *)
|
AfCaif* = 37; (* CAIF sockets. *)
|
||||||
AfAlg* = 38; (* Algorithm sockets. *)
|
AfAlg* = 38; (* Algorithm sockets. *)
|
||||||
AfNfc* = 39; (* NFC sockets. *)
|
AfNfc* = 39; (* NFC sockets. *)
|
||||||
AfVsock* = 40; (* vSockets. *)
|
AfVsock* = 40; (* vSockets. *)
|
||||||
AfMax* = 41; (* For now.. *)
|
AfMax* = 41; (* For now.. *)
|
||||||
|
|
||||||
InAddrAny* = 0;
|
InAddrAny* = 0;
|
||||||
|
|
||||||
TYPE
|
TYPE
|
||||||
(* /usr/include/netinet/in.h *)
|
(* /usr/include/netinet/in.h *)
|
||||||
|
|
@ -70,16 +70,13 @@ TYPE
|
||||||
SinZero*: ARRAY 8 OF CHAR;
|
SinZero*: ARRAY 8 OF CHAR;
|
||||||
END;
|
END;
|
||||||
(* /usr/include/sys/socket.h *)
|
(* /usr/include/sys/socket.h *)
|
||||||
|
|
||||||
SockAddr* = RECORD
|
SockAddr* = RECORD
|
||||||
SaFamily*: oocC.shortint;
|
SaFamily*: oocC.shortint;
|
||||||
SaData*: ARRAY 14 OF CHAR
|
SaData*: ARRAY 14 OF CHAR
|
||||||
END;
|
END;
|
||||||
|
|
||||||
PROCEDURE -includesocket "#include <sys/socket.h>";
|
PROCEDURE -includesocket "#include <sys/socket.h>";
|
||||||
PROCEDURE -includeInet "#include <arpa/inet.h>";
|
|
||||||
|
|
||||||
PROCEDURE -inetaddr*(s: ARRAY OF CHAR): LONGINT "(LONGINT)inet_addr((char*)s)";
|
|
||||||
|
|
||||||
PROCEDURE -SetCShort(i: INTEGER; VAR si: oocC.shortint)
|
PROCEDURE -SetCShort(i: INTEGER; VAR si: oocC.shortint)
|
||||||
"*(short*)si = i";
|
"*(short*)si = i";
|
||||||
|
|
@ -87,7 +84,7 @@ TYPE
|
||||||
PROCEDURE -SetCShortSwapped(i: INTEGER; VAR si: oocC.shortint)
|
PROCEDURE -SetCShortSwapped(i: INTEGER; VAR si: oocC.shortint)
|
||||||
"*(short*)si = ((i >> 8) & 0x00ff) | ((i << 8) & 0xff00)";
|
"*(short*)si = ((i >> 8) & 0x00ff) | ((i << 8) & 0xff00)";
|
||||||
|
|
||||||
PROCEDURE SetSockAddrIn*(family, port: INTEGER; inaddr: LONGINT; VAR sai: SockAddrIn);
|
PROCEDURE SetSockAddrIn*(family, port, inaddr: INTEGER; VAR sai: SockAddrIn);
|
||||||
VAR i: INTEGER;
|
VAR i: INTEGER;
|
||||||
BEGIN
|
BEGIN
|
||||||
SetCShort(family, sai.SinFamily);
|
SetCShort(family, sai.SinFamily);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue