From: Martin Jansa <martin.jansa@gmail.com>
To: openembedded-core@lists.openembedded.org
Subject: Re: [PATCHv2] fontcache: allow to pass extra parameters and environment to fc-cache
Date: Wed, 14 Oct 2015 16:37:51 +0200 [thread overview]
Message-ID: <20151014143751.GD22448@jama> (raw)
In-Reply-To: <20150929155055.GA14440@jama>
[-- Attachment #1: Type: text/plain, Size: 4020 bytes --]
On Tue, Sep 29, 2015 at 05:50:55PM +0200, Martin Jansa wrote:
> On Thu, Sep 10, 2015 at 04:31:26PM +0200, Martin Jansa wrote:
> > * this can be useful for passing extra parameters, pass
> > -v by default to see what's going on in do_rootfs
> > * we need to use this for extra parameter we implemented
> > in fontconfig:
> > --ignore-mtime always use cache file regardless of font directory mtime
> > because the checksum of fontcache generated in do_rootfs
> > doesn't match with /usr/share/fonts directory as seen on
> > target device causing fontconfig to re-create the cache
> > when fontconfig is used for first time or worse create
> > new cache in every user's home directory when /usr/
> > filesystem is read only and cache cannot be updated.
> >
> > Running FC_DEBUG=16 fc-cache -v on such device shows:
> > FcCacheTimeValid dir "/usr/share/fonts" cache checksum 1441207803 dir checksum 1441206149
> > * my guess is that the checksum is different, because pseudo
> > (which is unloaded when running qemuwrapper) or because some
> > influence of running the rootfs under qemu.
>
> ping
>
> was this postponed to 2.0? Any feedback would be nice.
>
> But thanks for applying the other 2, now we were able to implement this in our
> layer with overlayed fontcache.bbclass and intercepts scripts.
ping2
> > Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
> > ---
> > meta/classes/fontcache.bbclass | 19 +++++++++++++++----
> > scripts/postinst-intercepts/update_font_cache | 4 ++--
> > 2 files changed, 17 insertions(+), 6 deletions(-)
> >
> > diff --git a/meta/classes/fontcache.bbclass b/meta/classes/fontcache.bbclass
> > index d122387..8ebdfc4 100644
> > --- a/meta/classes/fontcache.bbclass
> > +++ b/meta/classes/fontcache.bbclass
> > @@ -9,12 +9,23 @@ inherit qemu
> > FONT_PACKAGES ??= "${PN}"
> > FONT_EXTRA_RDEPENDS ?= "fontconfig-utils"
> > FONTCONFIG_CACHE_DIR ?= "${localstatedir}/cache/fontconfig"
> > +FONTCONFIG_CACHE_PARAMS ?= "-v"
> > +# You can change this to e.g. FC_DEBUG=16 to debug fc-cache issues,
> > +# something has to be set, because qemuwrapper is using this variable after -E
> > +# multiple variables aren't allowed because for qemu they are separated
> > +# by comma and in -n "$D" case they should be separated by space
> > +FONTCONFIG_CACHE_ENV ?= "FC_DEBUG=1"
> > fontcache_common() {
> > -if [ "x$D" != "x" ] ; then
> > - $INTERCEPT_DIR/postinst_intercept update_font_cache ${PKG} mlprefix=${MLPREFIX} bindir=${bindir} \
> > - libdir=${libdir} base_libdir=${base_libdir} fontconfigcachedir=${FONTCONFIG_CACHE_DIR}
> > +if [ -n "$D" ] ; then
> > + $INTERCEPT_DIR/postinst_intercept update_font_cache ${PKG} mlprefix=${MLPREFIX} \
> > + 'bindir="${bindir}"' \
> > + 'libdir="${libdir}"' \
> > + 'base_libdir="${base_libdir}"' \
> > + 'fontconfigcachedir="${FONTCONFIG_CACHE_DIR}"' \
> > + 'fontconfigcacheparams="${FONTCONFIG_CACHE_PARAMS}"' \
> > + 'fontconfigcacheenv="${FONTCONFIG_CACHE_ENV}"'
> > else
> > - fc-cache
> > + ${FONTCONFIG_CACHE_ENV} fc-cache ${FONTCONFIG_CACHE_PARAMS}
> > fi
> > }
> >
> > diff --git a/scripts/postinst-intercepts/update_font_cache b/scripts/postinst-intercepts/update_font_cache
> > index c8c6018..0deab3c 100644
> > --- a/scripts/postinst-intercepts/update_font_cache
> > +++ b/scripts/postinst-intercepts/update_font_cache
> > @@ -1,5 +1,5 @@
> > #!/bin/sh
> >
> > -PSEUDO_UNLOAD=1 qemuwrapper -L $D -E LD_LIBRARY_PATH=$D/${libdir}:$D/${base_libdir}\
> > - $D${bindir}/fc-cache --sysroot=$D
> > +PSEUDO_UNLOAD=1 qemuwrapper -L $D -E LD_LIBRARY_PATH=$D/${libdir}:$D/${base_libdir} \
> > + -E ${fontconfigcacheenv} $D${bindir}/fc-cache --sysroot=$D ${fontconfigcacheparams}
> > chown -R root:root $D${fontconfigcachedir}
> > --
> > 2.5.1
> >
>
> --
> Martin 'JaMa' Jansa jabber: Martin.Jansa@gmail.com
--
Martin 'JaMa' Jansa jabber: Martin.Jansa@gmail.com
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 188 bytes --]
next prev parent reply other threads:[~2015-10-14 14:37 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-09-04 12:22 [RFC][PATCH 1/3] rootfs.py: Allow to override postinst-intercepts location Martin Jansa
2015-09-04 12:22 ` [RFC][PATCH 2/3] postinst_intercept: allow to pass variables with spaces Martin Jansa
2015-09-04 12:22 ` [RFC][PATCH 3/3] fontcache: allow to pass extra parameters and environment to fc-cache Martin Jansa
2015-09-10 14:31 ` [PATCHv2] " Martin Jansa
2015-09-29 15:50 ` Martin Jansa
2015-10-14 14:37 ` Martin Jansa [this message]
2015-09-04 12:27 ` [RFC][dizzy][fido][master][PATCH 1/3] rootfs.py: Allow to override postinst-intercepts location Martin Jansa
2015-09-10 16:07 ` akuster808
2015-09-04 18:56 ` [RFC][PATCH] rootfs.py: show intercept script output in log.do_rootfs Martin Jansa
2015-09-15 16:04 ` [RFC][PATCH 1/3] rootfs.py: Allow to override postinst-intercepts location Joshua Lock
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20151014143751.GD22448@jama \
--to=martin.jansa@gmail.com \
--cc=openembedded-core@lists.openembedded.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox