]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix 'python-shell-buffer-substring' when START is in middle of 1st line
authorkobarity <kobarity@gmail.com>
Sun, 1 Jan 2023 12:09:10 +0000 (21:09 +0900)
committerEli Zaretskii <eliz@gnu.org>
Sat, 7 Jan 2023 08:57:38 +0000 (10:57 +0200)
* lisp/progmodes/python.el (python-shell-buffer-substring): Instead
of checking whether START is point-min, check whether START is in
the first line.  (Bug#60466)
* test/lisp/progmodes/python-tests.el
(python-shell-buffer-substring-18): New test.

lisp/progmodes/python.el
test/lisp/progmodes/python-tests.el

index 59164d7d50ce5ba5f97ec4852720c4a59b787253..c399bbc64f8d1ef296e79646ee0aaf22610252d4 100644 (file)
@@ -3766,15 +3766,16 @@ the python shell:
                         (line-beginning-position)
                       start))))
          (substring (buffer-substring-no-properties start end))
-         (starts-at-point-min-p (save-restriction
-                                  (widen)
-                                  (= (point-min) start)))
+         (starts-at-first-line-p (save-restriction
+                                   (widen)
+                                   (goto-char start)
+                                   (= (line-number-at-pos) 1)))
          (encoding (python-info-encoding))
          (toplevel-p (zerop (save-excursion
                               (goto-char start)
                               (python-util-forward-comment 1)
                               (current-indentation))))
-         (fillstr (cond (starts-at-point-min-p
+         (fillstr (cond (starts-at-first-line-p
                          nil)
                         ((not no-cookie)
                          (concat
index eac558db10f0383a23d76fcc0500466b73f5ab49..df71990278e1469226e53785a123d2cd0abc5051 100644 (file)
@@ -4520,6 +4520,16 @@ def foo():
                      (python-tests-look-at "\"\"\""))
                     "# -*- coding: utf-8 -*-\n\nif True:\n    a = 1\n    b = 2\n\n"))))
 
+(ert-deftest python-shell-buffer-substring-18 ()
+  "Check substring from the part of the first line."
+  (python-tests-with-temp-buffer
+   "s = 'test'
+"
+   (should (string= (python-shell-buffer-substring
+                     (python-tests-look-at "'test'")
+                     (pos-eol))
+                    "'test'"))))
+
 
 \f
 ;;; Shell completion