Sphinx Application Documentation - Image duplication
Eugen Mohr
eugen.mohr at gmx.net
Sun Jan 22 19:45:47 GMT 2023
Hi Julius
Maybe we should do the opposite of this:
https://github.com/sphinx-doc/sphinx/issues/9758 and this:
https://stackoverflow.com/questions/39008064/how-to-customize-sphinx-doc-images-folder
The language-specific figures/images are set here:
https://www.sphinx-doc.org/en/master/usage/configuration.html#confval-figure_language_filename
-> can we switch this off / do the opposite?
Eugen
Am 22.01.2023 um 20:23 schrieb Julius Künzel:
> Hi Ben,
>
> yes, that seems to be the most proper solution for me, and I think
> this should work
>
> Cheers,
> Julius
>
> 22. Januar 2023 um 20:02, "Ben Cooksley" <bcooksley at kde.org
> <mailto:bcooksley at kde.org?to=%22Ben%20Cooksley%22%20%3Cbcooksley%40kde.org%3E>>
> schrieb:
>
> On Mon, Jan 23, 2023 at 7:51 AM Julius Künzel
> <jk.kdedev at smartlab.uber.space> wrote:
>
> Hi Ben, hi all,
>
>
> Hi Julius,
>
>
> I did a little research about this recently and unfortunately
> it seems to me as if there is not really a solution on the
> Sphinx side. One need to have separate build dirs for every
> language and it copies all static files (css, js, images,..)
> to every build dir. That's just how it works :-/ (Correct me
> in case anyone knows I am wrong).
> However we can of course try to solve this on our and and make
> our deploy tools smart in a way that they keep only one
> version of each image file and replace the others with symlinks.
> It should be more or less easy to detect images that are
> translated since they follow the pattern |filename.de.png
> where "de" is the language code, so this image would be
> special for German, while for all other languages filename.png
> is used.|
>
>
> I had a very strong feeling that would be the case (very much
> seems that Sphinx actually doesn't have proper i18n/l10n support
> and it's been hacked in / bolted on later).
>
> My initial thinking on a quick and (somewhat) dirty solution to
> this had been to merge all of the image files into a single folder
> at top level and then symlink that from each language.
> Knowing that translated images actually have a separate filename
> convention indicates that this might just be crazy enough to work.
>
> Thoughts?
>
>
> I hope that helps so far. I might be able to look into this,
> but probably not very soon so if anybody else can work on this
> I am more than happy.
>
> Cheers,
> Julius
>
>
> Regards,
> Ben
>
>
> ||
>
> 15. Januar 2023 um 07:45, "Ben Cooksley" <bcooksley at kde.org
> <mailto:bcooksley at kde.org?to=%22Ben%20Cooksley%22%20%3Cbcooksley%40kde.org%3E>>
> schrieb:
>
> Hi all,
>
> For some time now it has been known to me that the system
> for generating application documentation websites using
> Sphinx with l10n support has had issues with duplicating
> data - particularly images.
>
> That leads to the following outcome, where aside from
> sites that we expect to be quite large (like www.kde.org
> <http://www.kde.org/> and api.kde.org
> <http://api.kde.org/>) all of the application
> documentation sites are quite big as well:
>
> root at nicoda /srv/www # du -h --max-depth=1 ./generated/ |
> grep G
> 2.3G ./generated/cutehmi.kde.org <http://cutehmi.kde.org/>
> 3.7G ./generated/docs.digikam.org
> <http://docs.digikam.org/>
> 2.4G ./generated/api.kde.org <http://api.kde.org/>
> 2.3G ./generated/docs.krita.org <http://docs.krita.org/>
> 1.4G ./generated/www.kde.org <http://www.kde.org/>
> 7.9G ./generated/docs.kdenlive.org
> <http://docs.kdenlive.org/>
> 29G ./generated/
>
> This stands in comparison to the Docbook documentation
> site for all other KDE applications:
>
> root at nicoda /srv/www # du -h --max-depth=1 . | grep G
> 29G ./generated
> 16G ./api.kde.org-legacy
> 6.0G ./docs.kde.org <http://docs.kde.org/>
> 51G .
>
> It would be nice if we could please look into some fixes
> for this, as it looks like Sphinx is duplicating the
> images - once for every language - when that isn't necessary.
> I could understand if the screenshots were updated as part
> of the translation, but it looks like they're not in the
> majority of cases - below being just a sample:
>
> root at nicoda /srv/www/generated/docs.krita.org
> <http://docs.krita.org/> # sha256sum
> zh_CN/_images/Krita_cpb_mixing.gif
> 12eb4cbad29a5a6486d3438dabb888a0aa0b9579e55b3be2f3c1d6e1d76fc1d7
> zh_CN/_images/Krita_cpb_mixing.gif
> root at nicoda /srv/www/generated/docs.krita.org
> <http://docs.krita.org/> # sha256sum
> en/_images/Krita_cpb_mixing.gif
> 12eb4cbad29a5a6486d3438dabb888a0aa0b9579e55b3be2f3c1d6e1d76fc1d7
> en/_images/Krita_cpb_mixing.gif
>
> While this isn't a massive issue right now, it is a future
> scalability issue as for Krita at least each language
> costs 178MB or so, while for Digikam that sits at 415MB
> per language and Kdenlive is 392MB.
>
> Many thanks,
> Ben
>
>
>
> Julius Künzel
> Volunteer KDE Developer, mainly hacking Kdenlive
> KDE GitLab: https://my.kde.org/user/jlskuz/
> Matrix: @jlskuz:kde.org <http://kde.org/>
>
>
>
> Julius Künzel
> Volunteer KDE Developer, mainly hacking Kdenlive
> KDE GitLab: https://my.kde.org/user/jlskuz/
> Matrix: @jlskuz:kde.org
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/digikam-devel/attachments/20230122/b99b5611/attachment-0001.htm>
More information about the Digikam-devel
mailing list