mung server
--HG-- branch : mung
This commit is contained in:
commit
8a5b25e6b0
6 changed files with 200 additions and 0 deletions
10
Test.dsdb
Normal file
10
Test.dsdb
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
#0 "System Object" #-1
|
||||||
|
:"eval" cp *
|
||||||
|
CALLBUILTIN eval argstr
|
||||||
|
.
|
||||||
|
:"handle_connection" x *
|
||||||
|
RETURN #0;
|
||||||
|
.
|
||||||
|
|
||||||
|
|
||||||
|
|
0
bytecode.py
Normal file
0
bytecode.py
Normal file
3
database_dsdb.py
Normal file
3
database_dsdb.py
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
20
language.py
Normal file
20
language.py
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
|
||||||
|
from ply import lex
|
||||||
|
|
||||||
|
tokens = (
|
||||||
|
"OPERATION",
|
||||||
|
"LITERAL",
|
||||||
|
"VARIABLE"
|
||||||
|
)
|
||||||
|
|
||||||
|
t_OPERATION = (
|
||||||
|
r"CALLBUILTIN|CALLFUNC|SETVAR|RETURN"
|
||||||
|
)
|
||||||
|
|
||||||
|
t_LITERAL = (
|
||||||
|
r'"i"'
|
||||||
|
)
|
||||||
|
|
||||||
|
lex.lex()
|
||||||
|
print lex
|
||||||
|
|
135
listener.py
Normal file
135
listener.py
Normal file
|
@ -0,0 +1,135 @@
|
||||||
|
import os, sys, time
|
||||||
|
import socket
|
||||||
|
import select
|
||||||
|
import random
|
||||||
|
|
||||||
|
class Connection(object):
|
||||||
|
def __init__(self, id, conn, addr):
|
||||||
|
self.id = id
|
||||||
|
self.conn = conn
|
||||||
|
self.addr = addr
|
||||||
|
self.input_encoding = 'raw'
|
||||||
|
self.output_encoding = 'ascii'
|
||||||
|
self.linebuffer = True
|
||||||
|
|
||||||
|
def fileno(self):
|
||||||
|
return self.conn.fileno()
|
||||||
|
|
||||||
|
def escape(self, data):
|
||||||
|
bytes = map(ord, data)
|
||||||
|
for i, byte in enumerate(bytes):
|
||||||
|
if byte > 32 and byte < 125:
|
||||||
|
bytes[i] = chr(byte)
|
||||||
|
elif byte == 10 and self.linebuffer:
|
||||||
|
bytes[i] = chr(byte)
|
||||||
|
else:
|
||||||
|
bytes[i] = "~%x" % (byte,)
|
||||||
|
return "".join(bytes)
|
||||||
|
|
||||||
|
|
||||||
|
def recv(self, bytes=4096):
|
||||||
|
data = self.conn.recv(bytes)
|
||||||
|
|
||||||
|
if self.input_encoding == 'raw':
|
||||||
|
return unicode(self.escape(data), 'ascii')
|
||||||
|
else:
|
||||||
|
return unicode(data, self.input_encoding, 'ignore')
|
||||||
|
|
||||||
|
|
||||||
|
class Listener(object):
|
||||||
|
def __init__(self):
|
||||||
|
self.socket = None
|
||||||
|
self.bind_addr = None
|
||||||
|
self.bind_port = None
|
||||||
|
self.connections = {}
|
||||||
|
self.connection_list = []
|
||||||
|
self.connection_list_dirty = False
|
||||||
|
|
||||||
|
self.MAX_CONN = 3000
|
||||||
|
|
||||||
|
def listen(self, addr, port):
|
||||||
|
if self.socket != None:
|
||||||
|
raise ValueError("Already listening on %s:%d" % (self.bind_addr, self.bind_port))
|
||||||
|
|
||||||
|
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||||
|
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||||||
|
|
||||||
|
s.bind((addr, port))
|
||||||
|
self.bind_addr = addr
|
||||||
|
self.bind_port = port
|
||||||
|
|
||||||
|
s.setblocking(0)
|
||||||
|
s.listen(1)
|
||||||
|
self.socket = s
|
||||||
|
|
||||||
|
def add_connection(self, conn, addr):
|
||||||
|
addr = "%s:%d" % addr
|
||||||
|
while True:
|
||||||
|
connid = random.randint(1, 65535)
|
||||||
|
|
||||||
|
if not connid in self.connections:
|
||||||
|
print "%s connected from %s" % (connid, addr)
|
||||||
|
self.connections[connid] = Connection(connid, conn, addr)
|
||||||
|
self.connection_list_dirty = True
|
||||||
|
break
|
||||||
|
|
||||||
|
|
||||||
|
def delete_connection(self, conn):
|
||||||
|
print "%s disconnected." % (conn.id,)
|
||||||
|
del self.connections[conn.id]
|
||||||
|
self.connection_list_dirty = True
|
||||||
|
|
||||||
|
def all_connections(self):
|
||||||
|
if self.connection_list_dirty:
|
||||||
|
self.connection_list = self.connections.values()
|
||||||
|
self.connection_list_dirty = False
|
||||||
|
|
||||||
|
return self.connection_list
|
||||||
|
|
||||||
|
|
||||||
|
def handle_incoming_connections(self):
|
||||||
|
while True:
|
||||||
|
r, w, x = select.select([self.socket], [], [], 0)
|
||||||
|
|
||||||
|
if not r:
|
||||||
|
break
|
||||||
|
|
||||||
|
conn, addr = self.socket.accept()
|
||||||
|
conn.setblocking(0)
|
||||||
|
|
||||||
|
if len(self.connections) < self.MAX_CONN:
|
||||||
|
self.add_connection(conn, addr)
|
||||||
|
else:
|
||||||
|
conn.close()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def scan_for_input(self, callback):
|
||||||
|
r, w, x = select.select(self.all_connections(), [], [], 0)
|
||||||
|
for conn in r:
|
||||||
|
input = conn.recv()
|
||||||
|
if input == '':
|
||||||
|
self.delete_connection(conn)
|
||||||
|
else:
|
||||||
|
callback(conn, input)
|
||||||
|
|
||||||
|
def shutdown(self):
|
||||||
|
for x in self.connection_list:
|
||||||
|
x.conn.close()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
l = Listener()
|
||||||
|
l.listen("", 7878)
|
||||||
|
print "Listening on %s:%d" % (l.bind_addr, l.bind_port)
|
||||||
|
|
||||||
|
try:
|
||||||
|
while True:
|
||||||
|
l.handle_incoming_connections()
|
||||||
|
l.scan_for_input()
|
||||||
|
time.sleep(1)
|
||||||
|
finally:
|
||||||
|
l.shutdown()
|
||||||
|
|
||||||
|
|
||||||
|
|
32
server.py
Normal file
32
server.py
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
import os, sys, time
|
||||||
|
from listener import Listener
|
||||||
|
|
||||||
|
class Server(object):
|
||||||
|
def __init__(self, dbname):
|
||||||
|
self.dbname = dbname
|
||||||
|
self.listeners = []
|
||||||
|
|
||||||
|
def listen(self, addr, port):
|
||||||
|
l = Listener()
|
||||||
|
l.listen(addr, port)
|
||||||
|
self.listeners.append(l)
|
||||||
|
|
||||||
|
def mainloop(self):
|
||||||
|
while True:
|
||||||
|
for l in self.listeners:
|
||||||
|
l.handle_incoming_connections()
|
||||||
|
l.scan_for_input(self.read_input)
|
||||||
|
time.sleep(2)
|
||||||
|
|
||||||
|
|
||||||
|
def read_input(self, conn, data):
|
||||||
|
ds = data.split('\n')
|
||||||
|
if ds[-1] == '':
|
||||||
|
del ds[-1]
|
||||||
|
for line in ds:
|
||||||
|
print "%s: %s" % (conn.id, line)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
srv = Server("Test")
|
||||||
|
srv.listen("", 7878)
|
||||||
|
srv.mainloop()
|
Loading…
Add table
Reference in a new issue