mirror of
https://gerrit.googlesource.com/git-repo
synced 2025-01-08 16:14:26 +00:00
Support GIT_EDITOR='vim -c "set textwidth=80"'
If there are shell special characters in the editor string, we must use /bin/sh to parse and execute it, rather than trying to rely on a simple split(' '). This avoids vim starting up with two empty buffers, due to a misparsed command line. Signed-off-by: Shawn O. Pearce <sop@google.com>
This commit is contained in:
parent
37dbf2bf0f
commit
1dcb58a7d0
27
editor.py
27
editor.py
@ -14,6 +14,7 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
import re
|
||||||
import sys
|
import sys
|
||||||
import subprocess
|
import subprocess
|
||||||
import tempfile
|
import tempfile
|
||||||
@ -38,9 +39,10 @@ class Editor(object):
|
|||||||
if e:
|
if e:
|
||||||
return e
|
return e
|
||||||
|
|
||||||
e = cls.globalConfig.GetString('core.editor')
|
if cls.globalConfig:
|
||||||
if e:
|
e = cls.globalConfig.GetString('core.editor')
|
||||||
return e
|
if e:
|
||||||
|
return e
|
||||||
|
|
||||||
e = os.getenv('VISUAL')
|
e = os.getenv('VISUAL')
|
||||||
if e:
|
if e:
|
||||||
@ -69,21 +71,32 @@ least one of these before using this command."""
|
|||||||
Returns:
|
Returns:
|
||||||
new value of edited text; None if editing did not succeed
|
new value of edited text; None if editing did not succeed
|
||||||
"""
|
"""
|
||||||
editor = cls._GetEditor().split()
|
editor = cls._GetEditor()
|
||||||
|
if editor == ':':
|
||||||
|
return data
|
||||||
|
|
||||||
fd, path = tempfile.mkstemp()
|
fd, path = tempfile.mkstemp()
|
||||||
try:
|
try:
|
||||||
os.write(fd, data)
|
os.write(fd, data)
|
||||||
os.close(fd)
|
os.close(fd)
|
||||||
fd = None
|
fd = None
|
||||||
|
|
||||||
|
if re.compile("^.*[$ \t'].*$").match(editor):
|
||||||
|
args = [editor + ' "$@"']
|
||||||
|
shell = True
|
||||||
|
else:
|
||||||
|
args = [editor]
|
||||||
|
shell = False
|
||||||
|
args.append(path)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
rc = subprocess.Popen(editor + [path]).wait()
|
rc = subprocess.Popen(args, shell=shell).wait()
|
||||||
except OSError, e:
|
except OSError, e:
|
||||||
raise EditorError('editor failed, %s: %s %s'
|
raise EditorError('editor failed, %s: %s %s'
|
||||||
% (str(e), cls._GetEditor(), path))
|
% (str(e), editor, path))
|
||||||
if rc != 0:
|
if rc != 0:
|
||||||
raise EditorError('editor failed with exit status %d: %s %s'
|
raise EditorError('editor failed with exit status %d: %s %s'
|
||||||
% (rc, cls._GetEditor(), path))
|
% (rc, editor, path))
|
||||||
|
|
||||||
fd2 = open(path)
|
fd2 = open(path)
|
||||||
try:
|
try:
|
||||||
|
Loading…
Reference in New Issue
Block a user