Skip to content
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

More fonts are needed to avoid breaking rendering #49

Closed
lissyx opened this issue Jul 21, 2022 · 12 comments
Closed

More fonts are needed to avoid breaking rendering #49

lissyx opened this issue Jul 21, 2022 · 12 comments

Comments

@lissyx
Copy link

lissyx commented Jul 21, 2022

As documented on https://bugzilla.mozilla.org/show_bug.cgi?id=1767925 the fontconfig is missing some bits. This results in Firefox Snap package showing poor rendering both of webpages as well as PDF documents.

Copying everything using the following ensures the same rendering on both sides:

mkdir ~/snap/firefox/current/.config/fontconfig/conf.d; cp /etc/fonts/conf.d/* ~/snap/firefox/current/.config/fontconfig/conf.d

Screenshot_ubuntu22 04_2022-07-05_16:08:03

@lissyx
Copy link
Author

lissyx commented Jul 21, 2022

Screenshot_ubuntu22 04_2022-07-21_16:17:17

@seb128
Copy link
Contributor

seb128 commented Jul 21, 2022

so the issue there is that some of the /etc/fonts/conf.d files are not available in the snap, the directory has some entries which symlinks to ../conf.avail, which are there in the snap but some other are pointing to /usr, example

/etc/fonts/conf.d/61-urw-nimbus-roman.conf -> /usr/share/fontconfig/conf.avail/urw-nimbus-roman.conf

could snapd perhaps make /usr/share/fontconfig/conf.avail/ also available in the snap env?

@seb128
Copy link
Contributor

seb128 commented Jul 22, 2022

I've also reported a snapd issue about it on https://bugs.launchpad.net/snapd/+bug/1982577

@lissyx
Copy link
Author

lissyx commented Jul 27, 2022

So what would be a legit fix, modifying the common/desktop-exports script to take into account more fonts, or fix snapd itself ?

@seb128
Copy link
Contributor

seb128 commented Jul 27, 2022

So what would be a legit fix, modifying the common/desktop-exports script to take into account more fonts, or fix snapd itself ?

Since snapd already gives access to the conf.d/conf.avail it would probably make sense to include now the new directory in /usr/share/fontconfig, the snapd team seemed ok on principle with a such change.

@jhenstridge
Copy link

We've avoided using the host system fontconfig configuration because it was prone to triggering incompatibilities. In particular, the config file parser treats any unknown element as a hard error.

This last popped up when fontconfig added <its:rules> elements to its default configuration file, which caused older libfontconfig versions to complain and fall back to their builtin configuration. There hasn't been any config file additions for quite a while, but we'd risk old snaps breaking should new syntax be introduced.

I think either of these options would be appropriate:

  1. include the URW fonts in the gnome platform snap
  2. include the fontconfig rules for the URW fonts in the gnome platform snap's fontconfig configuration, and hope that the URW fonts are available.

seb128 added a commit to seb128/gnome-sdk that referenced this issue Sep 1, 2022
We need at least the URW fonts configuration for correct PDF rendering as
reported against firefox on ubuntu#49

After discussion we decided to include the configurations provided in a
default Ubuntu desktop installation for 3.38. It's not ideal but should
help with consistency with non snaps apps and be an improvement.
Going forward we should work with fontconfig upstream on a solution
which allows use to import the system configuration instead.
@seb128
Copy link
Contributor

seb128 commented Sep 1, 2022

After discussion we decided to bundled the fonts configuration from a default installation which should give a consistent behaviour with non snapped applications, submitted for review as #72 now. Going forward we want to work with the fontconfig upstream in a way to tag the configuration version in a way which would allow us to import the compatible system configuration

@lissyx
Copy link
Author

lissyx commented Sep 1, 2022

Thanks @seb128 for #72. I see it has been merged, how long until it gets built and pushed to the Snap store? Can we close this issue ?

@seb128
Copy link
Contributor

seb128 commented Sep 1, 2022

Thanks @seb128 for #72. I see it has been merged, how long until it gets built and pushed to the Snap store? Can we close this issue ?

We should have a build in the candidate channel in some hours, then it takes usually a bit longer to validate those and move them to stable, probably next week since we usually avoid to push stable updates on a friday

@seb128
Copy link
Contributor

seb128 commented Sep 1, 2022

the new snap is available in candidate now

@lissyx
Copy link
Author

lissyx commented Sep 2, 2022

the new snap is available in candidate now

Thanks, I've been able to locally verify that it is properly the issue.

@lissyx lissyx closed this as completed Sep 2, 2022
@lissyx
Copy link
Author

lissyx commented Oct 24, 2022

seb128 added a commit to seb128/gnome-sdk that referenced this issue Jun 1, 2023
We need at least the URW fonts configuration for correct PDF rendering as
reported against firefox on ubuntu#49

After discussion we decided to include the configurations provided in a
default Ubuntu desktop installation for 42. It's not ideal but should
help with consistency with non snaps apps and be an improvement.
Going forward we should work with fontconfig upstream on a solution
which allows use to import the system configuration instead.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants