projects
/
open-adventure.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Move pylint suppressions inline.
[open-adventure.git]
/
make_graph.py
diff --git
a/make_graph.py
b/make_graph.py
index cd085f4f65f2637eba1ae7cc9b470e97a8a82615..b9124d6ab9fc0c9e67cb81df7908dbe61aeb680a 100755
(executable)
--- a/
make_graph.py
+++ b/
make_graph.py
@@
-6,31
+6,32
@@
Make a DOT graph of Colossal Cave.
-a = emit graph of entire dungeon
-d = emit graoh of mazw all different
-a = emit graph of entire dungeon
-d = emit graoh of mazw all different
+-f = emit graph of forest locations
-m = emit graph of maze all alike
-m = emit graph of maze all alike
--s = emit graph of surface locations
--v = include internal sy
,no;
s in room labels
+-s = emit graph of
non-forest
surface locations
+-v = include internal sy
mbol
s in room labels
"""
# Copyright (c) 2017 by Eric S. Raymond
# SPDX-License-Identifier: BSD-2-clause
"""
# Copyright (c) 2017 by Eric S. Raymond
# SPDX-License-Identifier: BSD-2-clause
+# pylint: disable=consider-using-f-string,line-too-long,invalid-name,missing-function-docstring,multiple-imports,redefined-outer-name
+
import sys, getopt, yaml
def allalike(loc):
"Select out loci related to the Maze All Alike"
import sys, getopt, yaml
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"
def surface(loc):
"Select out surface locations"
- attrs = location_lookup[loc]
- if ("ABOVE" in attrs["conditions"]) and attrs["conditions"]["ABOVE"]:
- return True
- if ("FOREST" in attrs["conditions"]) and attrs["conditions"]["FOREST"]:
- return True
- return False
+ return location_lookup[loc]["conditions"].get("ABOVE")
+
+def forest(loc):
+ return location_lookup[loc]["conditions"].get("FOREST")
def abbreviate(d):
m = {"NORTH":"N", "EAST":"E", "SOUTH":"S", "WEST":"W", "UPWAR":"U", "DOWN":"D"}
def abbreviate(d):
m = {"NORTH":"N", "EAST":"E", "SOUTH":"S", "WEST":"W", "UPWAR":"U", "DOWN":"D"}
@@
-105,14
+106,14
@@
def reveal(objname):
return not obj.get("immovable")
if __name__ == "__main__":
return not obj.get("immovable")
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"])
object_lookup = dict(db["objects"])
try:
db = yaml.safe_load(f)
location_lookup = dict(db["locations"])
object_lookup = dict(db["objects"])
try:
- (options, arguments) = getopt.getopt(sys.argv[1:], "admsv")
+ (options, arguments) = getopt.getopt(sys.argv[1:], "ad
f
msv")
except getopt.GetoptError as e:
print(e)
sys.exit(1)
except getopt.GetoptError as e:
print(e)
sys.exit(1)
@@
-124,6
+125,8
@@
if __name__ == "__main__":
subset = lambda loc: True
elif switch == '-d':
subset = alldifferent
subset = lambda loc: True
elif switch == '-d':
subset = alldifferent
+ elif switch == '-f':
+ subset = forest
elif switch == '-m':
subset = allalike
elif switch == '-s':
elif switch == '-m':
subset = allalike
elif switch == '-s':