From 211117b78cd617e6117df99de895a0eb81751eb8 Mon Sep 17 00:00:00 2001
From: Christian Heller <c.heller@plomlompom.de>
Date: Thu, 19 Feb 2015 12:30:07 +0100
Subject: [PATCH] Server/py: Replace tokenizer() with shlex.split() (erlehmann
 advice).

---
 plomrogue-server.py | 40 ++--------------------------------------
 1 file changed, 2 insertions(+), 38 deletions(-)

diff --git a/plomrogue-server.py b/plomrogue-server.py
index 0b3ce1f..9bdab82 100755
--- a/plomrogue-server.py
+++ b/plomrogue-server.py
@@ -1,6 +1,7 @@
 import argparse
 import errno
 import os
+import shlex
 import time
 
 
@@ -52,44 +53,7 @@ def detect_atomic_leftover(path):
 def obey(msg):
     """"""
     print("Input: " + msg)
-
-
-def tokenize(string):
-    """Divide string by ' ', \t & " quotes (that also group). Escape with \."""
-    charlist_A = list(string)
-    i = 0
-    for c in charlist_A:
-        if "\\" == c and i < len(charlist_A) - 1:
-            charlist_A[i] = "remove"
-            charlist_A[i + 1] = charlist_A[i + 1] + "_escaped"
-        i = i + 1
-    charlist_B = []
-    for c in charlist_A:
-        if "remove" != c:
-            charlist_B.append(c)
-    in_quotes = 0
-    i = 0
-    for c in charlist_B:
-        if "\"" == c:
-            in_quotes = 0 if in_quotes else 1
-            if i < len(charlist_B) - 1:
-                charlist_B[i] = "separator"
-        elif (not in_quotes) and (" " == c or "\t" == c):
-            charlist_B[i] = "separator"
-        i = i + 1
-    list_of_charlists = [[]]
-    i = 0
-    for c in charlist_B:
-        if "separator" == c:
-            if [] != list_of_charlists[-1]:
-                list_of_charlists.append([])
-                i = i + 1
-        else:
-            list_of_charlists[i].append(c[0])
-    tokens = []
-    for charlist in list_of_charlists:
-        tokens.append("".join(charlist))
-    return tokens
+    print(shlex.split(msg))
 
 
 io_db = {}
-- 
2.30.2