feat(emacs): use s-join instead of string-join

Because string-join was introduced at Emacs 24.4 and subr-x.el must be
loaded for using it.
This commit is contained in:
Syohei YOSHIDA 2016-01-14 20:35:59 +09:00 committed by Soonho Kong
parent 885c62648f
commit f2eef7aa1b
6 changed files with 51 additions and 46 deletions

View file

@ -7,6 +7,7 @@
(require 'cl-lib) (require 'cl-lib)
(require 'dash) (require 'dash)
(require 'dash-functional) (require 'dash-functional)
(require 's)
(require 'lean-util) (require 'lean-util)
(require 'lean-debug) (require 'lean-debug)
@ -33,7 +34,7 @@
(defun lean-info-type-body (typeinfo) (defun lean-info-type-body (typeinfo)
(cl-third typeinfo)) (cl-third typeinfo))
(defun lean-info-type-body-str (typeinfo) (defun lean-info-type-body-str (typeinfo)
(string-join (lean-info-type-body typeinfo) "\n")) (s-join "\n" (lean-info-type-body typeinfo)))
;; Overload Information ;; Overload Information
;; -------------------- ;; --------------------
@ -48,7 +49,7 @@
(cl-second overload)) (cl-second overload))
(defun lean-info-overload-names (overload) (defun lean-info-overload-names (overload)
(cl-loop for seq in (cl-third overload) (cl-loop for seq in (cl-third overload)
collect (string-join seq "\n"))) collect (s-join "\n" seq)))
(defun lean-info-overload-parse-header (str) (defun lean-info-overload-parse-header (str)
(let ((items (split-string str "|"))) (let ((items (split-string str "|")))
(list (string-to-number (cl-second items)) (list (string-to-number (cl-second items))
@ -82,7 +83,7 @@
(defun lean-info-synth-body (synth) (defun lean-info-synth-body (synth)
(cl-third synth)) (cl-third synth))
(defun lean-info-synth-body-str (synth) (defun lean-info-synth-body-str (synth)
(string-join (lean-info-synth-body synth) "\n")) (s-join "\n" (lean-info-synth-body synth)))
;; Coercion Information ;; Coercion Information
;; ---------------- ;; ----------------
@ -109,11 +110,11 @@
(defun lean-info-coercion-expr (coercion) (defun lean-info-coercion-expr (coercion)
(cl-third coercion)) (cl-third coercion))
(defun lean-info-coercion-expr-str (coercion) (defun lean-info-coercion-expr-str (coercion)
(string-join (lean-info-coercion-expr coercion) "\n")) (s-join "\n" (lean-info-coercion-expr coercion)))
(defun lean-info-coercion-type (coercion) (defun lean-info-coercion-type (coercion)
(cl-fourth coercion)) (cl-fourth coercion))
(defun lean-info-coercion-type-str (coercion) (defun lean-info-coercion-type-str (coercion)
(string-join (lean-info-coercion-type coercion) "\n")) (s-join "\n" (lean-info-coercion-type coercion)))
;; Extra Information ;; Extra Information
;; ---------------- ;; ----------------
@ -140,11 +141,11 @@
(defun lean-info-extra-expr (extra) (defun lean-info-extra-expr (extra)
(cl-third extra)) (cl-third extra))
(defun lean-info-extra-expr-str (extra) (defun lean-info-extra-expr-str (extra)
(string-join (lean-info-extra-expr extra) "\n")) (s-join "\n" (lean-info-extra-expr extra)))
(defun lean-info-extra-type (extra) (defun lean-info-extra-type (extra)
(cl-fourth extra)) (cl-fourth extra))
(defun lean-info-extra-type-str (extra) (defun lean-info-extra-type-str (extra)
(string-join (lean-info-extra-type extra) "\n")) (s-join "\n" (lean-info-extra-type extra)))
;; Identifier Information ;; Identifier Information
;; ---------------------- ;; ----------------------
@ -169,7 +170,7 @@
(defun lean-info-identifier-body (identifier) (defun lean-info-identifier-body (identifier)
(cl-third identifier)) (cl-third identifier))
(defun lean-info-identifier-body-str (identifier) (defun lean-info-identifier-body-str (identifier)
(string-join (lean-info-identifier-body identifier) "\n")) (s-join "\n" (lean-info-identifier-body identifier)))
;; Symbol Information ;; Symbol Information
@ -195,12 +196,12 @@
(defun lean-info-symbol-body (symbol) (defun lean-info-symbol-body (symbol)
(cl-third symbol)) (cl-third symbol))
(defun lean-info-symbol-body-str (symbol) (defun lean-info-symbol-body-str (symbol)
(string-join (lean-info-symbol-body symbol) "\n")) (s-join "\n" (lean-info-symbol-body symbol)))
(defun lean-info-id-symbol-body-str (info) (defun lean-info-id-symbol-body-str (info)
(cl-case (lean-info-kind info) (cl-case (lean-info-kind info)
('IDENTIFIER (string-join (lean-info-symbol-body info) "\n")) ('IDENTIFIER (s-join "\n" (lean-info-symbol-body info)))
('SYMBOL (string-join (lean-info-identifier-body info) "\n")))) ('SYMBOL (s-join "\n" (lean-info-identifier-body info)))))
;; Proofstate Information ;; Proofstate Information
@ -227,7 +228,7 @@
(defun lean-info-proofstate-states (proofstate) (defun lean-info-proofstate-states (proofstate)
(cl-third proofstate)) (cl-third proofstate))
(defun lean-info-proofstate-state-str (string-seq) (defun lean-info-proofstate-state-str (string-seq)
(string-join string-seq "\n")) (s-join "\n" string-seq))
(defun lean-info-proofstate-extract-conclusion (string-seq) (defun lean-info-proofstate-extract-conclusion (string-seq)
(--drop-while (not (s-starts-with? "" it)) string-seq)) (--drop-while (not (s-starts-with? "" it)) string-seq))
(defun lean-info-proofstate-extract-premises (string-seq) (defun lean-info-proofstate-extract-premises (string-seq)
@ -241,18 +242,18 @@
(first-state (first-state
(pcase display-style (pcase display-style
(`show-all (`show-all
(string-join (s-join
(-map 'lean-info-proofstate-state-str states) "\n\n"
"\n\n")) (-map 'lean-info-proofstate-state-str states)))
(`show-first (`show-first
(lean-info-proofstate-state-str first-state)) (lean-info-proofstate-state-str first-state))
(`show-first-and-other-conclusions (`show-first-and-other-conclusions
(string-join (s-join
"\n\n"
(-map 'lean-info-proofstate-state-str (-map 'lean-info-proofstate-state-str
(cons first-state (-map (cons first-state (-map
'lean-info-proofstate-extract-conclusion 'lean-info-proofstate-extract-conclusion
rest-states))) rest-states)))))))
"\n\n"))))
(t "No Goal")))) (t "No Goal"))))
;; Basic ;; Basic
@ -470,13 +471,13 @@ Take out \"BEGININFO\" and \"ENDINFO\" and Use \"ACK\" as a delim."
(setq type-str (lean-info-type-body-str type))) (setq type-str (lean-info-type-body-str type)))
(when (and name-str overload) (when (and name-str overload)
(setq overload-str (setq overload-str
(string-join (s-join
", "
(--remove (--remove
(or (or
(and id (string-prefix-p (lean-info-id-symbol-body-str id) it)) (and id (string-prefix-p (lean-info-id-symbol-body-str id) it))
(and sym (string-prefix-p (lean-info-id-symbol-body-str sym) it))) (and sym (string-prefix-p (lean-info-id-symbol-body-str sym) it)))
(lean-info-overload-names overload)) (lean-info-overload-names overload)))))
", ")))
(when extra (when extra
(setq str (setq str
(cond (lean-show-only-type-in-parens (format ": %s" (lean-info-extra-type-str extra))) (cond (lean-show-only-type-in-parens (format ": %s" (lean-info-extra-type-str extra)))

View file

@ -7,6 +7,7 @@
(require 'dash) (require 'dash)
(require 'dash-functional) (require 'dash-functional)
(require 's)
(cl-defstruct lean-option-record name type value desc) (cl-defstruct lean-option-record name type value desc)
@ -24,7 +25,7 @@
(setq str-list (setq str-list
(-take (- (length str-list) 2) (-take (- (length str-list) 2)
(-drop 1 str-list))) (-drop 1 str-list)))
(string-join str-list "\n"))) (s-join "\n" str-list)))
(defun lean-option-string (&optional use-flycheck) (defun lean-option-string (&optional use-flycheck)
"Return string of Lean options set by lean-set-option command" "Return string of Lean options set by lean-set-option command"

View file

@ -4,6 +4,7 @@
;; Author: Soonho Kong ;; Author: Soonho Kong
;; ;;
(require 's)
(require 'lean-util) (require 'lean-util)
(defconst lean-project-file-name ".project" (defconst lean-project-file-name ".project"
@ -23,7 +24,8 @@
(if (file-exists-p project-file) (if (file-exists-p project-file)
(user-error "project-file %s already exists" project-file)) (user-error "project-file %s already exists" project-file))
(find-file project-file) (find-file project-file)
(insert (string-join '("# Lean project file" (insert (s-join "\n"
'("# Lean project file"
"" ""
"# Include all .lean files under this directory" "# Include all .lean files under this directory"
"+ *.lean" "+ *.lean"
@ -32,8 +34,7 @@
"- flycheck*.lean" "- flycheck*.lean"
"" ""
"# Exclude emacs temp files" "# Exclude emacs temp files"
"- .#*.lean") "- .#*.lean")))
"\n"))
(save-buffer))) (save-buffer)))
(provide 'lean-project) (provide 'lean-project)

View file

@ -492,7 +492,7 @@ If it's not the same with file-name (default: buffer-file-name), send VISIT cmd.
(setq str-list (setq str-list
(-take (- (length str-list) 2) (-take (- (length str-list) 2)
(-drop 1 str-list))) (-drop 1 str-list)))
(string-join str-list "\n"))) (s-join "\n" str-list)))
(defun lean-findp-parse-string (str) (defun lean-findp-parse-string (str)
"Parse the output of findp command." "Parse the output of findp command."

View file

@ -8,6 +8,7 @@
(require 'cl-lib) (require 'cl-lib)
(require 'dash) (require 'dash)
(require 'dash-functional) (require 'dash-functional)
(require 's)
(require 'lean-variable) (require 'lean-variable)
(require 'lean-util) (require 'lean-util)
(require 'lean-cmd) (require 'lean-cmd)
@ -65,7 +66,7 @@ buffer. It's used to avoid outputting the same message")
(defun lean-eldoc-documentation-function-cont (info-record &optional add-to-kill-ring) (defun lean-eldoc-documentation-function-cont (info-record &optional add-to-kill-ring)
"Continuation for lean-eldoc-documentation-function" "Continuation for lean-eldoc-documentation-function"
(let* ((info-strings (lean-info-record-to-strings info-record)) (let* ((info-strings (lean-info-record-to-strings info-record))
(info-string-mini-buffer (and info-strings (string-join info-strings " "))) (info-string-mini-buffer (and info-strings (s-join " " info-strings)))
(info-string-info-buffer (and info-strings (-last-item info-strings))) (info-string-info-buffer (and info-strings (-last-item info-strings)))
(proofstate (lean-info-record-proofstate info-record))) (proofstate (lean-info-record-proofstate info-record)))
(when info-strings (when info-strings
@ -112,7 +113,7 @@ buffer. It's used to avoid outputting the same message")
(setq str-list (setq str-list
(-take (- (length str-list) 2) (-take (- (length str-list) 2)
(-drop 1 str-list))) (-drop 1 str-list)))
(string-join str-list "\n"))) (s-join "\n" str-list)))
(defun lean-eval-cmd (lean-cmd) (defun lean-eval-cmd (lean-cmd)
"Evaluate lean command." "Evaluate lean command."

View file

@ -5,6 +5,7 @@
;; ;;
(require 'ert) (require 'ert)
(require 's)
(require 'lean-info) (require 'lean-info)
(ert-deftest lean-test-info-type () (ert-deftest lean-test-info-type ()
@ -291,7 +292,7 @@
"H_3 : c" "H_3 : c"
"⊢ and b c")) "⊢ and b c"))
'show-all) 'show-all)
(string-join '("a : Prop," (s-join "\n" '("a : Prop,"
"b : Prop," "b : Prop,"
"c : Prop," "c : Prop,"
"H_1 : a," "H_1 : a,"
@ -305,7 +306,7 @@
"H_1 : a," "H_1 : a,"
"H_2 : b," "H_2 : b,"
"H_3 : c" "H_3 : c"
"⊢ and b c") "\n"))) "⊢ and b c"))))
(should (equal (lean-info-proofstate-states-str (should (equal (lean-info-proofstate-states-str
(lean-info-proofstate-parse (lean-info-proofstate-parse
'("-- PROOF_STATE|6|17" '("-- PROOF_STATE|6|17"
@ -325,13 +326,13 @@
"H_3 : c" "H_3 : c"
"⊢ and b c")) "⊢ and b c"))
'show-first) 'show-first)
(string-join '("a : Prop," (s-join "\n" '("a : Prop,"
"b : Prop," "b : Prop,"
"c : Prop," "c : Prop,"
"H_1 : a," "H_1 : a,"
"H_2 : b," "H_2 : b,"
"H_3 : c" "H_3 : c"
"⊢ a") "\n"))) "⊢ a"))))
(should (equal (lean-info-proofstate-states-str (should (equal (lean-info-proofstate-states-str
(lean-info-proofstate-parse (lean-info-proofstate-parse
'("-- PROOF_STATE|6|17" '("-- PROOF_STATE|6|17"
@ -351,7 +352,7 @@
"H_3 : c" "H_3 : c"
"⊢ and b c")) "⊢ and b c"))
'show-first-and-other-conclusions) 'show-first-and-other-conclusions)
(string-join '("a : Prop," (s-join "\n" '("a : Prop,"
"b : Prop," "b : Prop,"
"c : Prop," "c : Prop,"
"H_1 : a," "H_1 : a,"
@ -359,7 +360,7 @@
"H_3 : c" "H_3 : c"
"⊢ a" "⊢ a"
"" ""
"⊢ and b c") "\n")))) "⊢ and b c")))))
(ert-deftest lean-test-info-pos () (ert-deftest lean-test-info-pos ()
"Test lean-info-pos" "Test lean-info-pos"