Rename Frotz plugin to TextAdventures

This commit is contained in:
oddluck 2019-12-06 03:20:32 +00:00
parent 577b0ee5f2
commit 1723b16e05
39 changed files with 22 additions and 23 deletions

View File

@ -6,7 +6,7 @@
### ###
""" """
Frotz: Play interactive fiction games TextAdventures: Play interactive fiction games
""" """
import supybot import supybot
@ -40,5 +40,5 @@ if world.testing:
from . import test from . import test
Class = plugin.Class Class = plugin.Class
Frotz = config.Frotz TextAdventures = config.TextAdventures

View File

@ -9,7 +9,7 @@ import supybot.conf as conf
import supybot.registry as registry import supybot.registry as registry
try: try:
from supybot.i18n import PluginInternationalization from supybot.i18n import PluginInternationalization
_ = PluginInternationalization('Frotz') _ = PluginInternationalization('TextAdventures')
except: except:
# Placeholder that allows to run the plugin on a bot # Placeholder that allows to run the plugin on a bot
# without the i18n module # without the i18n module
@ -22,14 +22,14 @@ def configure(advanced):
# user or not. You should effect your configuration by manipulating the # user or not. You should effect your configuration by manipulating the
# registry as appropriate. # registry as appropriate.
from supybot.questions import expect, anything, something, yn from supybot.questions import expect, anything, something, yn
conf.registerPlugin('Frotz', True) conf.registerPlugin('TextAdventures', True)
Frotz = conf.registerPlugin('Frotz') TextAdventures = conf.registerPlugin('TextAdventures')
conf.registerGlobalValue(Frotz, 'dfrotzPath', conf.registerGlobalValue(TextAdventures, 'dfrotzPath',
registry.String('/usr/local/bin/dfrotz', _("""The path to the dfrotz executable."""))) registry.String('/usr/local/bin/dfrotz', _("""The path to the dfrotz executable.""")))
conf.registerGlobalValue(Frotz, 'allowPrivate', conf.registerGlobalValue(TextAdventures, 'allowPrivate',
registry.Boolean('True', _("""Allow games to be played over private message."""))) registry.Boolean('True', _("""Allow games to be played over private message.""")))
Frotz = conf.registerPlugin('Frotz') TextAdventures = conf.registerPlugin('TextAdventures')

View File

@ -17,28 +17,28 @@ import re
try: try:
from supybot.i18n import PluginInternationalization from supybot.i18n import PluginInternationalization
_ = PluginInternationalization('Infocom') _ = PluginInternationalization('TextAdventures')
except ImportError: except ImportError:
# Placeholder that allows to run the plugin on a bot # Placeholder that allows to run the plugin on a bot
# without the i18n module # without the i18n module
_ = lambda x: x _ = lambda x: x
class Frotz(callbacks.Plugin): class TextAdventures(callbacks.Plugin):
""" """
Play Infocom (Interactive Fiction, Z_machine) Games. Play Text Adventure Games (Infocom, Interactive Fiction, Z-Machine) .
""" """
threaded = True threaded = True
def __init__(self, irc): def __init__(self, irc):
self.__parent = super(Frotz, self) self.__parent = super(TextAdventures, self)
self.__parent.__init__(irc) self.__parent.__init__(irc)
self.game = {} self.game = {}
self.game_path = "{0}/games/".format(os.path.dirname(os.path.abspath(__file__))) self.game_path = "{0}/games/".format(os.path.dirname(os.path.abspath(__file__)))
self.binary = self.registryValue('dfrotzPath') self.binary = self.registryValue('dFrotzPath')
def load(self, irc, msg, args, input): def open(self, irc, msg, args, input):
"""<game_name> """<game_name>
Load <game_name.z*>. Open <game_name.z*>.
""" """
channel = msg.args[0] channel = msg.args[0]
if not self.registryValue('allowPrivate') and not irc.isChannel(channel): if not self.registryValue('allowPrivate') and not irc.isChannel(channel):
@ -53,12 +53,12 @@ class Frotz(callbacks.Plugin):
else: else:
irc.reply("Starting {0} on {1}. Please wait...".format(game_name, channel)) irc.reply("Starting {0} on {1}. Please wait...".format(game_name, channel))
game_file= "{0}{1}".format(self.game_path, game_name) game_file= "{0}{1}".format(self.game_path, game_name)
self.game[channel] = pexpect.spawn("{0} -S 0 {1}".format(self.binary, game_file)) self.game[channel] = pexpect.spawn("{0} -m -S 0 {1}".format(self.binary, game_file))
response = self.output(self.game[channel]) response = self.output(self.game[channel])
for line in response: for line in response:
if line.strip() and line.strip() != ".": if line.strip() and line.strip() != ".":
irc.reply(line, prefixNick=False) irc.reply(line, prefixNick=False)
load = wrap(load, ['text']) open = wrap(open, ['text'])
def output(self, output): def output(self, output):
response = [] response = []
@ -90,9 +90,9 @@ class Frotz(callbacks.Plugin):
if line.strip() and line.strip() != ".": if line.strip() and line.strip() != ".":
irc.reply(line, prefixNick=False) irc.reply(line, prefixNick=False)
def stop(self, irc, msg, args): def end(self, irc, msg, args):
""" """
Stop game. End text adventure game.
""" """
channel = msg.args[0] channel = msg.args[0]
if not irc.isChannel(channel): if not irc.isChannel(channel):
@ -111,7 +111,7 @@ class Frotz(callbacks.Plugin):
except: except:
return return
return return
stop = wrap(stop) end = wrap(end)
def z(self, irc, msg, args, command): def z(self, irc, msg, args, command):
"""[<input>] """[<input>]
@ -143,5 +143,5 @@ class Frotz(callbacks.Plugin):
irc.reply(reply, prefixNick=False) irc.reply(reply, prefixNick=False)
games = wrap(games) games = wrap(games)
Class = Frotz Class = TextAdventures

View File

@ -9,9 +9,8 @@ from supybot.test import *
class InfocomTestCase(PluginTestCase): class InfocomTestCase(PluginTestCase):
plugins = ('Frotz',) plugins = ('TextAdventures',)
# vim:set shiftwidth=4 tabstop=4 expandtab textwidth=79: # vim:set shiftwidth=4 tabstop=4 expandtab textwidth=79: