فهرست منبع

more fleshing out of writing to file

Eric Schulte 16 سال پیش
والد
کامیت
c09041b785
1فایلهای تغییر یافته به همراه17 افزوده شده و 5 حذف شده
  1. 17 5
      lisp/org-babel-tangle.el

+ 17 - 5
lisp/org-babel-tangle.el

@@ -42,7 +42,8 @@ file.")
   "Extract the bodies of all source code blocks form the current
 file into their own source-specific files."
   (interactive)
-  (let (blocks)
+  (let ((base-name (file-name-sans-extension (buffer-file-name)))
+        blocks)
     ;; blocks will be two nested association lists, first grouped by
     ;; language, then by session, the contents of the second a-list
     ;; will be source-code blocks
@@ -74,14 +75,25 @@ file into their own source-specific files."
               (she-bang (second lang-specs))
               (by-session (cdr by-lang)))
          ;; if there are multiple sessions then break out by session
-         ))
-     )
-    ))
+         (if (> (length by-session) 1)
+             (mapc (lambda (session-pair)
+                     (org-babel-tangle-specs-to-file
+                      (format "%s-%s.%s" base-name (car session-pair) ext) (cdr session-pair) she-bang))
+                   by-session)
+           (org-babel-tangle-specs-to-file (format "%s.%s" base-name ext) ext she-bang))))
+     blocks)))
+
+(defun org-babel-tangle-specs-to-file (filename specs &optional she-bang)
+  "Take a list of source-block specifications in SPECS and write
+it out to FILENAME."
+  (with-temp-file filename
+    (when she-bang (insert she-bang))
+    (insert (mapconcat #'org-babel-spec-to-string specs "\n"))))
 
 (defun org-babel-spec-to-string (spec)
   "Return the string version of spec suitable for inclusion in a
 source code file."
-  )
+  (message spec))
 
 (provide 'org-babel-tangle)
 ;;; org-babel-tangle.el ends here