summaryrefslogtreecommitdiff
path: root/agent.prolog
diff options
context:
space:
mode:
authorJed Barber <jjbarber@y7mail.com>2014-03-29 00:13:58 +1100
committerJed Barber <jjbarber@y7mail.com>2014-03-29 00:13:58 +1100
commit6761a99f7e8ed4e73614f304031b136891c5e3b9 (patch)
treeb1747989afc6a15d7ddfbb50feb1a17e00da7eb5 /agent.prolog
parent52cc6731410d9862105b987bd0fa6ae819bab363 (diff)
Cleaned up minor init errors, variable names
Diffstat (limited to 'agent.prolog')
-rw-r--r--agent.prolog114
1 files changed, 64 insertions, 50 deletions
diff --git a/agent.prolog b/agent.prolog
index 3a189bb..ba59a43 100644
--- a/agent.prolog
+++ b/agent.prolog
@@ -19,10 +19,10 @@ init :-
initPos :-
- roomList(R),
- random_member(X,R),
retractall(here(_)),
- not(somethingAt(X)),
+ roomList(Rooms),
+ filter(Rooms, somethingAt, Emptyrooms),
+ random_member(X,Emptyrooms),
asserta(here(X)).
@@ -30,10 +30,10 @@ initPits :- true.
initWumpus :-
- roomList(R),
- random_member(X,R),
retractall(wumpusAt(_)),
- not(somethingAt(X)),
+ roomList(Rooms),
+ filter(Rooms, somethingAt, Emptyrooms),
+ random_member(X,Emptyrooms),
asserta(wumpusAt(X)).
@@ -48,26 +48,26 @@ initBats :- true.
% command functions
look :-
- here(L),
- writeSenses(L),
- writeExits(L).
-
-
-move(D) :-
- here(L),
- connects(L,N,D),
- retract(here(L)),
- asserta(here(N)),
- join(['You move to the ',D,' .\n\n'],M),
- write(M), !.
-
-
-take(T) :-
- here(L),
- itemAt(T,L),
- canTake(T),
- retract(itemAt(T,L)),
- asserta(holding(T)),
+ here(Location),
+ writeSenses(Location),
+ writeExits(Location).
+
+
+move(Direction) :-
+ here(Location),
+ connects(Location, New, Direction),
+ retract(here(Location)),
+ asserta(here(New)),
+ join(['You move to the ',Direction,' .\n\n'],W),
+ write(W), !.
+
+
+take(Item) :-
+ here(Location),
+ itemAt(Item,Location),
+ canTake(Item),
+ retract(itemAt(Item,Location)),
+ asserta(holding(Item)),
write('Taken.\n\n'), !.
@@ -75,43 +75,47 @@ take(T) :-
% letting the player know what's going on
-writeSenses(L) :-
- glitter(L),
- breeze(L),
- bats(L),
- stench(L).
+writeSenses(Location) :-
+ glitter(Location),
+ breeze(Location),
+ bats(Location),
+ stench(Location).
-glitter(_) :- not(current_predicate(goldAt/1)).
-glitter(L) :-
- goldAt(L),
+glitter(Location) :-
+ current_predicate(goldAt/1),
+ goldAt(Location),
write('You see a glitter along the sandy floor of the cave.\n').
+glitter(_) :- true.
-breeze(_) :- not(current_predicate(pitAt/1)).
-breeze(L) :-
- connects(L,X,_),
- pitAt(X),
+breeze(Location) :-
+ current_predicate(pitAt/1),
+ connects(Location, ConnectedRoom, _),
+ pitAt(ConnectedRoom),
write('A cold breeze blows through the room, making you shiver slightly.\n').
+breeze(_) :- true.
-bats(_) :- not(current_predicate(batsAt/1)).
-bats(L) :-
- connects(L,X,_),
- batsAt(X),
+bats(Location) :-
+ current_predicate(batsAt/1),
+ connects(Location, ConnectedRoom, _),
+ batsAt(ConnectedRoom),
write('All available surfaces are covered in guano. How unsanitary.\n').
+bats(_) :- true.
-stench(_) :- not(current_predicate(wumpusAt/1)).
-stench(L) :-
- connects(L,X,_),
- wumpusAt(X),
+stench(Location) :-
+ current_predicate(wumpusAt/1),
+ connects(Location, ConnectedRoom, _),
+ wumpusAt(ConnectedRoom),
write('An overpowering stench fills your nose.\n').
+stench(_) :- true.
-writeExits(L) :-
- findall(X, connects(L,_,X), E),
- intercalate(E, ', ', O),
+writeExits(Location) :-
+ findall(X, connects(Location,_,X), Exits),
+ intercalate(Exits, ', ', O),
join(['There are exits to the ',O,'.\n'],W),
write(W).
@@ -127,5 +131,15 @@ somethingAt(X) :- current_predicate(goldAt/1), goldAt(X).
somethingAt(X) :- current_predicate(batsAt/1), batsAt(X).
-intercalate(I,S,O) :- O is I.
+intercalate([X|Y], Spacer, Result) :-
+ intercalate(Y, Spacer, Tail),
+ atom_concat(X, Spacer, Head),
+ atom_concat(Head, Tail, Result).
+intercalate([X], _, Result) :- Result = X.
+
+
+filter(List, Predicate, Result) :-
+ Test =.. [Predicate,X],
+ findall(X, Test, No),
+ subtract(List, No, Result).