diff options
author | Guido van Rossum <guido@python.org> | 1992-08-09 13:54:50 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1992-08-09 13:54:50 (GMT) |
commit | 4732ccf6425b155cf7b2eb22c2dd071b97a462ff (patch) | |
tree | 77d1872d68bf4415a88c1424e854c2761413ccbf | |
parent | 21803b8a6f9e78fc220bf95658182f7ca3265173 (diff) | |
download | cpython-4732ccf6425b155cf7b2eb22c2dd071b97a462ff.zip cpython-4732ccf6425b155cf7b2eb22c2dd071b97a462ff.tar.gz cpython-4732ccf6425b155cf7b2eb22c2dd071b97a462ff.tar.bz2 |
Added emacs.py (for misc/py-connect.el).
posixpath.py: added undocumented expanndvars() (expands $VAR in string).
-rw-r--r-- | Lib/emacs.py | 18 | ||||
-rw-r--r-- | Lib/posixpath.py | 26 |
2 files changed, 44 insertions, 0 deletions
diff --git a/Lib/emacs.py b/Lib/emacs.py new file mode 100644 index 0000000..ffce099 --- /dev/null +++ b/Lib/emacs.py @@ -0,0 +1,18 @@ +# Execute Emacs code from a Python interpreter. +# This code should be imported from a Python interpreter that is +# running as an inferior process of Emacs. +# See misc/py-connect.el for the companion Emacs lisp code. +# Author: Terrence M. Brannon. + +start_marker = '+' +end_marker = '~' + +def eval (string): + tmpstr = start_marker + '(' + string + ')' + end_marker + print tmpstr + +def dired (directory): + eval( 'dired ' + '"' + directory + '"' ) + +def buffer_menu (): + eval( 'buffer-menu(buffer-list)' ) diff --git a/Lib/posixpath.py b/Lib/posixpath.py index b178e67..d2bda10 100644 --- a/Lib/posixpath.py +++ b/Lib/posixpath.py @@ -230,3 +230,29 @@ def expanduser(path): return path userhome = pwent[5] return userhome + path[i:] + + +# Expand paths containing shell variable substitutions. +# This is done by piping it through the shell. +# Shell quoting characters (\ " ' `) are protected by a backslash. +# NB: a future version may avoid starting a subprocess and do the +# substitutions internally. This may slightly change the syntax +# for variables. + +def expandvars(path): + if '$' not in path: + return path + q = '' + for c in path: + if c in ('\\', '"', '\'', '`'): + c = '\\' + c + q = q + c + d = '!' + if q == d: + d = '+' + p = posix.popen('cat <<' + d + '\n' + q + '\n' + d + '\n', 'r') + res = p.read() + del p + if res[-1:] == '\n': + res = res[:-1] + return res |