projects
/
open-adventure.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
saveresume.c: add missing semicolon
[open-adventure.git]
/
make_graph.py
diff --git
a/make_graph.py
b/make_graph.py
index f29c3e183b5a1b1ef1057e01a1aa7c849ef870fc..cd786edcd091d6f4dbfaf5116841630026e85f02 100755
(executable)
--- a/
make_graph.py
+++ b/
make_graph.py
@@
-1,43
+1,58
@@
#!/usr/bin/env python3
#!/usr/bin/env python3
+# SPDX-FileCopyrightText: Eric S. Raymond <esr@thyrsus.com>
+# SPDX-License-Identifier: BSD-2-Clause
"""\
"""\
-usage: make
-graph.py [-a] -d] [-m] [-s
]
+usage: make
_graph.py [-a] -d] [-m] [-s] [-v
]
Make a DOT graph of Colossal Cave.
-a = emit graph of entire dungeon
Make a DOT graph of Colossal Cave.
-a = emit graph of entire dungeon
--d = emit gra
oh of mazw
all different
+-d = emit gra
ph of maze
all different
-f = emit graph of forest locations
-m = emit graph of maze all alike
-s = emit graph of non-forest surface locations
-f = emit graph of forest locations
-m = emit graph of maze all alike
-s = emit graph of non-forest surface locations
--v = include internal sy
,no;
s in room labels
+-v = include internal sy
mbol
s in room labels
"""
"""
-# Copyright (c) 2017 by Eric S. Raymond
-#
SPDX-License-Identifier: BSD-2-claus
e
+
+#
pylint: disable=consider-using-f-string,line-too-long,invalid-name,missing-function-docstring,multiple-imports,redefined-outer-nam
e
import sys, getopt, yaml
import sys, getopt, yaml
+
def allalike(loc):
"Select out loci related to the Maze All Alike"
def allalike(loc):
"Select out loci related to the Maze All Alike"
- return ("ALIKE" in loc) or (loc == "LOC_PITBRINK") or ("MAZEEND" in loc) or ("STALACTITE" in loc)
+ return location_lookup[loc]["conditions"].get("ALLALIKE")
+
def alldifferent(loc):
"Select out loci related to the Maze All Alike"
def alldifferent(loc):
"Select out loci related to the Maze All Alike"
- return ("DIFFERENT" in loc) or (loc == "LOC_DEADEND13")
+ return location_lookup[loc]["conditions"].get("ALLDIFFERENT")
+
def surface(loc):
"Select out surface locations"
return location_lookup[loc]["conditions"].get("ABOVE")
def surface(loc):
"Select out surface locations"
return location_lookup[loc]["conditions"].get("ABOVE")
+
def forest(loc):
return location_lookup[loc]["conditions"].get("FOREST")
def forest(loc):
return location_lookup[loc]["conditions"].get("FOREST")
+
def abbreviate(d):
def abbreviate(d):
- m = {"NORTH":"N", "EAST":"E", "SOUTH":"S", "WEST":"W", "UPWAR":"U", "DOWN":"D"}
+ m = {
+ "NORTH": "N",
+ "EAST": "E",
+ "SOUTH": "S",
+ "WEST": "W",
+ "UPWAR": "U",
+ "DOWN": "D",
+ }
return m.get(d, d)
return m.get(d, d)
+
def roomlabel(loc):
"Generate a room label from the description, if possible"
def roomlabel(loc):
"Generate a room label from the description, if possible"
- loc_descriptions = location_lookup[loc][
'description'
]
+ loc_descriptions = location_lookup[loc][
"description"
]
description = ""
if debug:
description = loc[4:]
description = ""
if debug:
description = loc[4:]
@@
-49,8
+64,12
@@
def roomlabel(loc):
if short.startswith("You're "):
short = short[7:]
if short.startswith("You are "):
if short.startswith("You're "):
short = short[7:]
if short.startswith("You are "):
- short = short[8 :]
- if short.startswith("in ") or short.startswith("at ") or short.startswith("on "):
+ short = short[8:]
+ if (
+ short.startswith("in ")
+ or short.startswith("at ")
+ or short.startswith("on ")
+ ):
short = short[3:]
if short.startswith("the "):
short = short[4:]
short = short[3:]
if short.startswith("the "):
short = short[4:]
@@
-67,8
+86,9
@@
def roomlabel(loc):
description += "\\n(" + ",".join(startlocs[loc]).lower() + ")"
return description
description += "\\n(" + ",".join(startlocs[loc]).lower() + ")"
return description
+
# A forwarder is a location that you can't actually stop in - when you go there
# A forwarder is a location that you can't actually stop in - when you go there
-# it ships some message (which is the point) then shifts you to a nex
r
location.
+# it ships some message (which is the point) then shifts you to a nex
t
location.
# A forwarder has a zero-length array of notion verbs in its travel section.
#
# Here is an example forwarder declaration:
# A forwarder has a zero-length array of notion verbs in its travel section.
#
# Here is an example forwarder declaration:
@@
-83,10
+103,12
@@
def roomlabel(loc):
# {verbs: [], action: [goto, LOC_NOWHERE]},
# ]
# {verbs: [], action: [goto, LOC_NOWHERE]},
# ]
+
def is_forwarder(loc):
"Is a location a forwarder?"
def is_forwarder(loc):
"Is a location a forwarder?"
- travel = location_lookup[loc]['travel']
- return len(travel) == 1 and len(travel[0]['verbs']) == 0
+ travel = location_lookup[loc]["travel"]
+ return len(travel) == 1 and len(travel[0]["verbs"]) == 0
+
def forward(loc):
"Chase a location through forwarding links."
def forward(loc):
"Chase a location through forwarding links."
@@
-94,8
+116,9
@@
def forward(loc):
loc = location_lookup[loc]["travel"][0]["action"][1]
return loc
loc = location_lookup[loc]["travel"][0]["action"][1]
return loc
+
def reveal(objname):
def reveal(objname):
- "Should this object be revealed when mappin
m
g?"
+ "Should this object be revealed when mapping?"
if "OBJ_" in objname:
return False
if objname == "VEND":
if "OBJ_" in objname:
return False
if objname == "VEND":
@@
-103,8
+126,9
@@
def reveal(objname):
obj = object_lookup[objname]
return not obj.get("immovable")
obj = object_lookup[objname]
return not obj.get("immovable")
+
if __name__ == "__main__":
if __name__ == "__main__":
- with open("adventure.yaml", "r") as f:
+ with open("adventure.yaml", "r"
, encoding="ascii", errors="surrogateescape"
) as f:
db = yaml.safe_load(f)
location_lookup = dict(db["locations"])
db = yaml.safe_load(f)
location_lookup = dict(db["locations"])
@@
-119,17
+143,17
@@
if __name__ == "__main__":
subset = allalike
debug = False
for (switch, val) in options:
subset = allalike
debug = False
for (switch, val) in options:
- if switch ==
'-a'
:
+ if switch ==
"-a"
:
subset = lambda loc: True
subset = lambda loc: True
- elif switch ==
'-d'
:
+ elif switch ==
"-d"
:
subset = alldifferent
subset = alldifferent
- elif switch ==
'-f'
:
+ elif switch ==
"-f"
:
subset = forest
subset = forest
- elif switch ==
'-m'
:
+ elif switch ==
"-m"
:
subset = allalike
subset = allalike
- elif switch ==
'-s'
:
+ elif switch ==
"-s"
:
subset = surface
subset = surface
- elif switch ==
'-v'
:
+ elif switch ==
"-v"
:
debug = True
else:
sys.stderr.write(__doc__)
debug = True
else:
sys.stderr.write(__doc__)
@@
-146,8
+170,8
@@
if __name__ == "__main__":
startlocs[location] = [objname]
# Compute reachability, using forwards.
startlocs[location] = [objname]
# Compute reachability, using forwards.
- # Dictionary ke
6
y is (from, to) iff its a valid link,
- # value is correspo
i
nding motion verbs.
+ # Dictionary key is (from, to) iff its a valid link,
+ # value is corresponding motion verbs.
links = {}
nodes = []
for (loc, attrs) in db["locations"]:
links = {}
nodes = []
for (loc, attrs) in db["locations"]:
@@
-168,7
+192,7
@@
if __name__ == "__main__":
neighbors = set()
for loc in nodes:
for (f, t) in links:
neighbors = set()
for loc in nodes:
for (f, t) in links:
- if f ==
'LOC_NOWHERE' or t == 'LOC_NOWHERE'
:
+ if f ==
"LOC_NOWHERE" or t == "LOC_NOWHERE"
:
continue
if (f == loc and subset(t)) or (t == loc and subset(f)):
if loc not in neighbors:
continue
if (f == loc and subset(t)) or (t == loc and subset(f)):
if loc not in neighbors:
@@
-187,7
+211,7
@@
if __name__ == "__main__":
# Draw arcs
for (f, t) in links:
arc = "%s -> %s" % (f[4:], t[4:])
# Draw arcs
for (f, t) in links:
arc = "%s -> %s" % (f[4:], t[4:])
- label
=
",".join(links[(f, t)]).lower()
+ label
=
",".join(links[(f, t)]).lower()
if len(label) > 0:
arc += ' [label="%s"]' % label
print(" " + arc)
if len(label) > 0:
arc += ' [label="%s"]' % label
print(" " + arc)