X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=decoders%2Fmidi%2Fpd.py;h=5915976c164535d42c10d29b920f9a81795777a3;hb=e4227bafd63472d1a0d23fa54f62a2b20e296115;hp=7c4fa9afd794cfc6e0739e3398bddef6e46eb32b;hpb=0169f19c53e195df2f96c4df731ad3214c59e20a;p=libsigrokdecode.git diff --git a/decoders/midi/pd.py b/decoders/midi/pd.py index 7c4fa9a..5915976 100644 --- a/decoders/midi/pd.py +++ b/decoders/midi/pd.py @@ -18,8 +18,6 @@ ## Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA ## -# MIDI protocol decoder - import sigrokdecode as srd from .lists import * @@ -27,7 +25,7 @@ RX = 0 TX = 1 class Decoder(srd.Decoder): - api_version = 1 + api_version = 2 id = 'midi' name = 'MIDI' longname = 'Musical Instrument Digital Interface' @@ -35,13 +33,9 @@ class Decoder(srd.Decoder): license = 'gplv2+' inputs = ['uart'] outputs = ['midi'] - probes = [] - optional_probes = [] - options = {} - annotations = [ - ['Text (verbose)', 'Human-readable text (verbose)'], - # ['Text', 'Human-readable text'], - ] + annotations = ( + ('text-verbose', 'Human-readable text (verbose)'), + ) def __init__(self, **kwargs): self.cmd = [] @@ -52,7 +46,6 @@ class Decoder(srd.Decoder): self.es_block = None def start(self): - # self.out_proto = self.register(srd.OUTPUT_PYTHON) self.out_ann = self.register(srd.OUTPUT_ANN) def putx(self, data): @@ -77,7 +70,7 @@ class Decoder(srd.Decoder): c = self.cmd if len(c) < 3: return - self.es_block = self.ss + self.es_block = self.es msg, chan, note, velocity = c[0] & 0xf0, (c[0] & 0x0f) + 1, c[1], c[2] s = 'note off' if (velocity == 0) else status_bytes[msg] self.putx([0, ['Channel %d: %s (note = %d, velocity = %d)' % \ @@ -169,7 +162,7 @@ class Decoder(srd.Decoder): def handle_sysrealtime_msg(self, newbyte): # System realtime message: 0b11111ttt (t = message type) - self.es_block = self.ss + self.es_block = self.es self.putx([0, ['System realtime message: %s' % status_bytes[newbyte]]]) self.cmd, self.state = [], 'IDLE' @@ -182,6 +175,9 @@ class Decoder(srd.Decoder): self.ss, self.es = ss, es + # We're only interested in the byte value (not individual bits). + pdata = pdata[0] + # Short MIDI overview: # - Status bytes are 0x80-0xff, data bytes are 0x00-0x7f. # - Most messages: 1 status byte, 1-2 data bytes. @@ -213,6 +209,3 @@ class Decoder(srd.Decoder): self.handle_syscommon_msg(pdata) elif self.state == 'HANDLE SYSREALTIME MSG': self.handle_sysrealtime_msg(pdata) - else: - raise Exception('Invalid state: %s' % self.state) -