代码拉取完成,页面将自动刷新
#!/usr/bin/env python
###############################################################################
#
# MODULE : tm_python.py
# DESCRIPTION : Initialize python plugin
# COPYRIGHT : (C) 2004 Ero Carrera, ero@dkbza.org
# (C) 2012 Adrian Soto
# (C) 2014 Miguel de Benito Delgado, mdbenito@texmacs.org
# (C) 2018-2020 Darcy Shen
#
# This software falls under the GNU general public license version 3 or later.
# It comes WITHOUT ANY WARRANTY WHATSOEVER. For details, see the file LICENSE
# in the root directory or <http://www.gnu.org/licenses/gpl-3.0.html>.
import os
import sys
import platform
from os.path import exists
tmpy_home_path = os.environ.get("TEXMACS_HOME_PATH") + "/plugins/tmpy"
if (exists (tmpy_home_path)):
sys.path.append(os.environ.get("TEXMACS_HOME_PATH") + "/plugins/")
else:
sys.path.append(os.environ.get("TEXMACS_PATH") + "/plugins/")
import traceback
import string
import ast
from inspect import ismodule, getsource, getsourcefile
from tmpy.compat import py_ver
from tmpy.capture import CaptureStdout
from tmpy.postscript import ps_out, PSOutDummy, pdf_out, FileOutDummy
from tmpy.completion import parse_complete_command, complete
from tmpy.protocol import *
if py_ver == 2:
flush_err ("Python 2 is no longer supported, please use Python 3")
exit (-1)
# import logging as log
# log.basicConfig(filename='/tmp/tm_python.log',level=log.INFO)
def flush_output (data):
"""Do some parsing on the output according to its type.
Non printable characters in unicode strings are escaped
and objects of type None are not printed (so that procedure calls,
as opposed to function calls, don't produce any output)."""
if (data is None):
flush_verbatim ("")
return
if isinstance (data, PSOutDummy):
flush_ps (data.content)
elif isinstance (data, FileOutDummy):
if (data.content is None):
flush_verbatim ("")
else:
flush_file (data.content)
else:
flush_verbatim (str(data).strip())
def as_scm_string (text):
return '"%s"' % text.replace('\\', '\\\\').replace('"', '\\"')
def compile_help (text):
cmd = 'help(%s)' % text
out = {"help" : "", "src": "", "file": ""}
try:
out["help"] = CaptureStdout.capture (cmd, my_globals, "tm_python");
except Exception as e:
out ["help"] = 'No help for "%s": %s' % (text, e)
try:
out["src"] = eval ('getsource(%s)' % text,
my_globals, {'getsource' : getsource})
except Exception as e:
out["src"] = 'No code available for "%s": %s' % (text, e)
try:
# Todo: strip docstring from code
out["file"] = eval ('getsourcefile(%s)' % text,
my_globals, {'getsourcefile' : getsourcefile})
except Exception as e:
out["file"] = 'Unable to access the code for "%s": %s' % (text, e)
return dict (map (lambda k_v: (k_v[0], as_scm_string (k_v[1])), out.items()))
def my_eval (code, p_globals):
'''Execute a script and return the value of the last expression'''
block = ast.parse(code, mode='exec')
if len(block.body) > 1 and isinstance(block.body[-1], ast.Expr):
last = ast.Expression(block.body.pop().value)
exec(compile(block, '<string>', mode='exec'), p_globals)
return eval(compile(last, '<string>', mode='eval'), p_globals)
else:
return eval(code, p_globals)
__version__ = '3.0'
__author__ = 'Ero Carrera, Adrian Soto, Miguel de Benito Delgado, Darcy Shen'
my_globals = {}
# We insert into the session's namespace the 'ps_out' method.
my_globals['ps_out'] = ps_out
my_globals['pdf_out'] = pdf_out
# As well as some documentation.
my_globals['__doc__'] = """A Python plugin for TeXmacs.
Provides autocompletion and embedding of PostScript data into the document,
e.g from files or from matplotlib.pyplot.
A rudimentary help window is also implemented: type the name of an object
with a question mark at the end to use it."""
text = 'import builtins as __builtins__'
CaptureStdout.capture (text, my_globals, "tm_python")
sys.stdout = os.fdopen (sys.stdout.fileno(), 'w')
###############################################################################
# Session start
###############################################################################
if (exists (tmpy_home_path)):
flush_verbatim ("WARNING: You are under develop mode using " + tmpy_home_path)
flush_newline (2)
flush_verbatim (f"Python { platform.python_version() } [{ sys.executable }] \n" +
"Python plugin for TeXmacs.\n" +
"Please see the documentation in Help -> Plugins -> Python")
flush_prompt (">>> ")
while True:
line= input ()
if not line:
continue
if line[0] == DATA_COMMAND:
sf = parse_complete_command (line[1:])
if sf[0] == 'complete':
flush_scheme (complete (sf[1], sf[2], my_globals))
continue
elif line.endswith('?') and not line.strip().startswith('#'):
if len(line) > 1:
out= compile_help (line[:-1])
flush_command ('(tmpy-open-help %s %s %s)' %
(out["help"], out["src"], out["file"]))
else:
flush_verbatim ('Type a name before the "?" to see the help')
continue
else:
lines= [line]
while line != "<EOF>":
line= input ()
if line == '':
continue
lines.append (line)
text = '\n'.join (lines[:-1])
try: # Is it an expression?
result= my_eval (text, my_globals)
except:
result= CaptureStdout.capture (text, my_globals, "tm_python")
flush_output (result)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。