summaryrefslogtreecommitdiff
path: root/lampion.rb
diff options
context:
space:
mode:
authorPatrick Simianer <simianer@cl.uni-heidelberg.de>2014-03-10 17:45:30 +0100
committerPatrick Simianer <simianer@cl.uni-heidelberg.de>2014-03-10 17:45:30 +0100
commit00e2f9f227c28242ce97cfc7f86a953b84062d3f (patch)
tree271ab699e780d8e2f2140647a72eef2e0203ee3b /lampion.rb
parent51f2a52da9804e503d828781d3e1af538623f987 (diff)
enable to ignore zombies
Diffstat (limited to 'lampion.rb')
-rwxr-xr-xlampion.rb8
1 files changed, 3 insertions, 5 deletions
diff --git a/lampion.rb b/lampion.rb
index 2758664..00b5508 100755
--- a/lampion.rb
+++ b/lampion.rb
@@ -6,9 +6,6 @@ require 'tempfile'
require 'memcached'
require_relative './hopefear'
-# memcached has to be running
-$cache = Memcached.new('localhost:11211')
-
def exec natural_language_string, reference_output, no_output=false
mrl = output = feedback = nil
@@ -20,9 +17,10 @@ def exec natural_language_string, reference_output, no_output=false
output = $cache.get key_prefix+'__OUTPUT'
feedback = $cache.get key_prefix+'__FEEDBACK'
rescue Memcached::NotFound
+ mrl_cmd = "#{SMT_SEMPARSE} \"#{natural_language_string}\""
# beware: EVAL_PL sometimes hangs and can't be killed!
- mrl = spawn_with_timeout("#{SMT_SEMPARSE} \"#{natural_language_string}\" ", 60).strip
- output = spawn_with_timeout("echo \"execute_funql_query(#{mrl}, X).\" | swipl -s #{EVAL_PL} 2>&1 | grep \"X =\"", 60).strip.split('X = ')[1]
+ mrl = spawn_with_timeout(mrl_cmd, TIMEOUT, ACCEPT_ZOMBIES).strip
+ output = spawn_with_timeout("echo \"execute_funql_query(#{mrl}, X).\" | swipl -s #{EVAL_PL} 2>&1 | grep \"X =\"", TIMEOUT).strip.split('X = ')[1]
feedback = output==reference_output
begin
$cache.set key_prefix+'__MRL', mrl