Beispiel #1
0
 def test_dotted(self):
     self.assertEqual(
         visp.read("(1 . hello)").cdr.name,
         'hello')
     self.assertEqual(
         visp.read("(1 . hello)").car,
         1)
Beispiel #2
0
 def test_list_of_pairs(self):
     self.assertEqual(
         visp.read("((1 . 2) (3 . 4) (5 . 6))"),
         visp.cons(
             visp.cons(1, 2),
             visp.cons(visp.cons(3, 4), visp.cons(visp.cons(5, 6),
                                                  visp.nil))))
Beispiel #3
0
 def test_simple_macro(self):
     self.assertEqual(
         visp.evaluate_many(visp.read_many(
             """(defmacro foo (x)
                  (list '+ '1 '2 x))
                (foo 3)"""), self.base_env),
         visp.read("6"))
Beispiel #4
0
    def test_viral_inexactness(self):
        test_cases = {
            "(+ #e100 #e100)": Exact,
            "(+ #e100 #i100)": Inexact,
            "(+ #i100 #e100)": Inexact,
            "(+ #i100 #i100)": Inexact,
        }

        for input_string, expected_type in test_cases.items():
            self.assertTrue(isinstance(
                visp.evaluate(visp.read(input_string), self.base_env),
                expected_type))
Beispiel #5
0
 def test_debug_macroexpand(self):
     self.assertEqual(
         visp.evaluate_many(visp.read_many(
             """(defmacro debug (a)
                  (list 'let (list (list 'x a))
                    (list 'print 'x)
                    'x))
                (macroexpand (debug "hello"))"""), self.base_env),
         visp.read(
             """(let ((x "hello"))
                  (print x)
                  x)"""))
Beispiel #6
0
    def test_viral_inexactness(self):
        test_cases = {
            "(+ #e100 #e100)": Exact,
            "(+ #e100 #i100)": Inexact,
            "(+ #i100 #e100)": Inexact,
            "(+ #i100 #i100)": Inexact,
        }

        for input_string, expected_type in test_cases.items():
            self.assertTrue(
                isinstance(
                    visp.evaluate(visp.read(input_string), self.base_env),
                    expected_type))
Beispiel #7
0
 def test_quote(self):
     self.assertEqual(
         visp.evaluate(visp.read(
                 "'(1 2 3)"),
             visp.Env()).car,
         1)
Beispiel #8
0
 def test_inexact(self):
     self.assertEqual(
         visp.evaluate(visp.read("#i10"), visp.Env()),
         10.0)
Beispiel #9
0
 def assertEvalEqual(self, actual, expected):
     self.assertEqual(
         visp.evaluate(visp.read(actual), self.base_env),
         visp.evaluate(visp.read(expected), self.base_env))
Beispiel #10
0
 def test_inexact_add(self):
     self.assertEqual(
         visp.evaluate(visp.read(
             """(+ #i100 #i100)"""
         ), visp.Env()),
         200.0)
Beispiel #11
0
 def test_unmet_token_requirement(self):
     with self.assertRaises(StopIteration):
         visp.read("(1 2")
Beispiel #12
0
 def test_unexpected_token(self):
     with self.assertRaises(RuntimeError):
         visp.read(")")
Beispiel #13
0
 def test_integer(self):
     self.assertEqual(visp.read("1"), 1)
Beispiel #14
0
 def test_inexact(self):
     self.assertEqual(visp.read("#i100"), visp.read('(inexact-number 100)'))
Beispiel #15
0
 def test_unexpected_token(self):
     with self.assertRaises(RuntimeError):
         visp.read(")")
Beispiel #16
0
 def test_quote(self):
     self.assertEqual(visp.read("'(1 2 3)"), visp.read("(quote (1 2 3))"))
Beispiel #17
0
 def test_integers_dot_nil(self):
     self.assertEqual(visp.read("(1 2 3 . ())"),
                      visp.cons(1, visp.cons(2, visp.cons(3, visp.nil))))
Beispiel #18
0
 def test_nil(self):
     self.assertEqual(visp.read("()"), visp.nil)
Beispiel #19
0
 def test_nested(self):
     self.assertEqual(visp.read("((1 . 2) . (3 . 4))"),
                      visp.cons(visp.cons(1, 2), visp.cons(3, 4)))
Beispiel #20
0
 def test_unexpected_readermacro(self):
     with self.assertRaises(RuntimeError):
         visp.read("#oblong")
Beispiel #21
0
 def test_symbol(self):
     self.assertEqual(visp.evaluate(visp.read("a"), visp.Env({'a': 2})), 2)
Beispiel #22
0
 def test_unmet_token_requirement(self):
     with self.assertRaises(StopIteration):
         visp.read("(1 2")
Beispiel #23
0
 def assertEvalEqual(self, actual, expected):
     self.assertEqual(visp.evaluate(visp.read(actual), self.base_env),
                      visp.evaluate(visp.read(expected), self.base_env))
Beispiel #24
0
 def test_symbol(self):
     self.assertEqual(visp.read("hello!").name, 'hello!')
Beispiel #25
0
 def test_unexpected_readermacro(self):
     with self.assertRaises(RuntimeError):
         visp.read("#oblong")
Beispiel #26
0
 def test_nil(self):
     self.assertEqual(
         visp.read("()"),
         visp.nil)
Beispiel #27
0
 def test_symbol(self):
     self.assertEqual(
         visp.read("hello!").name,
         'hello!')
Beispiel #28
0
 def setUp(self):
     self.base_env = visp.Env()
     self.base_env.set(
         'print', visp.evaluate(visp.read("(lambda x x)"), self.base_env))
     visp.load_prelude(self.base_env)
Beispiel #29
0
 def test_sub_mixed(self):
     self.assertEqual(
         visp.evaluate(visp.read(
             "(- #i100 #e20 #e40 #e1)"
         ), visp.Env()),
         39.0)
Beispiel #30
0
 def test_exact(self):
     self.assertEqual(
         visp.evaluate(visp.read("1"), visp.Env()),
         1)
Beispiel #31
0
 def setUp(self):
     self.base_env = visp.Env()
     self.base_env.set('print',
         visp.evaluate(visp.read(
             "(lambda x x)"), self.base_env))
     visp.load_prelude(self.base_env)
Beispiel #32
0
 def default(self, line, to_string=str):
     try:
         print(to_string(visp.evaluate(visp.read(line), self.env)))
     except Exception as exc:
         print(traceback.format_exc())
Beispiel #33
0
 def test_symbol(self):
     self.assertEqual(
         visp.evaluate(visp.read("a"), visp.Env({ 'a': 2 })),
         2)
Beispiel #34
0
 def test_sub_mixed(self):
     self.assertEqual(
         visp.evaluate(visp.read("(- #i100 #e20 #e40 #e1)"), visp.Env()),
         39.0)
Beispiel #35
0
 def test_nested(self):
     self.assertEqual(
         visp.read("((1 . 2) . (3 . 4))"),
         visp.cons(visp.cons(1, 2), visp.cons(3, 4)))
Beispiel #36
0
 def test_dotted(self):
     self.assertEqual(visp.read("(1 . hello)").cdr.name, 'hello')
     self.assertEqual(visp.read("(1 . hello)").car, 1)
Beispiel #37
0
 def default(self, line, to_string=str):
     try:
         print(to_string(visp.evaluate(visp.read(line), self.env)))
     except Exception as exc:
         print(traceback.format_exc())
Beispiel #38
0
 def test_list_of_pairs(self):
     self.assertEqual(
         visp.read("((1 . 2) (3 . 4) (5 . 6))"),
         visp.cons(visp.cons(1, 2), 
             visp.cons(visp.cons(3, 4),
                 visp.cons(visp.cons(5, 6), visp.nil))))
Beispiel #39
0
 def test_inexact_add(self):
     self.assertEqual(
         visp.evaluate(visp.read("""(+ #i100 #i100)"""), visp.Env()), 200.0)
Beispiel #40
0
 def test_integer(self):
     self.assertEqual(
         visp.read("1"),
         1)
Beispiel #41
0
 def test_inexact(self):
     self.assertEqual(visp.evaluate(visp.read("#i10"), visp.Env()), 10.0)
Beispiel #42
0
 def test_integers_dot_nil(self):
     self.assertEqual(
         visp.read("(1 2 3 . ())"),
         visp.cons(1, visp.cons(2, visp.cons(3, visp.nil))))
Beispiel #43
0
 def test_quote(self):
     self.assertEqual(
         visp.evaluate(visp.read("'(1 2 3)"), visp.Env()).car, 1)
Beispiel #44
0
 def test_quote(self):
     self.assertEqual(
         visp.read("'(1 2 3)"),
         visp.read("(quote (1 2 3))"))
Beispiel #45
0
 def test_exact(self):
     self.assertEqual(visp.evaluate(visp.read("1"), visp.Env()), 1)
Beispiel #46
0
 def test_inexact(self):
     self.assertEqual(
         visp.read("#i100"),
         visp.read('(inexact-number 100)'))