Syntax highlight blocks as clj
* hy is close enough to clojure , we can (ab)use that for syntax highlighting code blocks * fix "sphynx" spelling in requirements file
This commit is contained in:
parent
6deb8e303c
commit
e7cae36ff0
@ -22,7 +22,9 @@ Basic intro to lisp for pythonistas
|
|||||||
|
|
||||||
Okay, maybe you've never used lisp before, but you've used python!
|
Okay, maybe you've never used lisp before, but you've used python!
|
||||||
|
|
||||||
A "hello world" in hy is actually super simple. Let's try it::
|
A "hello world" in hy is actually super simple. Let's try it:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(print "hello world")
|
(print "hello world")
|
||||||
|
|
||||||
@ -31,18 +33,24 @@ version of::
|
|||||||
|
|
||||||
print "hello world"
|
print "hello world"
|
||||||
|
|
||||||
To add up some super simple math, we could do::
|
To add up some super simple math, we could do:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(+ 1 3)
|
(+ 1 3)
|
||||||
|
|
||||||
Which would return 4 and would be the equivalent of::
|
Which would return 4 and would be the equivalent of:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
1 + 3
|
1 + 3
|
||||||
|
|
||||||
What you'll notice is that the first item in the list is the function
|
What you'll notice is that the first item in the list is the function
|
||||||
being called and the rest of the arguments are the arguments being
|
being called and the rest of the arguments are the arguments being
|
||||||
passed in. In fact, in hy (as with most lisps) we can pass in
|
passed in. In fact, in hy (as with most lisps) we can pass in
|
||||||
multiple arguments to the plus operator::
|
multiple arguments to the plus operator:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(+ 1 3 55)
|
(+ 1 3 55)
|
||||||
|
|
||||||
@ -54,7 +62,9 @@ is a great way to start learning lisp. The main thing that's obvious
|
|||||||
about lisp is that there's a lot of parentheses. This might seem
|
about lisp is that there's a lot of parentheses. This might seem
|
||||||
confusing at first, but it isn't so hard. Let's look at some simple
|
confusing at first, but it isn't so hard. Let's look at some simple
|
||||||
math that's wrapped in a bunch of parentheses that we could enter into
|
math that's wrapped in a bunch of parentheses that we could enter into
|
||||||
the hy interpreter::
|
the hy interpreter:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(def result (- (/ (+ 1 3 88) 2) 8))
|
(def result (- (/ (+ 1 3 88) 2) 8))
|
||||||
|
|
||||||
@ -76,7 +86,9 @@ exercise first in python::
|
|||||||
# simplified to...
|
# simplified to...
|
||||||
result = 38
|
result = 38
|
||||||
|
|
||||||
Now let's try the same thing in hy::
|
Now let's try the same thing in hy:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(def result (- (/ (+ 1 3 88) 2) 8))
|
(def result (- (/ (+ 1 3 88) 2) 8))
|
||||||
; simplified to...
|
; simplified to...
|
||||||
@ -115,7 +127,9 @@ If we ran this program, it might go like::
|
|||||||
What is your age? 38
|
What is your age? 38
|
||||||
Hello Gary! I see you are 38 years old.
|
Hello Gary! I see you are 38 years old.
|
||||||
|
|
||||||
Now let's look at the equivalent hy program::
|
Now let's look at the equivalent hy program:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(defn simple-conversation []
|
(defn simple-conversation []
|
||||||
(print "Hello! I'd like to get to know you. Tell me about yourself!")
|
(print "Hello! I'd like to get to know you. Tell me about yourself!")
|
||||||
@ -171,7 +185,9 @@ hy. Let's experiment with this in the hy interpreter::
|
|||||||
{'dog': 'bark', 'cat': 'meow'}
|
{'dog': 'bark', 'cat': 'meow'}
|
||||||
|
|
||||||
(You may notice that at present, the common lisp method of quoting
|
(You may notice that at present, the common lisp method of quoting
|
||||||
things like so::
|
things like so:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
'(1 2 3)
|
'(1 2 3)
|
||||||
|
|
||||||
@ -187,12 +203,16 @@ What's this? Yes indeed, this is precisely the same as::
|
|||||||
" fooooo ".strip()
|
" fooooo ".strip()
|
||||||
|
|
||||||
That's right... lisp with dot notation! If we have this string
|
That's right... lisp with dot notation! If we have this string
|
||||||
assigned as a variable, we can also do the following::
|
assigned as a variable, we can also do the following:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(def this-string " fooooo ")
|
(def this-string " fooooo ")
|
||||||
(this-string.strip)
|
(this-string.strip)
|
||||||
|
|
||||||
What about conditionals?::
|
What about conditionals?:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(if (try-some-thing)
|
(if (try-some-thing)
|
||||||
(print "this is if true")
|
(print "this is if true")
|
||||||
@ -214,7 +234,9 @@ called "cond". In python, you might do something like::
|
|||||||
else:
|
else:
|
||||||
print "That variable is jussssst right!"
|
print "That variable is jussssst right!"
|
||||||
|
|
||||||
In hy, you would do::
|
In hy, you would do:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(cond
|
(cond
|
||||||
((> somevar 50)
|
((> somevar 50)
|
||||||
@ -231,7 +253,9 @@ notice that the "else" is implemented at the end simply by checking
|
|||||||
for "true"... that's because true will always be true, so if we get
|
for "true"... that's because true will always be true, so if we get
|
||||||
this far, we'll always run that one!
|
this far, we'll always run that one!
|
||||||
|
|
||||||
You might notice above that if you have code like::
|
You might notice above that if you have code like:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(if some-condition
|
(if some-condition
|
||||||
(body-if-true)
|
(body-if-true)
|
||||||
@ -240,7 +264,9 @@ You might notice above that if you have code like::
|
|||||||
But wait! What if you want to execute more than one statment in the
|
But wait! What if you want to execute more than one statment in the
|
||||||
body of one of these?
|
body of one of these?
|
||||||
|
|
||||||
You can do the following::
|
You can do the following:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(if (try-some-thing)
|
(if (try-some-thing)
|
||||||
(do
|
(do
|
||||||
@ -273,7 +299,9 @@ TODO: explain the extra power of hy's for, the list comprehensions
|
|||||||
aspect ;)
|
aspect ;)
|
||||||
|
|
||||||
You can also import and make use of various python libraries. For
|
You can also import and make use of various python libraries. For
|
||||||
example::
|
example:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
(import os)
|
(import os)
|
||||||
|
|
||||||
@ -281,6 +309,13 @@ example::
|
|||||||
(os.mkdir "/tmp/somedir/anotherdir")
|
(os.mkdir "/tmp/somedir/anotherdir")
|
||||||
(print "Hey, that path isn't there!"))
|
(print "Hey, that path isn't there!"))
|
||||||
|
|
||||||
|
Comments start with semicolons:
|
||||||
|
|
||||||
|
.. code-block:: clj
|
||||||
|
|
||||||
|
(print "this will run")
|
||||||
|
; (print "but this will not")
|
||||||
|
(+ 1 2 3) ; we'll execute the addition, but not this comment!
|
||||||
|
|
||||||
|
|
||||||
TODO
|
TODO
|
||||||
|
@ -2,5 +2,5 @@ tox
|
|||||||
nose
|
nose
|
||||||
astor
|
astor
|
||||||
flake8
|
flake8
|
||||||
sphynx
|
Sphinx
|
||||||
coverage
|
coverage
|
||||||
|
Loading…
x
Reference in New Issue
Block a user