mirror of
https://github.com/vishapoberon/vipak.git
synced 2026-04-05 20:42:26 +00:00
compiles.
This commit is contained in:
parent
4acd41201c
commit
4c64d37338
5 changed files with 79 additions and 36 deletions
2
Makefile
2
Makefile
|
|
@ -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
28
irc.Mod
|
|
@ -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.
|
||||||
|
|
|
||||||
12
netdb.Mod
12
netdb.Mod
|
|
@ -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.
|
||||||
|
|
|
||||||
34
sockets.Mod
34
sockets.Mod
|
|
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
39
types.Mod
39
types.Mod
|
|
@ -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.
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue