From: Yann E. MORIN <yann.morin.1998@free.fr>
To: buildroot@busybox.net
Subject: [Buildroot] [PATCH] Add agg (Anti-Grain Geometry) package
Date: Sun, 30 Mar 2014 19:07:04 +0200 [thread overview]
Message-ID: <20140330170704.GD3152@free.fr> (raw)
In-Reply-To: <533844F5.8010906@free.fr>
Julien, All,
On 2014-03-30 18:23 +0200, Julien Boibessot spake thusly:
> On 03/25/2014 11:37 PM, Arnout Vandecappelle wrote:
> > On 21/03/14 15:12, julien.boibessot at free.fr wrote:
> >> From: Julien Boibessot <julien.boibessot@armadeus.com>
> >>
> >> This library will be needed by gnash (soon coming Flash player).
> >>
> >> Signed-off-by: Julien Boibessot <julien.boibessot@armadeus.com>
> >> ---
> >> package/Config.in | 1 +
> >> package/agg/Config.in | 13 +++++++++++++
> >> package/agg/agg.mk | 40 ++++++++++++++++++++++++++++++++++++++++
> >> 3 files changed, 54 insertions(+), 0 deletions(-)
> >> create mode 100644 package/agg/Config.in
> >> create mode 100644 package/agg/agg.mk
> >>
> >> diff --git a/package/Config.in b/package/Config.in
> >> index 688ed4d..3b34a67 100644
> >> --- a/package/Config.in
> >> +++ b/package/Config.in
> >> @@ -556,6 +556,7 @@ source "package/lockdev/Config.in"
> >> endmenu
> >>
> >> menu "Graphics"
> >> +source "package/agg/Config.in"
> >> source "package/atk/Config.in"
> >> source "package/cairo/Config.in"
> >> source "package/fltk/Config.in"
> >> diff --git a/package/agg/Config.in b/package/agg/Config.in
> >> new file mode 100644
> >> index 0000000..a842098
> >> --- /dev/null
> >> +++ b/package/agg/Config.in
> >> @@ -0,0 +1,13 @@
> >> +config BR2_PACKAGE_AGG
> >> + bool "agg"
> >> + depends on BR2_INSTALL_LIBSTDCPP
> >> + select BR2_PACKAGE_SDL
> >> + help
> >> + The Anti-Grain Geometry project. A High Quality 2D Graphics Rendering
> >> + Engine for C++.
> >> + We select the SDL backend by default.
> >> +
> >> + http://www.antigrain.com/index.html
> >> +
> >> +comment "agg needs a toolchain with C++ support"
> >> + depends on !BR2_INSTALL_LIBSTDCPP
> >> diff --git a/package/agg/agg.mk b/package/agg/agg.mk
> >> new file mode 100644
> >> index 0000000..05be931
> >> --- /dev/null
> >> +++ b/package/agg/agg.mk
> >> @@ -0,0 +1,40 @@
> >> +###############################################################################
> >> +#
> >> +# agg
> >> +#
> >> +###############################################################################
> >> +
> >> +AGG_VERSION = 2.5
> >> +AGG_SITE = http://www.antigrain.com/
> >> +AGG_LICENSE = GPLv3+
> >> +AGG_LICENSE_FILES = COPYING
> >> +AGG_INSTALL_STAGING = YES
> >> +AGG_AUTORECONF = YES
> > Why is autoreconf needed? You take a release and don't have patches.
>
> there is no "configure" in sources, so I thought it was the way to
> regenerate it.
> Another way to do that ?
No, that's the correct way. However, just state so in a comment, like:
# No ./configure in the sources, we need to generate it:
AGG_AUTORECONF = YES
> >> +AGG_DEPENDENCIES = host-pkgconf sdl
> >> +
> >> +AGG_CONF_OPT = \
> >> + --with-sdl-prefix=$(STAGING_DIR)/usr \
> > Is this option really needed? It should be the default location for sdl...
>
> it seems mandatory, otherwise "configure" takes the Host installed SDL
> devt files in /usr/include/SDL/
Ditto, say so in a comment just above.
> >> + --disable-sdltest
> >> +
> >> +ifeq ($(BR2_PACKAGE_SDL_X11),)
> >> +AGG_CONF_OPT += \
> >> + --with-x=NO \
> >> + --disable-examples # examples require X11
> >> +endif
> >> +
> >> +ifeq ($(BR2_PACKAGE_FREETYPE),y)
> >> +AGG_DEPENDENCIES += freetype
> >> +AGG_CONF_OPT += --enable-freetype
> >> +else
> >> +AGG_CONF_OPT += --disable-freetype
> >> +endif
> >> +
> >> +define AGG_CREATE_MISSING_FILES
> >> + touch $(@D)/NEWS $(@D)/AUTHORS $(@D)/README
> >> +# Fixes reconfiguring with recent automake:
> >> + $(SED) 's/AM_C_PROTOTYPES//' $(@D)/configure.in
> >> +endef
> >> +AGG_POST_EXTRACT_HOOKS += AGG_CREATE_MISSING_FILES
> > If you don't autoreconf, this wouldn't be needed, right?
>
> maybe, but I don't know how to bypass autoreconf :-)
> I could call agg's "autogen.sh" but Buildroot AUTORECONF is doing the
> same no ?
In fact, there is a better way yet: add a patch to configure or
Makefile.am that adds the 'foreign' option to automake, which tells
the autotools that those files are not needed. Similar to what is
done for libfcgi (search for 'foreign'):
package/libfcgi/libfcgi-make-autoreconfable.patch
With foreign, those files are not needed, so you can just use
AGG_AUTORECONF = YES without the need to create the files.
And then, push that patch upstream, if possible. ;-)
Regards,
Yann E. MORIN.
--
.-----------------.--------------------.------------------.--------------------.
| Yann E. MORIN | Real-Time Embedded | /"\ ASCII RIBBON | Erics' conspiracy: |
| +33 662 376 056 | Software Designer | \ / CAMPAIGN | ___ |
| +33 223 225 172 `------------.-------: X AGAINST | \e/ There is no |
| http://ymorin.is-a-geek.org/ | _/*\_ | / \ HTML MAIL | v conspiracy. |
'------------------------------^-------^------------------^--------------------'
next prev parent reply other threads:[~2014-03-30 17:07 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-03-21 14:12 [Buildroot] [PATCH] Add agg (Anti-Grain Geometry) package julien.boibessot at free.fr
2014-03-25 22:37 ` Arnout Vandecappelle
2014-03-30 16:23 ` Julien Boibessot
2014-03-30 17:07 ` Yann E. MORIN [this message]
2014-03-30 17:21 ` Yann E. MORIN
2014-04-20 9:39 ` Thomas Petazzoni
2014-04-23 10:05 ` Julien Boibessot
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=20140330170704.GD3152@free.fr \
--to=yann.morin.1998@free.fr \
--cc=buildroot@busybox.net \
/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