From b5c2382364e1e833edda31aa16831cc527e16c52 Mon Sep 17 00:00:00 2001 From: Mike Naberezny Date: Mon, 2 Jan 2012 17:13:40 -0800 Subject: [PATCH] Add the ability to load from URLs --- CHANGES.txt | 2 ++ src/py65/monitor.py | 27 +++++++++++++++++++-------- 2 files changed, 21 insertions(+), 8 deletions(-) diff --git a/CHANGES.txt b/CHANGES.txt index a48fac7..00938db 100644 --- a/CHANGES.txt +++ b/CHANGES.txt @@ -5,6 +5,8 @@ - The monitor now accepts command line arguments. See ``py65mon --help`` for usage. Contributed by Ed Spittles. + - The monitor's load command can now fetch URLs. + 0.10 (2011-08-27) - Fixed long-standing bugs in relative branch calculations in the diff --git a/src/py65/monitor.py b/src/py65/monitor.py index 71941b7..7746152 100644 --- a/src/py65/monitor.py +++ b/src/py65/monitor.py @@ -18,6 +18,7 @@ import os import re import shlex import sys +import urllib2 from asyncore import compact_traceback from py65.devices.mpu6502 import MPU as NMOS6502 from py65.devices.mpu65c02 import MPU as CMOS65C02 @@ -476,14 +477,24 @@ class Monitor(cmd.Cmd): else: start = self._mpu.pc - try: - f = open(filename, 'rb') - bytes = f.read() - f.close() - except (OSError, IOError), why: - msg = "Cannot load file: [%d] %s" % (why[0], why[1]) - self._output(msg) - return + if "://" in filename: + try: + f = urllib2.urlopen(filename) + bytes = f.read() + f.close() + except (urllib2.URLError, urllib2.HTTPError), why: + msg = "Cannot fetch remote file: %s" % str(why) + self._output(msg) + return + else: + try: + f = open(filename, 'rb') + bytes = f.read() + f.close() + except (OSError, IOError), why: + msg = "Cannot load file: [%d] %s" % (why[0], why[1]) + self._output(msg) + return # if the start address was -1, we load to top of memory if start == -1: