OXIESEC PANEL
- Current Dir:
/
/
snap
/
core
/
17210
/
usr
/
lib
/
python3
/
dist-packages
/
serial
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
10/02/2024 07:52:55 PM
rwxr-xr-x
📄
__init__.py
3.04 KB
01/11/2016 09:54:11 PM
rw-r--r--
📁
__pycache__
-
10/02/2024 07:52:55 PM
rwxr-xr-x
📄
aio.py
3.55 KB
12/16/2015 10:00:40 PM
rw-r--r--
📄
rfc2217.py
56.8 KB
12/16/2015 09:56:35 PM
rw-r--r--
📄
rs485.py
3.19 KB
12/16/2015 09:52:07 PM
rw-r--r--
📄
serialcli.py
9.22 KB
12/16/2015 09:53:00 PM
rw-r--r--
📄
serialjava.py
8.87 KB
12/16/2015 09:53:28 PM
rw-r--r--
📄
serialposix.py
29.47 KB
12/16/2015 09:53:46 PM
rw-r--r--
📄
serialutil.py
19.05 KB
01/02/2016 10:22:59 PM
rw-r--r--
📄
serialwin32.py
17.93 KB
12/16/2015 10:05:30 PM
rw-r--r--
📁
threaded
-
10/02/2024 07:52:54 PM
rwxr-xr-x
📁
tools
-
10/02/2024 07:52:55 PM
rwxr-xr-x
📁
urlhandler
-
10/02/2024 07:52:54 PM
rwxr-xr-x
📄
win32.py
10.2 KB
12/16/2015 09:56:19 PM
rw-r--r--
Editing: __init__.py
Close
#!/usr/bin/env python # # This is a wrapper module for different platform implementations # # This file is part of pySerial. https://github.com/pyserial/pyserial # (C) 2001-2016 Chris Liechti <cliechti@gmx.net> # # SPDX-License-Identifier: BSD-3-Clause import importlib import sys from serial.serialutil import * #~ SerialBase, SerialException, to_bytes, iterbytes VERSION = '3.0.1' if sys.platform == 'cli': from serial.serialcli import Serial else: import os # chose an implementation, depending on os if os.name == 'nt': # sys.platform == 'win32': from serial.serialwin32 import Serial elif os.name == 'posix': from serial.serialposix import Serial, PosixPollSerial, VTIMESerial elif os.name == 'java': from serial.serialjava import Serial else: raise ImportError("Sorry: no implementation for your platform ('%s') available" % (os.name,)) protocol_handler_packages = [ 'serial.urlhandler', ] def serial_for_url(url, *args, **kwargs): """\ Get an instance of the Serial class, depending on port/url. The port is not opened when the keyword parameter 'do_not_open' is true, by default it is. All other parameters are directly passed to the __init__ method when the port is instantiated. The list of package names that is searched for protocol handlers is kept in ``protocol_handler_packages``. e.g. we want to support a URL ``foobar://``. A module ``my_handlers.protocol_foobar`` is provided by the user. Then ``protocol_handler_packages.append("my_handlers")`` would extend the search path so that ``serial_for_url("foobar://"))`` would work. """ # check and remove extra parameter to not confuse the Serial class do_open = not kwargs.pop('do_not_open', False) # the default is to use the native implementation klass = Serial try: url_lowercase = url.lower() except AttributeError: # it's not a string, use default pass else: # if it is an URL, try to import the handler module from the list of possible packages if '://' in url_lowercase: protocol = url_lowercase.split('://', 1)[0] module_name = '.protocol_%s' % (protocol,) for package_name in protocol_handler_packages: try: package = importlib.import_module(package_name) handler_module = importlib.import_module(module_name, package_name) except ImportError: continue else: if hasattr(handler_module, 'serial_class_for_url'): url, klass = handler_module.serial_class_for_url(url) else: klass = handler_module.Serial break else: raise ValueError('invalid URL, protocol %r not known' % (protocol,)) # instantiate and open when desired instance = klass(None, *args, **kwargs) instance.port = url if do_open: instance.open() return instance