Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!
Bug 643184 - net-misc/curl: support brotli
Summary: net-misc/curl: support brotli
Status: RESOLVED FIXED
Alias: None
Product: Gentoo Linux
Classification: Unclassified
Component: Current packages (show other bugs)
Hardware: All Linux
: Normal normal
Assignee: Anthony Basile
URL: https://daniel.haxx.se/blog/2017/11/2...
Whiteboard:
Keywords:
Depends on: 643182
Blocks:
  Show dependency tree
 
Reported: 2018-01-02 20:29 UTC by Craig Andrews
Modified: 2018-01-16 21:58 UTC (History)
2 users (show)

See Also:
Package list:
Runtime testing required: ---


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Craig Andrews gentoo-dev 2018-01-02 20:29:22 UTC
Curl 7.57.0 support brotli compression: https://daniel.haxx.se/blog/2017/11/29/curl-7-57-0-happiness/
Comment 1 Anthony Basile gentoo-dev 2018-01-03 01:20:30 UTC
I tried with the ebuild in https://github.com/gentoo/gentoo/pull/6723 - its straight forward and correct, but I hit the following error:

make[1]: Entering directory '/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0-abi_x86_32.x86/lib'
make  all-am
make[2]: Entering directory '/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0-abi_x86_32.x86/lib'
/bin/sh ../libtool  --tag=CC   --mode=compile x86_64-pc-linux-gnu-gcc -m32 -DHAVE_CONFIG_H   -I/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/include -I../lib -I/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib  -DBUILDING_LIBCURL  -DCURL_HIDDEN_SYMBOLS -I/usr/include/nss -I/usr/include/nspr -I/usr/include/p11-kit-1   -fvisibility=hidden -O2 -pipe -Werror-implicit-function-declaration -pthread  -c -o libcurl_la-content_encoding.lo `test -f 'content_encoding.c' || echo '/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib/'`content_encoding.c
libtool: compile:  x86_64-pc-linux-gnu-gcc -m32 -DHAVE_CONFIG_H -I/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/include -I../lib -I/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib -DBUILDING_LIBCURL -DCURL_HIDDEN_SYMBOLS -I/usr/include/nss -I/usr/include/nspr -I/usr/include/p11-kit-1 -fvisibility=hidden -O2 -pipe -Werror-implicit-function-declaration -pthread -c /var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib/content_encoding.c  -fPIC -DPIC -o .libs/libcurl_la-content_encoding.o
/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib/content_encoding.c: In function ‘brotli_map_error’:
/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib/content_encoding.c:549:8: error: ‘BROTLI_DECODER_ERROR_COMPOUND_DICTIONARY’ undeclared (first use in this function)
   case BROTLI_DECODER_ERROR_COMPOUND_DICTIONARY:
        ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib/content_encoding.c:549:8: note: each undeclared identifier is reported only once for each function it appears in
/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0/lib/content_encoding.c:550:8: error: ‘BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET’ undeclared (first use in this function)
   case BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET:
        ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
make[2]: *** [Makefile:1508: libcurl_la-content_encoding.lo] Error 1
make[2]: Leaving directory '/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0-abi_x86_32.x86/lib'
make[1]: *** [Makefile:734: all] Error 2
make[1]: Leaving directory '/var/tmp/portage/net-misc/curl-7.57.0-r1/work/curl-7.57.0-abi_x86_32.x86/lib'
make: *** [Makefile:906: all-recursive] Error 1
Comment 2 Craig Andrews gentoo-dev 2018-01-03 01:36:47 UTC
What version of app-arch/brotli are you using? If it's not 1.0.2, can you please try with 1.0.2? (I successfully tested curl with that version earlier today)
Comment 3 Anthony Basile gentoo-dev 2018-01-03 09:15:30 UTC
(In reply to Craig Andrews from comment #2)
> What version of app-arch/brotli are you using? If it's not 1.0.2, can you
> please try with 1.0.2? (I successfully tested curl with that version earlier
> today)

ah it was just added to the tree.  i hadn't sync-ed yet.(In reply to Craig Andrews from comment #2)
> What version of app-arch/brotli are you using? If it's not 1.0.2, can you
> please try with 1.0.2? (I successfully tested curl with that version earlier
> today)

okay it works with 1.0.2 so you need to change the dependency to

brotli? ( >=app-arch/brotli-1.0.2:0= )

Also, brotli is only keyworded as follows

         |                                 |   u         |  
         | a a         p   a     n r     s |   n         |  
         | l m   h i   p   r m m i i s   p | e u s       | r
         | p d a p a p c x m i 6 o s 3   a | a s l       | e
         | h 6 r p 6 p 6 8 6 p 8 s c 9 s r | p e o       | p
         | a 4 m a 4 c 4 6 4 s k 2 v 0 h c | i d t       | o
---------+---------------------------------+-------------+-------
   0.6.0 | o ~ o o o o o ~ o o o o o o o o | 6 o 0/0.6.0 | gentoo
---------+---------------------------------+-------------+-------
[I]1.0.2 | o ~ o o o o o ~ o o o o o o o o | 6 o 0/1.0.2 | gentoo
---------+---------------------------------+-------------+-------
    9999 | o o o o o o o o o o o o o o o o | 6 o 0/9999  | gentoo



while curl is keyworded as


Keywords for net-misc/curl:
          |                                 |   u   |  
          | a a         p   a     n r     s |   n   |  
          | l m   h i   p   r m m i i s   p | e u s | r
          | p d a p a p c x m i 6 o s 3   a | a s l | e
          | h 6 r p 6 p 6 8 6 p 8 s c 9 s r | p e o | p
          | a 4 m a 4 c 4 6 4 s k 2 v 0 h c | i d t | o
----------+---------------------------------+-------+-------
[I]7.57.0 | + + + + + + + + ~ ~ ~ o o ~ ~ + | 6 o 0 | gentoo



So please get brotli keyworded up to curl and then submit a patch.
Comment 4 Anthony Basile gentoo-dev 2018-01-03 09:17:11 UTC
> 
> 
> So please get brotli keyworded up to curl and then submit a patch.

alternatively we could mask brotli on certain untested arches, but that's less desirable.
Comment 5 Craig Andrews gentoo-dev 2018-01-03 17:57:44 UTC
There's already an app-arch/brotli keyword request bug, and it's marked as a dependency of this one (if you have any of those arches and can provide any of those keywords, that would be quite awesome!): bug 643182

Instead of >=app-arch/brotli-1.0.2:0=, the old version was simply dropped: https://github.com/gentoo/gentoo/commit/747fdfc3170b5bbd2ddd0093c91c3770d14cb846
Comment 6 Larry the Git Cow gentoo-dev 2018-01-16 21:58:47 UTC
The bug has been closed via the following commit(s):

https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c868aeea7a0f517f66a30e3036e65711fe4bec0e

commit c868aeea7a0f517f66a30e3036e65711fe4bec0e
Author:     Craig Andrews <candrews@gentoo.org>
AuthorDate: 2018-01-02 20:37:02 +0000
Commit:     Anthony G. Basile <blueness@gentoo.org>
CommitDate: 2018-01-16 21:54:30 +0000

    net-misc/curl: add support for brotli
    
    Closes: https://bugs.gentoo.org/643184
    
    Package-Manager: Portage-2.3.19, Repoman-2.3.6
    
    Signed-off-by: Anthony G. Basile <blueness@gentoo.org>

 net-misc/curl/curl-7.57.0-r1.ebuild | 249 ++++++++++++++++++++++++++++++++++++
 net-misc/curl/metadata.xml          |   1 +
 2 files changed, 250 insertions(+)