From 4d01fc8399630d6ea2184654460c0e193d677c03 Mon Sep 17 00:00:00 2001 From: Jakub Adamski Date: Wed, 1 Jun 2022 12:22:40 +0200 Subject: [PATCH] added question response approve --- system_mockup/generator_jezyka_nautalnego.py | 9 ++++++++- system_mockup/monitor_stanu_dialogowego.py | 5 +++-- system_mockup/system_dialogowy.py | 10 ++++------ system_mockup/taktyka_dialogu.py | 2 +- 4 files changed, 16 insertions(+), 10 deletions(-) diff --git a/system_mockup/generator_jezyka_nautalnego.py b/system_mockup/generator_jezyka_nautalnego.py index 122289c..9a6ea88 100644 --- a/system_mockup/generator_jezyka_nautalnego.py +++ b/system_mockup/generator_jezyka_nautalnego.py @@ -3,17 +3,24 @@ from taktyka_dialogu import Questions welcome = 'Witaj!' unknown = "Nie rozumiem." end = "Żegnaj!" +help = "Obsługuję przekazywanie informacji z systemu GitHub - repozytoria, pull requesty, issue, powiadomienia." -def generator_jezyka_nautalnego(frame, question): +def generator_jezyka_nautalnego(frame, question, state): if question != Questions.NONE: #ask additional questions if question == Questions.TIME: print("Z jakiego czasu?") + + elif state[-2]['questions'] != Questions.NONE and frame['act'] != "": + print("Przyjęto odpowiedź na pytanie.") + else: #dont ask questions if frame['act'] == "hello": print(welcome) elif frame['act'] == "bye": print(end) + elif frame['act'] == "pomoc": + print(help) else: print(unknown) diff --git a/system_mockup/monitor_stanu_dialogowego.py b/system_mockup/monitor_stanu_dialogowego.py index 858e430..6f996ef 100644 --- a/system_mockup/monitor_stanu_dialogowego.py +++ b/system_mockup/monitor_stanu_dialogowego.py @@ -1,13 +1,14 @@ dialogue_state = [] iterator = 1 -def monitor_stanu_dialogowego(frame): +def monitor_stanu_dialogowego(frame, questions): global iterator # Some frames can reset the dialogue state, like saying hello. reset_state_if_needed(frame) singleState = { "iteration": iterator, - "frame": frame + "frame": frame, + "questions": questions } dialogue_state.append(singleState) iterator += 1 diff --git a/system_mockup/system_dialogowy.py b/system_mockup/system_dialogowy.py index 5d648ac..731e6b9 100644 --- a/system_mockup/system_dialogowy.py +++ b/system_mockup/system_dialogowy.py @@ -5,20 +5,18 @@ from generator_jezyka_nautalnego import generator_jezyka_nautalnego def main(): running = True + state = [] while running: text = input('>>>') frame = analizator_jezyka_naturalnego(text) - print("[INFO] - Analizator: {}".format(frame)) - state = monitor_stanu_dialogowego(frame) - print("[INFO] - Liczba elementów stanu: {}".format(len(state))) + questions = taktyka_dialogu(frame) - questions = taktyka_dialogu(state, frame) - print("[INFO] - Taktyka: {}".format(questions)) + state = monitor_stanu_dialogowego(frame, questions) - generator_jezyka_nautalnego(frame, questions) + generator_jezyka_nautalnego(frame, questions, state) if __name__ == '__main__': main() diff --git a/system_mockup/taktyka_dialogu.py b/system_mockup/taktyka_dialogu.py index e4e1217..9149389 100644 --- a/system_mockup/taktyka_dialogu.py +++ b/system_mockup/taktyka_dialogu.py @@ -5,7 +5,7 @@ class Questions(Enum): REPO = "repo" NONE = "none" -def taktyka_dialogu(state, frame): +def taktyka_dialogu(frame): return questions(frame) # TODO inna taktyka