babel hashing now handles more complex types in params

* lisp/ob.el (org-babel-sha1-hash): now handles more complex types in
  params
* testing/examples/babel.org: whitespace
* testing/lisp/test-ob.el (test-org-babel/sha1-hash): new test for
  babel hashing
This commit is contained in:
Eric Schulte 2010-10-16 13:55:54 -06:00 committed by Dan Davison
parent cea9fd7421
commit e905dbe0f6
3 changed files with 23 additions and 8 deletions

View File

@ -609,17 +609,24 @@ the current subtree."
(defun org-babel-sha1-hash (&optional info) (defun org-babel-sha1-hash (&optional info)
"Generate an sha1 hash based on the value of info." "Generate an sha1 hash based on the value of info."
(interactive) (interactive)
(let* ((info (or info (org-babel-get-src-block-info))) (let* ((print-level nil)
(info (or info (org-babel-get-src-block-info)))
(hash (sha1 (hash (sha1
(format "%s-%s" (format "%s-%s"
(mapconcat (mapconcat
(lambda (arg) #'identity
(if (stringp (cdr arg)) (delq nil
(mapconcat (mapcar
#'identity (lambda (arg)
(sort (split-string (cdr arg)) #'string<) " ") (let ((v (cdr arg)))
(cdr arg))) (when (and v (not (and (sequencep v)
(nth 2 info) ":") (> (length v) 0))))
(if (stringp v)
(mapconcat #'identity
(sort (split-string v)
#'string<) " ")
(format "%S" v)))))
(nth 2 info))) ":")
(nth 1 info))))) (nth 1 info)))))
(when (interactive-p) (message hash)) (when (interactive-p) (message hash))
hash)) hash))

View File

@ -129,6 +129,7 @@
(pascals-triangle n) (pascals-triangle n)
#+end_src #+end_src
* calling code blocks from inside table * calling code blocks from inside table
:PROPERTIES: :PROPERTIES:
:ID: 6d2ff4ce-4489-4e2a-9c65-e3f71f77d975 :ID: 6d2ff4ce-4489-4e2a-9c65-e3f71f77d975
@ -138,6 +139,7 @@
#+begin_src emacs-lisp :var n=9 #+begin_src emacs-lisp :var n=9
(sqrt n) (sqrt n)
#+end_src #+end_src
* executing an lob call line * executing an lob call line
:PROPERTIES: :PROPERTIES:
:results: silent :results: silent

View File

@ -64,6 +64,12 @@
(should (equal 'a (cadr (assoc 1 results)))) (should (equal 'a (cadr (assoc 1 results))))
(should (equal 'd (cadr (assoc 4 results))))))) (should (equal 'd (cadr (assoc 4 results)))))))
(ert-deftest test-org-babel/sha1-hash ()
(org-test-at-id "f68821bc-7f49-4389-85b5-914791ee3718"
(org-babel-next-src-block 2)
(should (string= "615946d1cd30c88c17ae6bf1d56a3f90232ddf78"
(org-babel-sha1-hash)))))
(provide 'test-ob) (provide 'test-ob)
;;; test-ob ends here ;;; test-ob ends here