-
-
Notifications
You must be signed in to change notification settings - Fork 7.9k
Plot directive preserve #10149
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Plot directive preserve #10149
Conversation
👍 in principle, but the docs need to build cleanly! |
@@ -656,6 +674,9 @@ def render_figures(code, code_path, output_dir, output_base, context, | |||
for format, dpi in formats: | |||
try: | |||
figman.canvas.figure.savefig(img.filename(format), dpi=dpi) | |||
if config.plot_preserve_dir and outname: | |||
print("Preserving '{0}' into '{1}'".format(img.filename(format), config.plot_preserve_dir)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not reviewing, but I don't think you want print
in here do you? I'd do _log.info
or _log.debug
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, that's probably what I want, but I didn't know about them. I'll update.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually, I don't see _log
as a variable in the plot_directive.py
namespace, so I'm not sure how to make that adjustment.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If its not already in this module, then up at the top:
# ... other imports
import logging
# ... other imports
_log = logging.getLogger(__name__)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks: got that up.
Eliminated some spaces |
@r-barnes sorry this didn't get a second review yet. If you give it a rebase and ping me I'll give it a quick look and merge on the basis of @tacaswell 's approval. We are about to branch 3.2, so it'd be nice to get this in |
Wouldn't |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mostly the indentation needs to be fixed.
@r-barnes I am going to do the rebase and force-push to your branch
if config.plot_preserve_dir and outname: | ||
outfiles = glob.glob(os.path.join(config.plot_preserve_dir, outname) + '*') | ||
for of in outfiles: | ||
_log.info("Copying preserved copy of '{0}' into '{1}'".format(of, build_dir)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we are py36+ so we can use f-strings 😄
e222429
to
e238368
Compare
sorry, I read the year when this was opened wrong and thought it was from this January, not from 2 years ago. |
I did the re-base and added the leading spaces
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
modulo tests passing
e9fe4f7
to
725f25d
Compare
2c10b86
to
134aaf9
Compare
I took the liberty of pushing an update to fix the doc issues. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Needs a rebase on master. Then move whats new entry to our new whats new scheme.
@@ -519,7 +548,7 @@ def get_plot_formats(config): | |||
|
|||
def render_figures(code, code_path, output_dir, output_base, context, | |||
function_name, config, context_reset=False, | |||
close_figs=False): | |||
close_figs=False, outname=''): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would go with outname=None
, which is IMHO a more standard way for "not defined" than an empty string.
@@ -0,0 +1,61 @@ | |||
Plot Directive `outname` and `plot_preserve_dir` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I propose to rename plot_preserve_dir
to plot_cache_dir
.
See #25091 (comment) for context on closing. |
PR Summary
The Sphinx plot directive can be used to automagically generate figures for documentation like so:
But, if you reorder the figures in the documentation then all the figures may need to be rebuilt. This takes time. The names given to the figures are also fairly meaningless, making them more difficult to index by search engines or to find on a filesystem.
Alternatively, if you are compiling on a limited-resource service like ReadTheDocs, you may wish to build imagery locally to avoid hitting resource limits on the server. Using the new changes allows extensive dynamically generated imagery to be used on services like ReadTheDocs.
The
:outname:
propertyThese problems are addressed through two new features in the plot directive. The first is the introduction of the
:outname:
property. It is used like so:Without
:outname:
, the figure generated above would normally be called, e.g.docfile3-4-01.png
or something equally mysterious. With:outname:
the figure generated will instead be namedstinkbug_plot-01.png
or evenstinkbug_plot.png
. This makes it easy to understand which output image is which and, more importantly, uniquely keys output images to code snippets.The
plot_preserve_dir
configuration valueSetting the
plot_preserve_dir
configuration value to the name of a directory will cause all images with:outname:
set to be copied to this directory upon generation.If an image is already in
plot_preserve_dir
when documentation is being generated, this image is copied to the build directory thereby pre-empting generation and reducing computation time in low-resource environments.Related issues were raised on ReadTheDocs (link) and on StackOverflow (link).
PR Checklist