compiles.

This commit is contained in:
norayr 2017-04-13 16:41:08 +04:00
parent 4acd41201c
commit 4c64d37338
5 changed files with 79 additions and 36 deletions

View file

@ -2,7 +2,7 @@
VOC = /opt/voc/bin/voc VOC = /opt/voc/bin/voc
all: all:
$(VOC) -s types.Mod sockets.Mod s.Mod -m $(VOC) -s types.Mod sockets.Mod netdb.Mod irc.Mod
clean: clean:
rm *.h rm *.h

28
irc.Mod
View file

@ -1,17 +1,25 @@
MODULE irc; MODULE irc;
IMPORT sockets, netdb, Unix, Strings; IMPORT sockets, netdb, Platform, Strings, types, SYSTEM;
CONST strLen = 1024; CONST strLen = 1024;
TYPE
Int16 = types.Int16;
Int32 = types.Int32;
Int64 = types.Int64;
VAR VAR
nick*, channel*, host*, port*, user*, command*, where*, message*, sep*, target*: ARRAY strLen OF CHAR; nick*, channel*, host*, port*, user*, command*, where*, message*, sep*, target*: ARRAY strLen OF CHAR;
PROCEDURE write(fd: Int32; VAR buf: ARRAY OF CHAR; len: LONGINT); PROCEDURE rawWrite(fd: Int32; VAR buf: ARRAY OF CHAR; len: LONGINT);
VAR VAR
l: LONGINT; l: SYSTEM.ADDRESS;
r: INTEGER;
BEGIN BEGIN
Unix.Write(fd, buf, len); l := SYSTEM.ADR(buf);
END raw; r := Platform.Write(fd, l, len);
END rawWrite;
PROCEDURE connect; PROCEDURE connect;
VAR hints : netdb.addrInfo; VAR hints : netdb.addrInfo;
@ -29,15 +37,19 @@ BEGIN
tmp32 := netdb.getAddrInfo(host, port, hints, res); tmp32 := netdb.getAddrInfo(host, port, hints, res);
conn := sockets.Socket(res^.aiFamily, res^.aiSockType, res^.aiProtocol); conn := sockets.Socket(res^.aiFamily, res^.aiSockType, res^.aiProtocol);
tmp32 := sockets.Connect(conn, res^.aiAddr, res^.aiAddrlen); tmp32 := sockets.Connect(conn, res^.aiAddr, res^.aiAddrLen);
(* "USER test 0 0 :test\r\n" *) (* "USER test 0 0 :test\r\n" *)
(* "NICK test\r\n\000\060 :test\r\n"*) (* "NICK test\r\n\000\060 :test\r\n"*)
COPY("USER ", str0); COPY("USER ", str0);
Strings.Append(user, str0) Strings.Append(user, str0);
Strings.Append(" 0 0 :", str0); Strings.Append(" 0 0 :", str0);
Strings.Append(nick, str0); Strings.Append(nick, str0);
str1[0] := 0AX; str1[1] := 0DX; str1[2] := 0X; str1[0] := 0AX; str1[1] := 0DX; str1[2] := 0X;
Strings.Append(str1, str0); Strings.Append(str1, str0);
write(conn, str0, Strings.Length(str0)); rawWrite(conn, str0, Strings.Length(str0));
END connect; END connect;
BEGIN
END irc.

View file

@ -3,11 +3,11 @@ MODULE netdb;
IMPORT SYSTEM; IMPORT SYSTEM;
TYPE TYPE
Int32* = INTEGER; Int32* = LONGINT;
Int64* = LONGINT; Int64* = HUGEINT;
TYPE TYPE
PaddrInfo = POINTER [1] TO addrInfo; PaddrInfo* = POINTER [1] TO addrInfo;
addrInfo* = RECORD addrInfo* = RECORD
aiFlags*: Int32; aiFlags*: Int32;
@ -15,14 +15,14 @@ TYPE
aiSockType*: Int32; aiSockType*: Int32;
aiProtocol*: Int32; aiProtocol*: Int32;
aiAddrLen*: Int32; aiAddrLen*: Int32;
aiAddr*, aiCanonName*, aiNext*: LONGINT; (* pointers *) aiAddr*, aiCanonName*, aiNext*: SYSTEM.ADDRESS; (* pointers *)
END; END;
PROCEDURE getAddrInfo*(VAR node, service: ARRAY OF CHAR; VAR hints: addrInfo; res: LONGINT): Int32 PROCEDURE -getAddrInfo*(VAR node, service: ARRAY OF CHAR; VAR hints: addrInfo; res: PaddrInfo): Int32
"getaddrinfo (node, service, hints, res)"; "getaddrinfo (node, service, hints, res)";
PROCEDURE freeAddrInfo*(VAR res: addrInfo) PROCEDURE -freeAddrInfo*(VAR res: addrInfo)
"freeaddrinfo(res)"; "freeaddrinfo(res)";
END netdb. END netdb.

View file

@ -62,7 +62,7 @@ CONST
InAddrAny* = 0; InAddrAny* = 0;
TYPE TYPE
(*
(* /usr/include/netinet/in.h *) (* /usr/include/netinet/in.h *)
InAddr* = RECORD InAddr* = RECORD
SAddr* : Int32; SAddr* : Int32;
@ -74,13 +74,17 @@ TYPE
SinAddr* : InAddr; SinAddr* : InAddr;
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* : Int16; SaFamily* : Int16;
SaData* : ARRAY 14 OF CHAR SaData* : ARRAY 14 OF CHAR
END; END;
(*
PROCEDURE -includeSockets
"#include <sys/socket.h>";
*)
PROCEDURE -socket(domain, type, protocol: Int32): Int32 PROCEDURE -socket(domain, type, protocol: Int32): Int32
"(int)socket(domain, type, protocol)"; "(int)socket(domain, type, protocol)";
@ -114,8 +118,32 @@ TYPE
END Accept; END Accept;
(* int connect(int sockfd, const struct sockaddr *addr, (* int connect(int sockfd, const struct sockaddr *addr,
socklen_t addrlen); *) socklen_t addrlen); *)
PROCEDURE Connect*(sockfd: Int32; VAR addr: SockAddr; addrlen: Int32): Int32 "(socklen_t)(connect(sockfd, addr, addrlen))"; PROCEDURE -connect(sockfd: Int32; VAR addr: SYS.ADDRESS; addrlen: Int32): Int32
"(INTEGER)(connect(sockfd, addr, addrlen))";
PROCEDURE Connect*(sockfd: Int32; sockaddr: SYS.ADDRESS; addrlen: Int32): Int32;
BEGIN
RETURN connect(sockfd, sockaddr, addrlen)
END Connect;
(*
PROCEDURE -SizeofSockaddr(): INTEGER
"sizeof(sockaddr)";
PROCEDURE -Error(msg: ARRAY OF CHAR; len: INTEGER)
"write(1/*stdout*/, msg, len); char ch = 0xa; write(1, &ch, 1)";
PROCEDURE sockaddrCheck; (* check for inconsistent usage of sigjmp_buf; better avoid Unix_JmpBuf *)
VAR x, y: LONGINT;
BEGIN
x := SizeofSockaddr();
y := SIZE(SockAddr);
IF x # y THEN
Error("sockets.sockaddrCheck: inconsistent usage of sockaddr", 52);
HALT(1);
END
END sockaddrCheck;
*)
BEGIN BEGIN

View file

@ -6,33 +6,36 @@ TYPE
intarr64 = ARRAY 8 OF SYS.BYTE; (* to emulate int16 on x86_64; -- noch *) intarr64 = ARRAY 8 OF SYS.BYTE; (* to emulate int16 on x86_64; -- noch *)
intarr32 = ARRAY 4 OF SYS.BYTE; intarr32 = ARRAY 4 OF SYS.BYTE;
intarr16 = ARRAY 2 OF SYS.BYTE; intarr16 = ARRAY 2 OF SYS.BYTE;
Int16* = intarr16; (* INTEGER on 32 bit platform *) Int16* = INTEGER; (* INTEGER on 32 bit platform *)
Int32* = INTEGER; Int32* = LONGINT;
Int64* = LONGINT; Int64* = HUGEINT;
String* = ARRAY 256 OF CHAR; String* = ARRAY 256 OF CHAR;
PROCEDURE LongintToInt16*(int: LONGINT; VAR int16: Int16); PROCEDURE HugeintToInt16*(in: HUGEINT; VAR out: Int16);
VAR longintarr : intarr64; VAR
int64 : intarr64;
int16 : intarr16;
BEGIN BEGIN
(*RETURN SYS.VAL(Int16, int)*) int64 := SYS.VAL(intarr64, in);
longintarr := SYS.VAL(intarr64, int); int16[0] := int64[0];
int16[0] := longintarr[0]; int16[1] := int64[1];
int16[1] := longintarr[1]; (* this will work for little endian -- noch *) out := SYS.VAL(Int16, int16)
END LongintToInt16; END HugeintToInt16;
PROCEDURE IntegerToInt16*(int: INTEGER; VAR int16: Int16); PROCEDURE LongintToInt16*(int: LONGINT; VAR int16: Int16);
VAR intarr : intarr32;
BEGIN BEGIN
int16 := SYS.VAL(Int16, int) int16 := SYS.VAL(Int16, int)
(*intarr := SYS.VAL(intarr32, int); END LongintToInt16;
int16[0] := intarr[0];
int16[1] := intarr[1];*) (* this will work for little endian -- noch *)
END IntegerToInt16;
PROCEDURE htons*(in: Int16; VAR out : Int16); PROCEDURE htons*(in: Int16; VAR out : Int16);
VAR
tmpin, tmpout : intarr16;
BEGIN BEGIN
out[0] := in[1]; tmpin := SYS.VAL(intarr16, in);
out[1] := in[0]; tmpout := SYS.VAL(intarr16, out);
tmpout[0] := tmpin[1];
tmpout[1] := tmpin[0];
out := SYS.VAL(Int16, tmpout)
END htons; END htons;
END types. END types.