mirror of https://github.com/ARMmbed/mbed-os.git
Merge pull request #1133 from sarahmarshy/mbedrpc_python_update
Updated to mbedrpc python scriptpull/1140/head
commit
03fff9249b
|
@ -18,50 +18,15 @@ limitations under the License.
|
|||
Example:
|
||||
> from mbedRPC import*
|
||||
> mbed = SerialRPC("COM5",9600);
|
||||
> myled = DigitalOut(mbed, LED1);
|
||||
> myled = DigitalOut(mbed, "myled"); <--- Where the text in quotations matches your
|
||||
RPC pin definition's second parameter, in
|
||||
this case it could be RpcDigitalOut myled(LED1,"myled");
|
||||
> myled.write(1)
|
||||
>
|
||||
"""
|
||||
|
||||
import serial, urllib2, time
|
||||
|
||||
|
||||
class pin():
|
||||
def __init__(self, id):
|
||||
self.name = id
|
||||
|
||||
LED1 = pin("LED1")
|
||||
LED2 = pin("LED2")
|
||||
LED3 = pin("LED3")
|
||||
LED4 = pin("LED4")
|
||||
|
||||
p5 = pin("p5")
|
||||
p6 = pin("p6")
|
||||
p7 = pin("p7")
|
||||
p8 = pin("p8")
|
||||
p9 = pin("p9")
|
||||
p10 = pin("p10")
|
||||
p11 = pin("p11")
|
||||
p12 = pin("p12")
|
||||
p13 = pin("p13")
|
||||
p14 = pin("p14")
|
||||
p15 = pin("p15")
|
||||
p16 = pin("p16")
|
||||
p17 = pin("p17")
|
||||
p18 = pin("p18")
|
||||
p19 = pin("p19")
|
||||
p20 = pin("p20")
|
||||
p21 = pin("p21")
|
||||
p22 = pin("p22")
|
||||
p23 = pin("p23")
|
||||
p24 = pin("p24")
|
||||
p25 = pin("p25")
|
||||
p26 = pin("p26")
|
||||
p27 = pin("p27")
|
||||
p28 = pin("p28")
|
||||
p29 = pin("p29")
|
||||
p30 = pin("p30")
|
||||
|
||||
|
||||
#mbed super class
|
||||
class mbed:
|
||||
def __init__(self):
|
||||
|
@ -71,37 +36,25 @@ class mbed:
|
|||
print("Superclass method not overridden")
|
||||
|
||||
#Transport mechanisms, derived from mbed
|
||||
|
||||
class SerialRPC(mbed):
|
||||
def __init__(self, port, baud=9600, reset=True, debug=False):
|
||||
|
||||
def __init__(self,port, baud):
|
||||
self.ser = serial.Serial(port)
|
||||
self.ser.setBaudrate(baud)
|
||||
self.ser.flushInput()
|
||||
self.ser.flushOutput()
|
||||
self.debug = debug
|
||||
if reset:
|
||||
if debug:
|
||||
print "Reset mbed"
|
||||
self.ser.sendBreak()
|
||||
time.sleep(2)
|
||||
|
||||
def rpc(self, name, method, args):
|
||||
request = "/" + name + "/" + method + " " + " ".join(args)
|
||||
if self.debug:
|
||||
print "[RPC::TX] %s" % request
|
||||
self.ser.write(request + "\n")
|
||||
|
||||
while True:
|
||||
response = self.ser.readline().strip()
|
||||
if self.debug:
|
||||
print "[RPC::RX] %s" % response
|
||||
|
||||
# Ignore comments
|
||||
if not response.startswith('#'): break
|
||||
return response
|
||||
|
||||
#creates the command to be sent serially - /name/method arg1 arg2 arg3 ... argN
|
||||
str = "/" + name + "/" + method + " " + " ".join(args) + "\n"
|
||||
#prints the command being executed
|
||||
print str
|
||||
#writes the command to serial
|
||||
self.ser.write(str)
|
||||
#strips trailing characters from the line just written
|
||||
ret_val = self.ser.readline().strip()
|
||||
return ret_val
|
||||
|
||||
class HTTPRPC(mbed):
|
||||
|
||||
def __init__(self, ip):
|
||||
self.host = "http://" + ip
|
||||
|
||||
|
@ -110,130 +63,112 @@ class HTTPRPC(mbed):
|
|||
return response.read().strip()
|
||||
|
||||
|
||||
#mbed Interfaces
|
||||
|
||||
class DigitalOut():
|
||||
#generic mbed interface super class
|
||||
class mbed_interface():
|
||||
#initialize an mbed interface with a transport mechanism and pin name
|
||||
def __init__(self, this_mbed , mpin):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(mpin, str):
|
||||
if isinstance(mpin,str):
|
||||
self.name = mpin
|
||||
elif isinstance(mpin, pin):
|
||||
self.name = self.mbed.rpc("DigitalOut", "new", [mpin.name])
|
||||
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
|
||||
def write(self, value):
|
||||
r = self.mbed.rpc(self.name, "write", [str(value)])
|
||||
|
||||
#generic read
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return int(r)
|
||||
|
||||
#for classes that need write functionality - inherits from the generic reading interface
|
||||
class mbed_interface_write(mbed_interface):
|
||||
|
||||
class AnalogIn():
|
||||
def __init__(self, this_mbed , mpin):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(mpin, str):
|
||||
self.name = mpin
|
||||
elif isinstance(mpin, pin):
|
||||
self.name = self.mbed.rpc("AnalogIn", "new", [mpin.name])
|
||||
mbed_interface.__init__(self,this_mbed,mpin)
|
||||
#generic write
|
||||
def write(self, value):
|
||||
r = self.mbed.rpc(self.name, "write", [str(value)])
|
||||
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
#mbed interfaces
|
||||
class DigitalOut(mbed_interface_write):
|
||||
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return float(r)
|
||||
def __init__(self, this_mbed , mpin):
|
||||
mbed_interface_write.__init__(self,this_mbed,mpin)
|
||||
|
||||
class AnalogIn(mbed_interface):
|
||||
|
||||
def __init__(self, this_mbed , mpin):
|
||||
mbed_interface.__init__(self,this_mbed,mpin)
|
||||
|
||||
def read_u16(self):
|
||||
r = self.mbed.rpc(self.name, "read_u16", [])
|
||||
return int(r)
|
||||
|
||||
class AnalogOut(mbed_interface_write):
|
||||
|
||||
class AnalogOut():
|
||||
def __init__(self, this_mbed , mpin):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(mpin, str):
|
||||
self.name = mpin
|
||||
elif isinstance(mpin, pin):
|
||||
self.name = self.mbed.rpc("AnalogOut", "new", [mpin.name])
|
||||
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
|
||||
def write(self, value):
|
||||
r = self.mbed.rpc(self.name, "write", [str(value)])
|
||||
mbed_interface_write.__init__(self,this_mbed,mpin)
|
||||
|
||||
def write_u16(self, value):
|
||||
r = self.mbed.rpc(self.name, "write_u16", [str(value)])
|
||||
self.mbed.rpc(self.name, "write_u16", [str(value)])
|
||||
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return float(r)
|
||||
|
||||
class DigitalIn(mbed_interface):
|
||||
|
||||
class DigitalIn():
|
||||
def __init__(self, this_mbed , mpin):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(mpin, str):
|
||||
self.name = mpin
|
||||
elif isinstance(mpin, pin):
|
||||
self.name = self.mbed.rpc("DigitalIn", "new", [mpin.name])
|
||||
mbed_interface.__init__(self,this_mbed,mpin)
|
||||
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
class PwmOut(mbed_interface_write):
|
||||
|
||||
def __init__(self, this_mbed , mpin):
|
||||
mbed_interface_write.__init__(self,this_mbed,mpin)
|
||||
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return int(r)
|
||||
|
||||
|
||||
class PwmOut():
|
||||
def __init__(self, this_mbed , mpin):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(mpin, str):
|
||||
self.name = mpin
|
||||
elif isinstance(mpin, pin):
|
||||
self.name = self.mbed.rpc("PwmOut", "new", [mpin.name])
|
||||
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
|
||||
def write(self, value):
|
||||
r = self.mbed.rpc(self.name, "write", [str(value)])
|
||||
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return float(r)
|
||||
return r
|
||||
|
||||
def period(self, value):
|
||||
r = self.mbed.rpc(self.name, "period", [str(value)])
|
||||
self.mbed.rpc(self.name, "period", [str(value)])
|
||||
|
||||
def period_ms(self, value):
|
||||
r = self.mbed.rpc(self.name, "period_ms", [str(value)])
|
||||
self.mbed.rpc(self.name, "period_ms", [str(value)])
|
||||
|
||||
def period_us(self, value):
|
||||
r = self.mbed.rpc(self.name, "period_us", [str(value)])
|
||||
self.mbed.rpc(self.name, "period_us", [str(value)])
|
||||
|
||||
def puslewidth(self, value):
|
||||
r = self.mbed.rpc(self.name, "pulsewidth", [str(value)])
|
||||
def pulsewidth(self, value):
|
||||
self.mbed.rpc(self.name, "pulsewidth", [str(value)])
|
||||
|
||||
def puslewidth_ms(self, value):
|
||||
r = self.mbed.rpc(self.name, "pulsewidth_ms", [str(value)])
|
||||
def pulsewidth_ms(self, value):
|
||||
self.mbed.rpc(self.name, "pulsewidth_ms", [str(value)])
|
||||
|
||||
def puslewidth_us(self, value):
|
||||
r = self.mbed.rpc(self.name, "pulsewidth_us", [str(value)])
|
||||
def pulsewidth_us(self, value):
|
||||
self.mbed.rpc(self.name, "pulsewidth_us", [str(value)])
|
||||
|
||||
class RPCFunction(mbed_interface):
|
||||
|
||||
def __init__(self, this_mbed , name):
|
||||
mbed_interface.__init__(self,this_mbed,name)
|
||||
|
||||
def run(self, input):
|
||||
r = self.mbed.rpc(self.name, "run", [input])
|
||||
return r
|
||||
|
||||
class RPCVariable(mbed_interface_write):
|
||||
|
||||
def __init__(self, this_mbed , name):
|
||||
mbed_interface_write.__init__(self,this_mbed,name)
|
||||
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return r
|
||||
#Serial
|
||||
class Serial():
|
||||
|
||||
def __init__(self, this_mbed , tx, rx = ""):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(tx, str):
|
||||
self.name = mpin
|
||||
elif isinstance(mpin, pin):
|
||||
self.name = self.mbed.rpc("Serial", "new", [tx.name, rx.name])
|
||||
|
||||
self.name = tx
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
|
||||
|
@ -248,40 +183,5 @@ class Serial():
|
|||
return int(r)
|
||||
|
||||
|
||||
class RPCFunction():
|
||||
def __init__(self, this_mbed , name):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(name, str):
|
||||
self.name = name
|
||||
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return int(r)
|
||||
|
||||
def run(self, input):
|
||||
r = self.mbed.rpc(self.name, "run", [input])
|
||||
return r
|
||||
|
||||
|
||||
class RPCVariable():
|
||||
def __init__(self, this_mbed , name):
|
||||
self.mbed = this_mbed
|
||||
if isinstance(name, str):
|
||||
self.name = name
|
||||
|
||||
def __del__(self):
|
||||
r = self.mbed.rpc(self.name, "delete", [])
|
||||
|
||||
def write(self, value):
|
||||
self.mbed.rpc(self.name, "write", [str(value)])
|
||||
|
||||
def read(self):
|
||||
r = self.mbed.rpc(self.name, "read", [])
|
||||
return r
|
||||
|
||||
|
||||
def wait(s):
|
||||
time.sleep(s)
|
||||
|
|
Loading…
Reference in New Issue