ob-smiles.el 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. ;;; ob-smiles.el --- Org-mode Babel support for SMILES.
  2. ;;; -*- coding: utf-8 -*-
  3. ;; Keywords: org babel SMILES
  4. ;; Version: 0.0.1
  5. ;; Package-Requires: ((smiles-mode "0.0.1") (org "8"))
  6. ;;; Commentary:
  7. ;;; I copy code from:
  8. ;;; https://kitchingroup.cheme.cmu.edu/blog/2016/03/26/A-molecule-link-for-org-mode
  9. ;; Author: John Kitchin [jkitchin@andrew.cmu.edu]
  10. ;; Maintainer: stardiviner [numbchild@gmail.com]
  11. ;;; Code:
  12. (require 'ob)
  13. (require 'org-element)
  14. ;; Org-mode Babel
  15. (defun org-babel-execute:smiles (body params)
  16. "Execute SMILES babel `BODY' with `PARAMS'."
  17. (shell-command-to-string
  18. (format "obabel -:\"%s\" -osvg 2> /dev/null" body)))
  19. ;; Org-mode link
  20. (defun molecule-jump (name)
  21. "Jump to molecule `NAME' definition."
  22. (org-mark-ring-push)
  23. (org-link-open-from-string (format "[[%s]]" name)))
  24. (defun molecule-export (path desc backend)
  25. "Export molecule to HTML format on `PATH' with `DESC' and `BACKEND'."
  26. (let ((name (save-window-excursion
  27. (molecule-jump path)
  28. (org-element-property :name (org-element-context)))))
  29. (cond
  30. ((eq 'html backend)
  31. (format "<a href=\"#%s\">%s</a>" name name)))))
  32. (org-link-set-parameters
  33. "molecule"
  34. :follow 'molecule-jump
  35. :export 'molecule-export)
  36. ;; org-mode element
  37. (org-element-map (org-element-parse-buffer)
  38. 'src-block
  39. (lambda (src)
  40. (when (string= "smiles" (org-element-property :language src))
  41. (org-element-property :name src))))
  42. (provide 'ob-smiles)
  43. ;;; ob-smiles.el ends here