From 79a1ea6667f77cce08282089da5b3989039ef3e0 Mon Sep 17 00:00:00 2001 From: Paul Tagliamonte Date: Thu, 24 Jul 2014 20:51:43 -0400 Subject: [PATCH 1/5] *cough* From 45e0ff16ca9b3e1c91463dd8ece9fadc288d7d57 Mon Sep 17 00:00:00 2001 From: Abhishek L Date: Tue, 5 Aug 2014 00:10:14 +0530 Subject: [PATCH 2/5] Add a simple .mailmap file --- .mailmap | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 .mailmap diff --git a/.mailmap b/.mailmap new file mode 100644 index 0000000..678f585 --- /dev/null +++ b/.mailmap @@ -0,0 +1,12 @@ +Paul R. Tagliamonte Paul Tagliamonte +Paul R. Tagliamonte Paul Tagliamonte +Paul R. Tagliamonte Paul Tagliamonte +Paul R. Tagliamonte Paul Tagliamonte +Morten Linderud Foxboron +Morten Linderud +James King agentultra +James King J Kenneth King +Abhishek L +Bob Tolbert Bob Tolbert +Guillermo Vaya Guillermo Vaya +Gergely Nagy Gergely Nagy \ No newline at end of file From f7675c829efe1a5f376d9eff49c112c0762264ac Mon Sep 17 00:00:00 2001 From: Foxboron Date: Thu, 24 Jul 2014 20:44:55 +0200 Subject: [PATCH 3/5] Added read and tests --- docs/language/core.rst | 26 ++++++++++++++++++++++++++ hy/core/language.hy | 21 ++++++++++++++++++++- tests/native_tests/language.hy | 27 +++++++++++++++++++++++++++ 3 files changed, 73 insertions(+), 1 deletion(-) diff --git a/docs/language/core.rst b/docs/language/core.rst index 42070cf..a51b488 100644 --- a/docs/language/core.rst +++ b/docs/language/core.rst @@ -862,6 +862,32 @@ Return an iterator of `x`, `fn(x)`, `fn(fn(x))`. [5, 25, 625, 390625, 152587890625] +.. _read-fn: + +read +---- + +Usage: ``(read [stdin eof])`` + +Reads the given form and parses it to hy. Takes optional argument +for a different stdin object or eof byte. Throws `EOFError` when +stdin is empty. + +.. code-block:: hy + => (read) + (+ 2 2) + ('+' 2 2) + => (eval (read)) + (+ 2 2) + 4 + => (import io) + => (def buffer (io.StringIO "(+ 2 2)\n(- 2 1)")) + => (eval (apply read [] {"stdin" buffer})) + 4 + => (eval (apply read [] {"stdin" buffer})) + 1 + + .. _remove-fn: remove diff --git a/hy/core/language.hy b/hy/core/language.hy index d7ee3ec..d6a3837 100644 --- a/hy/core/language.hy +++ b/hy/core/language.hy @@ -26,8 +26,10 @@ (import itertools) (import functools) (import collections) +(import sys) (import [hy._compat [long-type]]) ; long for python2, int for python3 (import [hy.models.cons [HyCons]]) +(import [hy.lex [LexException PrematureEndOfInput tokenize]]) (defn _numeric-check [x] @@ -326,12 +328,29 @@ (_numeric_check n) (= n 0)) +(defn read [&optional [stdin sys.stdin] + [eof ""]] + "Read from input and returns a tokenized string. + Can take a given input buffer to read from" + (def buff "") + (while true + (def inn (str (.read stdin 1))) + (if (= inn eof) + (throw (EOFError "Reached end of file" ))) + (setv buff (+ buff inn)) + (try + (def parsed (first (tokenize buff))) + (except [e [LexException PrematureEndOfInput IndexError]]) + (else (if parsed (break))))) + parsed) + + (def *exports* '[butlast calling-module-name coll? cons cons? cycle dec distinct disassemble drop drop-while empty? even? every? first filter filterfalse flatten float? gensym identity inc input instance? integer integer? integer-char? iterable? iterate iterator? keyword? list* macroexpand macroexpand-1 map neg? nil? none? nth - numeric? odd? pos? range remove repeat repeatedly + numeric? odd? pos? range read remove repeat repeatedly rest reduce second some string string? take take-nth take-while zero? zip zip_longest zipwith]) diff --git a/tests/native_tests/language.hy b/tests/native_tests/language.hy index b7888e2..9955394 100644 --- a/tests/native_tests/language.hy +++ b/tests/native_tests/language.hy @@ -1028,3 +1028,30 @@ (foo [&rest spam] 1) (catch [NameError] True) (else (raise AssertionError)))) + +(defn test-read [] + "NATIVE: test that read takes something for stdin and reads" + (if-python2 + (import [StringIO [StringIO]]) + (import [io [StringIO]])) + (import [hy.models.expression [HyExpression]]) + + (def stdin-buffer (StringIO "(+ 2 2)\n(- 2 2)")) + (assert (= (eval (apply read [] {"stdin" stdin-buffer})) 4)) + (assert (isinstance (apply read [] {"stdin" stdin-buffer}) HyExpression)) + + "Multiline test" + (def stdin-buffer (StringIO "(\n+\n41\n1\n)\n(-\n2\n1\n)")) + (assert (= (eval (apply read [] {"stdin" stdin-buffer})) 42)) + (assert (= (eval (apply read [] {"stdin" stdin-buffer})) 1)) + + "EOF test" + (def stdin-buffer (StringIO "(+ 2 2)")) + (apply read [] {"stdin" stdin-buffer}) + (try + (apply read [] {"stdin" stdin-buffer}) + (catch [e Exception] + (print e) + (assert (isinstance e EOFError))))) + + From d5668403aef3868bb4b328daa95ab965f3841efd Mon Sep 17 00:00:00 2001 From: Abhishek L Date: Tue, 12 Aug 2014 23:44:35 +0530 Subject: [PATCH 4/5] Typo fix s/reprsntation/representation --- hy/models/complex.py | 2 +- hy/models/float.py | 2 +- hy/models/integer.py | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/hy/models/complex.py b/hy/models/complex.py index 9647997..26ac863 100644 --- a/hy/models/complex.py +++ b/hy/models/complex.py @@ -23,7 +23,7 @@ from hy.models import HyObject class HyComplex(HyObject, complex): """ - Internal represntation of a Hy Complex. May raise a ValueError as if + Internal representation of a Hy Complex. May raise a ValueError as if complex(foo) was called, given HyComplex(foo). """ diff --git a/hy/models/float.py b/hy/models/float.py index 184c3a3..ffcf455 100644 --- a/hy/models/float.py +++ b/hy/models/float.py @@ -23,7 +23,7 @@ from hy.models import HyObject class HyFloat(HyObject, float): """ - Internal represntation of a Hy Float. May raise a ValueError as if + Internal representation of a Hy Float. May raise a ValueError as if float(foo) was called, given HyFloat(foo). """ diff --git a/hy/models/integer.py b/hy/models/integer.py index 0eacef7..614520f 100644 --- a/hy/models/integer.py +++ b/hy/models/integer.py @@ -24,7 +24,7 @@ from hy._compat import long_type class HyInteger(HyObject, long_type): """ - Internal represntation of a Hy Integer. May raise a ValueError as if + Internal representation of a Hy Integer. May raise a ValueError as if int(foo) was called, given HyInteger(foo). On python 2.x long will be used instead """ From c8adf9b726f166332a1f9462071f81724a24614f Mon Sep 17 00:00:00 2001 From: Foxboron Date: Thu, 14 Aug 2014 18:18:05 +0200 Subject: [PATCH 5/5] Renamed stdin -> from-file and removed apply from tests + docs --- docs/language/core.rst | 13 +++++++------ hy/core/language.hy | 4 ++-- tests/native_tests/language.hy | 13 ++++++------- 3 files changed, 15 insertions(+), 15 deletions(-) diff --git a/docs/language/core.rst b/docs/language/core.rst index a51b488..8b2fec1 100644 --- a/docs/language/core.rst +++ b/docs/language/core.rst @@ -867,11 +867,12 @@ Return an iterator of `x`, `fn(x)`, `fn(fn(x))`. read ---- -Usage: ``(read [stdin eof])`` +Usage: ``(read [from-file eof])`` -Reads the given form and parses it to hy. Takes optional argument -for a different stdin object or eof byte. Throws `EOFError` when -stdin is empty. +Reads the next hy expression from `from-file` (defaults to `sys.stdin`), and +can take a single byte as EOF (defaults to an empty string). +Raises an `EOFError` if `from-file` ends before a complete expression can be +parsed. .. code-block:: hy => (read) @@ -882,9 +883,9 @@ stdin is empty. 4 => (import io) => (def buffer (io.StringIO "(+ 2 2)\n(- 2 1)")) - => (eval (apply read [] {"stdin" buffer})) + => (eval (apply read [] {"from_file" buffer})) 4 - => (eval (apply read [] {"stdin" buffer})) + => (eval (apply read [] {"from_file" buffer})) 1 diff --git a/hy/core/language.hy b/hy/core/language.hy index d6a3837..3b208e6 100644 --- a/hy/core/language.hy +++ b/hy/core/language.hy @@ -328,13 +328,13 @@ (_numeric_check n) (= n 0)) -(defn read [&optional [stdin sys.stdin] +(defn read [&optional [from-file sys.stdin] [eof ""]] "Read from input and returns a tokenized string. Can take a given input buffer to read from" (def buff "") (while true - (def inn (str (.read stdin 1))) + (def inn (str (.read from-file 1))) (if (= inn eof) (throw (EOFError "Reached end of file" ))) (setv buff (+ buff inn)) diff --git a/tests/native_tests/language.hy b/tests/native_tests/language.hy index 9955394..cc104fa 100644 --- a/tests/native_tests/language.hy +++ b/tests/native_tests/language.hy @@ -1037,21 +1037,20 @@ (import [hy.models.expression [HyExpression]]) (def stdin-buffer (StringIO "(+ 2 2)\n(- 2 2)")) - (assert (= (eval (apply read [] {"stdin" stdin-buffer})) 4)) - (assert (isinstance (apply read [] {"stdin" stdin-buffer}) HyExpression)) + (assert (= (eval (read stdin-buffer)) 4)) + (assert (isinstance (read stdin-buffer) HyExpression)) "Multiline test" (def stdin-buffer (StringIO "(\n+\n41\n1\n)\n(-\n2\n1\n)")) - (assert (= (eval (apply read [] {"stdin" stdin-buffer})) 42)) - (assert (= (eval (apply read [] {"stdin" stdin-buffer})) 1)) + (assert (= (eval (read stdin-buffer)) 42)) + (assert (= (eval (read stdin-buffer)) 1)) "EOF test" (def stdin-buffer (StringIO "(+ 2 2)")) - (apply read [] {"stdin" stdin-buffer}) + (read stdin-buffer) (try - (apply read [] {"stdin" stdin-buffer}) + (read stdin-buffer) (catch [e Exception] - (print e) (assert (isinstance e EOFError)))))