本文整理匯總了Python中docutils.utils.SystemMessage方法的典型用法代碼示例。如果您正苦於以下問題:Python utils.SystemMessage方法的具體用法?Python utils.SystemMessage怎麽用?Python utils.SystemMessage使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類docutils.utils
的用法示例。
在下文中一共展示了utils.SystemMessage方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def test(self, data):
content_type = data.get("long_description_content_type", None)
if content_type in ("text/plain", "text/markdown"):
# These can't fail. Markdown will just assume everything
# it doesn't understand is plain text.
return True
# This should be ReStructuredText
source = data.get("long_description", "")
stream = io.StringIO()
settings = {"warning_stream": stream}
try:
publish_parts(
source=source, writer_name="html4css1", settings_overrides=settings
)
except SystemMessage as e:
self._message = e.args[0]
errors = stream.getvalue().strip()
if not errors:
return True
self._message = "\n" + errors
return False
示例2: report_Exception
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def report_Exception(self, error):
if isinstance(error, utils.SystemMessage):
self.report_SystemMessage(error)
elif isinstance(error, UnicodeEncodeError):
self.report_UnicodeError(error)
elif isinstance(error, io.InputError):
self._stderr.write('Unable to open source file for reading:\n'
' %s\n' % ErrorString(error))
elif isinstance(error, io.OutputError):
self._stderr.write(
'Unable to open destination file for writing:\n'
' %s\n' % ErrorString(error))
else:
print('%s' % ErrorString(error), file=self._stderr)
print(("""\
Exiting due to error. Use "--traceback" to diagnose.
Please report errors to <docutils-users@lists.sf.net>.
Include "--traceback" output, Docutils version (%s [%s]),
Python version (%s), your OS type & version, and the
command line used.""" % (__version__, __version_details__,
sys.version.split()[0])), file=self._stderr)
示例3: report_Exception
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def report_Exception(self, error):
if isinstance(error, utils.SystemMessage):
self.report_SystemMessage(error)
elif isinstance(error, UnicodeEncodeError):
self.report_UnicodeError(error)
elif isinstance(error, io.InputError):
self._stderr.write(u'Unable to open source file for reading:\n'
u' %s\n' % ErrorString(error))
elif isinstance(error, io.OutputError):
self._stderr.write(
u'Unable to open destination file for writing:\n'
u' %s\n' % ErrorString(error))
else:
print >>self._stderr, u'%s' % ErrorString(error)
print >>self._stderr, ("""\
Exiting due to error. Use "--traceback" to diagnose.
Please report errors to <docutils-users@lists.sf.net>.
Include "--traceback" output, Docutils version (%s [%s]),
Python version (%s), your OS type & version, and the
command line used.""" % (__version__, __version_details__,
sys.version.split()[0]))
示例4: render
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def render(raw, stream=None, **kwargs):
if stream is None:
# Use a io.StringIO as the warning stream to prevent warnings from
# being printed to sys.stderr.
stream = io.StringIO()
settings = SETTINGS.copy()
settings["warning_stream"] = stream
writer = Writer()
writer.translator_class = ReadMeHTMLTranslator
try:
parts = publish_parts(raw, writer=writer, settings_overrides=settings)
except SystemMessage:
rendered = None
else:
rendered = parts.get("docinfo", "") + parts.get("fragment", "")
if rendered:
return clean(rendered)
else:
return None
示例5: report_Exception
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def report_Exception(self, error):
if isinstance(error, utils.SystemMessage):
self.report_SystemMessage(error)
elif isinstance(error, UnicodeEncodeError):
self.report_UnicodeError(error)
elif isinstance(error, io.InputError):
self._stderr.write('Unable to open source file for reading:\n'
' %s\n' % ErrorString(error))
elif isinstance(error, io.OutputError):
self._stderr.write(
'Unable to open destination file for writing:\n'
' %s\n' % ErrorString(error))
else:
print('%s' % ErrorString(error), file=self._stderr)
print(("""\
Exiting due to error. Use "--traceback" to diagnose.
Please report errors to <docutils-users@lists.sf.net>.
Include "--traceback" output, Docutils version (%s%s),
Python version (%s), your OS type & version, and the
command line used.""" % (__version__,
docutils.__version_details__ and
' [%s]'%docutils.__version_details__ or '',
sys.version.split()[0])), file=self._stderr)
示例6: report_Exception
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def report_Exception(self, error):
if isinstance(error, utils.SystemMessage):
self.report_SystemMessage(error)
elif isinstance(error, UnicodeEncodeError):
self.report_UnicodeError(error)
elif isinstance(error, io.InputError):
self._stderr.write(u'Unable to open source file for reading:\n'
u' %s\n' % ErrorString(error))
elif isinstance(error, io.OutputError):
self._stderr.write(
u'Unable to open destination file for writing:\n'
u' %s\n' % ErrorString(error))
else:
print >>self._stderr, u'%s' % ErrorString(error)
print >>self._stderr, ("""\
Exiting due to error. Use "--traceback" to diagnose.
Please report errors to <docutils-users@lists.sf.net>.
Include "--traceback" output, Docutils version (%s%s),
Python version (%s), your OS type & version, and the
command line used.""" % (__version__,
docutils.__version_details__ and
' [%s]'%docutils.__version_details__ or '',
sys.version.split()[0]))
示例7: render
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def render(raw, stream=None):
if stream is None:
# Use a io.StringIO as the warning stream to prevent warnings from
# being printed to sys.stderr.
stream = io.StringIO()
settings = SETTINGS.copy()
settings["warning_stream"] = stream
writer = Writer()
writer.translator_class = ReadMeHTMLTranslator
try:
parts = publish_parts(raw, writer=writer, settings_overrides=settings)
except SystemMessage:
rendered = None
else:
rendered = parts.get("fragment")
if rendered:
return clean(rendered)
else:
return None
示例8: _get_part
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def _get_part(self, part):
try:
return getattr(self.markup_, part)(self.raw)
except SystemMessage:
return ''
示例9: _sphinx_run
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def _sphinx_run(self):
if not self.verbose:
status_stream = cStringIO.StringIO()
else:
status_stream = sys.stdout
confoverrides = {}
if self.version:
confoverrides['version'] = self.version
if self.release:
confoverrides['release'] = self.release
if self.today:
confoverrides['today'] = self.today
sphinx_config = config.Config(self.config_dir, 'conf.py', {}, [])
sphinx_ver = pkg_resources.get_distribution("sphinx").version
if pkg_resources.parse_version(sphinx_ver) > \
pkg_resources.parse_version('1.2.3'):
sphinx_config.init_values(warnings.warn)
else:
sphinx_config.init_values()
if self.builder == 'man' and len(sphinx_config.man_pages) == 0:
return
app = application.Sphinx(
self.source_dir, self.config_dir,
self.builder_target_dir, self.doctree_dir,
self.builder, confoverrides, status_stream,
freshenv=self.fresh_env, warningiserror=False)
try:
app.build(force_all=self.all_files)
except Exception as err:
from docutils import utils
if isinstance(err, utils.SystemMessage):
sys.stder.write('reST markup error:\n')
sys.stderr.write(err.args[0].encode('ascii',
'backslashreplace'))
sys.stderr.write('\n')
else:
raise
if self.link_index:
src = app.config.master_doc + app.builder.out_suffix
dst = app.builder.get_outfilename('index')
os.symlink(src, dst)
示例10: sphinxify
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def sphinxify(docstring, context, buildername='html', img_path=''):
"""
Largely modified Spyder's sphinxify.
"""
# if not img_path:
# img_path = os.path.join(CONFDIR, "_images")
if img_path:
if os.name == 'nt':
img_path = img_path.replace('\\', '/')
leading = '/' if os.name.startswith('posix') else ''
docstring = docstring.replace('_images', leading+img_path)
srcdir = osp.join(CONFDIR, '_sources')
if not os.path.exists(srcdir):
os.makedirs(srcdir)
# srcdir = encoding.to_unicode_from_fs(srcdir)
base_name = osp.join(srcdir, xrtQookPageName)
rst_name = base_name + '.rst'
# This is needed so users can type \\ on latex eqnarray envs inside raw
# docstrings
docstring = docstring.replace('\\\\', '\\\\\\\\')
# Add a class to several characters on the argspec. This way we can
# highlight them using css, in a similar way to what IPython does.
# NOTE: Before doing this, we escape common html chars so that they
# don't interfere with the rest of html present in the page
argspec = escape(context['argspec'])
for char in ['=', ',', '(', ')', '*', '**']:
argspec = argspec.replace(
char, '<span class="argspec-highlight">' + char + '</span>')
context['argspec'] = argspec
doc_file = codecs.open(rst_name, 'w', encoding='utf-8')
doc_file.write(docstring)
doc_file.close()
confoverrides = {'html_context': context,
'extensions': ['sphinx.ext.mathjax']}
doctreedir = osp.join(CONFDIR, 'doctrees')
sphinx_app = Sphinx(srcdir, CONFDIR, CONFDIR, doctreedir, buildername,
confoverrides, status=None, warning=None,
freshenv=True, warningiserror=False, tags=None)
try:
sphinx_app.build(None, [rst_name])
except SystemMessage:
pass
# output = ("It was not possible to generate rich text help for this "
# "object.</br>Please see it in plain text.")
示例11: run
# 需要導入模塊: from docutils import utils [as 別名]
# 或者: from docutils.utils import SystemMessage [as 別名]
def run(self):
try:
from sphinx.application import Sphinx
from docutils.utils import SystemMessage
except ImportError:
raise SystemExit('This command requires Sphinx to be installed.') from None
fix_docutils()
dest_dir = os.path.join(basedir, 'doc')
src_dir = os.path.join(basedir, 'rst')
confoverrides = {}
confoverrides['version'] = s3ql.VERSION
confoverrides['release'] = s3ql.RELEASE
for builder in ('html', 'latex', 'man'):
print('Running %s builder...' % builder)
self.mkpath(os.path.join(dest_dir, builder))
app = Sphinx(srcdir=src_dir, confdir=src_dir,
outdir=os.path.join(dest_dir, builder),
doctreedir=os.path.join(dest_dir, 'doctrees'),
buildername=builder, confoverrides=confoverrides,
freshenv=self.fresh_env)
self.fresh_env = False
self.all_files = False
try:
if self.all_files:
app.builder.build_all()
else:
app.builder.build_update()
except SystemMessage as err:
print('reST markup error:',
err.args[0].encode('ascii', 'backslashreplace'),
file=sys.stderr)
# These shouldn't be installed by default
for name in ('expire_backups.1', 'pcp.1'):
os.rename(os.path.join(dest_dir, 'man', name),
os.path.join(basedir, 'contrib', name))
print('Running pdflatex...')
for _ in range(3):
with open('/dev/null', 'wb') as null:
subprocess.check_call(['pdflatex', '-interaction', 'batchmode', 'manual.tex'],
cwd=os.path.join(dest_dir, 'latex'), stdout=null)
os.rename(os.path.join(dest_dir, 'latex', 'manual.pdf'),
os.path.join(dest_dir, 'manual.pdf'))