From 57f764ebfef599ef037e4c96be086bf7164a661e Mon Sep 17 00:00:00 2001 From: Will Kahn-Greene Date: Fri, 5 Apr 2013 14:56:59 -0400 Subject: [PATCH 1/5] Cosmetic: Fix header formatting This tweaks the header formatting in reST so that we can use --- for 3rd level headers. --- docs/language/tutorial.rst | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/language/tutorial.rst b/docs/language/tutorial.rst index b0d6ed7..f10002f 100644 --- a/docs/language/tutorial.rst +++ b/docs/language/tutorial.rst @@ -1,3 +1,4 @@ +======== Tutorial ======== @@ -20,7 +21,7 @@ This is pretty cool because it means Hy is several things: Basic intro to lisp for pythonistas ------------------------------------ +=================================== Okay, maybe you've never used lisp before, but you've used python! @@ -173,7 +174,7 @@ incredible power (just be careful to not aim them footward)! Hy is python flavored lisp (or vice versa?) -------------------------------------------- +=========================================== Hy converts to python's own abstract syntax tree, so you'll soon start to find that all the familiar power of python is at your fingertips. @@ -364,7 +365,7 @@ In hy, you could do these like: Protips! --------- +======== Hy also features something known as the "threading macro", a really neat feature of Clojure's. The "threading macro" (written as "->"), is used @@ -404,9 +405,8 @@ Which, of course, expands out to: Much more readable, no! Use the threading macro! - TODO ----- +==== - How do I define classes? - Blow your mind with macros! From 39106c9c6279fad71a502fac265022b55022e8a0 Mon Sep 17 00:00:00 2001 From: Will Kahn-Greene Date: Fri, 5 Apr 2013 16:29:32 -0400 Subject: [PATCH 2/5] Add explicit LICENSE file The LICENSE is at the top of setup.py, but ... having a LICENSE or COPYING file is more conventional. So this adds that. --- LICENSE | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) create mode 100644 LICENSE diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..c98d41b --- /dev/null +++ b/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2012, 2013 Paul Tagliamonte + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the "Software"), +to deal in the Software without restriction, including without limitation +the rights to use, copy, modify, merge, publish, distribute, sublicense, +and/or sell copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +DEALINGS IN THE SOFTWARE. From 6fbba171581f4248128b6a694e4a0d8161789c94 Mon Sep 17 00:00:00 2001 From: Will Kahn-Greene Date: Fri, 5 Apr 2013 16:30:12 -0400 Subject: [PATCH 3/5] Add quickstart and hacking docs --- README.md | 11 ++++++++ docs/hacking.rst | 67 +++++++++++++++++++++++++++++++++++++++++++++ docs/index.rst | 2 ++ docs/quickstart.rst | 31 +++++++++++++++++++++ 4 files changed, 111 insertions(+) create mode 100644 docs/hacking.rst create mode 100644 docs/quickstart.rst diff --git a/README.md b/README.md index 36dffe1..6c398e7 100644 --- a/README.md +++ b/README.md @@ -7,6 +7,7 @@ Lisp and Python should love each other. Let's make it happen. [![Build Status](https://travis-ci.org/paultag/hy.png?branch=master)](https://travis-ci.org/paultag/hy) + Hylarious Hacks --------------- @@ -28,3 +29,13 @@ Well, I wrote Hy to help people realize one thing about Python: It's really goddamn awesome. Oh, and lisps are neat. + + +Project +------- + +* Code: https://github.com/paultag/hy +* Docs: http://hy.rtfd.org/ +* Quickstart: http://hy.rtfd.org/en/latest/quickstart.html +* Bug reports: We have no bugs! Your bugs are your own! (https://github.com/paultag/hy/issues) +* License: MIT (Expat) diff --git a/docs/hacking.rst b/docs/hacking.rst new file mode 100644 index 0000000..9e64076 --- /dev/null +++ b/docs/hacking.rst @@ -0,0 +1,67 @@ +=============== + Hacking on hy +=============== + +Join our hyve! +============== + +Please come hack on hy! + +Please come hang out with us on ``#hy`` on ``irc.freenode.net``! + +Please talk about it on Twitter with the ``#hy`` hashtag! + +Please blog about it! + +Please spraypaint it on your neighbor's fence! + + +Hack! +===== + +Do this: + +1. create a Python virtual environment +2. (optional) go to https://github.com/paultag/hy and fork it +3. get the source code:: + + $ git clone git@github.com:paultag/hy.git + + (or use your fork) +4. install for hacking:: + + $ python setup.py develop + +5. install other develop-y requirements:: + + $ pip install -r requirements-dev.txt + +6. do awesome things; make someone shriek in delight/disgust at what + you have wrought + + +Test! +===== + +Tests are located in ``tests/``. We use `nose +`_. + +To run the tests:: + + $ nosetests + +Write tests---tests are good! + + +Document! +========= + +Documentation is located in ``docs/``. We use `Sphinx +`_. + +To build the docs in html:: + + $ cd docs + $ make html + +Write docs---docs are good! Even this doc! diff --git a/docs/index.rst b/docs/index.rst index 9998081..1618c2f 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -36,5 +36,7 @@ Contents: .. toctree:: :maxdepth: 3 + quickstart + hacking language/tutorial .. library/index diff --git a/docs/quickstart.rst b/docs/quickstart.rst new file mode 100644 index 0000000..561418d --- /dev/null +++ b/docs/quickstart.rst @@ -0,0 +1,31 @@ +========== +Quickstart +========== + +I WANT TO BE DOING HY STUFF RIGHT NOW! + +1. create a Python virtual environment +2. activate your Python virtual environment +3. ``pip install hy`` +4. start a REPL with ``hy`` +5. type stuff in the REPL:: + + => (print "Hy!") + Hy! + => (defn salutationsnm [] (print (+ "Hy " name "!"))) + => (salutationsnm "YourName") + Hy YourName! + + etc + +6. hit CTRL-D when you're done + +OMG! That's amazing! I want to write a hy program. + +7. open up an elite programming editor +8. type:: + + (print "hy is the BEST!") + +9. save as ``test_program_of_awesome.hy`` +10. run ``hy test_program_of_awesome.hy`` From b37f5f21d59714ae2418daa5c5db20b8375618a7 Mon Sep 17 00:00:00 2001 From: Will Kahn-Greene Date: Fri, 5 Apr 2013 16:34:25 -0400 Subject: [PATCH 4/5] Fix to be more friendly --- docs/hacking.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/hacking.rst b/docs/hacking.rst index 9e64076..5db4a07 100644 --- a/docs/hacking.rst +++ b/docs/hacking.rst @@ -13,7 +13,7 @@ Please talk about it on Twitter with the ``#hy`` hashtag! Please blog about it! -Please spraypaint it on your neighbor's fence! +Please don't spraypaint it on your neighbor's fence (without asking nicely)! Hack! From 4ddae38a8b4a201df8b3c017ea295683a6760669 Mon Sep 17 00:00:00 2001 From: Will Kahn-Greene Date: Fri, 5 Apr 2013 16:39:46 -0400 Subject: [PATCH 5/5] Linkificate the Python virtual environment text --- docs/hacking.rst | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/docs/hacking.rst b/docs/hacking.rst index 5db4a07..10ebc50 100644 --- a/docs/hacking.rst +++ b/docs/hacking.rst @@ -21,7 +21,8 @@ Hack! Do this: -1. create a Python virtual environment +1. create a `Python virtual environment + `_ 2. (optional) go to https://github.com/paultag/hy and fork it 3. get the source code::