Changeset 165


Ignore:
Timestamp:
06/26/12 03:13:44 (13 years ago)
Author:
atzm
Message:
  • kill multi-thread
File:
1 edited

Legend:

Unmodified
Added
Removed
  • etherws/trunk/etherws.py

    r164 r165  
    4949import getpass 
    5050import argparse 
    51 import threading 
     51import traceback 
    5252 
    5353import pytun 
     
    150150        self._clients = [] 
    151151        self._table = SwitchingTable(debug=debug) 
    152         self._tablelock = threading.Lock() 
    153152        self._tap = pytun.TunTapDevice(dev, pytun.IFF_TAP | pytun.IFF_NO_PI) 
    154153        self._tap.up() 
    155         self._taplock = threading.Lock() 
    156154        self.register_client(self) 
    157155 
     
    166164        self._clients.remove(client) 
    167165 
    168     # synchronized methods 
    169166    def write_message(self, message, binary=False): 
    170         with self._taplock: 
    171             self._tap.write(message) 
     167        self._tap.write(message) 
    172168 
    173169    def write(self, caller, message): 
    174170        frame = EthernetFrame(message) 
    175171 
    176         with self._tablelock: 
    177             self._table.learn(frame, caller) 
     172        self._table.learn(frame, caller) 
    178173 
    179174        if not frame.multicast: 
    180             with self._tablelock: 
    181                 dst = self._table.lookup(frame) 
     175            dst = self._table.lookup(frame) 
    182176 
    183177            if dst: 
     
    204198 
    205199        while True: 
    206             with self._taplock: 
    207                 data = self._tap.read(self.READ_SIZE) 
     200            data = self._tap.read(self.READ_SIZE) 
    208201 
    209202            if data: 
     
    264257        self._sock = None 
    265258        self.dprintf('disconnected: %s\n', lambda: self._url) 
     259 
     260    def fileno(self): 
     261        if self.closed: 
     262            raise websocket.WebSocketException('closed socket') 
     263        return self._sock.io_sock.fileno() 
    266264 
    267265    def write_message(self, message, binary=False): 
     
    274272        self._sock.send(message, flag) 
    275273 
    276     def run_forever(self): 
     274    def __call__(self, fd, events): 
    277275        try: 
    278             if self.closed: 
    279                 self.open() 
    280             while True: 
    281                 data = self._sock.recv() 
    282                 if data is None: 
    283                     break 
     276            data = self._sock.recv() 
     277            if data is not None: 
    284278                self._tap.write(self, data) 
    285         finally: 
    286             self.close() 
     279                return 
     280        except: 
     281            traceback.print_exc() 
     282        tornado.ioloop.IOLoop.instance().stop() 
    287283 
    288284 
     
    432428    ioloop = tornado.ioloop.IOLoop.instance() 
    433429    ioloop.add_handler(tap.fileno(), tap, ioloop.READ) 
    434  
    435     t = threading.Thread(target=ioloop.start) 
    436     t.setDaemon(True) 
     430    ioloop.add_handler(client.fileno(), client, ioloop.READ) 
    437431 
    438432    if not args.foreground: 
    439433        daemonize() 
    440434 
    441     t.start() 
    442     client.run_forever() 
     435    ioloop.start() 
    443436 
    444437 
Note: See TracChangeset for help on using the changeset viewer.