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

Add c-blosc to gdal recipe #60

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open

Conversation

ateucher
Copy link

@ateucher ateucher commented Dec 12, 2024

I successfully built the c-blosc recipe with ./build.sh c-blosc. I tried to build gdal, but it failed with errors:

clang++: error: linker command failed with exit code 1 (use -v to see invocation)
ld: warning: -bind_at_load is deprecated on macOS
ld: warning: ignoring duplicate libraries: '-lc++'
make: *** [gdalenhance] Error 1
Undefined symbols for architecture arm64:
  "_iconv", referenced from:
      _common_open in libfreexl.a[2](freexl.o)
      _get_workbook_stream in libfreexl.a[2](freexl.o)
      _convert_to_utf8 in libfreexl.a[2](freexl.o)
      _parse_SST in libfreexl.a[2](freexl.o)
      _parse_unicode_string in libfreexl.a[2](freexl.o)
      _ansi_to_unicode_copy in libodbc.a[121](__info.o)
      _unicode_to_ansi_copy in libodbc.a[121](__info.o)
      ...
  "_iconv_close", referenced from:
      _destroy_workbook in libfreexl.a[2](freexl.o)
      _destroy_workbook in libfreexl.a[2](freexl.o)
      _biff_set_utf8_converter in libfreexl.a[2](freexl.o)
      _search_for_pool in libodbc.a[19](SQLConnect.o)
      _search_for_pool in libodbc.a[19](SQLConnect.o)
      _unicode_setup in libodbc.a[121](__info.o)
      _unicode_setup in libodbc.a[121](__info.o)
      ...
  "_iconv_open", referenced from:
      _common_open in libfreexl.a[2](freexl.o)
      _biff_set_utf8_converter in libfreexl.a[2](freexl.o)
      _unicode_setup in libodbc.a[121](__info.o)
      _unicode_setup in libodbc.a[121](__info.o)
      _unicode_setup in libodbc.a[121](__info.o)
      _unicode_setup in libodbc.a[121](__info.o)
ld: symbol(s) not found for architecture arm64
clang++: error: linker command failed with exit code 1 (use -v to see invocation)
make: *** [gdaltransform] Error 1
make: *** [apps-target] Error 2
make: *** [gdal-3.5.3-dst] Error 2

I am pretty sure those errors are unrelated to c-blosc, and it looks like blosc was included in the previous build steps while building gdal.

(Maybe?) closes #59

@s-u
Copy link
Member

s-u commented Jan 2, 2025

@ateucher Unfortunately, c-blosc's build system is broken. It ignores -DBUILD_SHARED_LIBS=OFF and when their own -DBUILD_SHARED=OFF is used instead it fails:

[...]
-- Build files have been written to: /Volumes/Builds/recipes/build/c-blosc-1.21.6-obj
+ set +x
Makefile generated.
[...]
/Volumes/Builds/recipes/build/src/c-blosc-1.21.6/compat/filegen.c:13:10: fatal error: 'blosc.h' file not found
#include <blosc.h>
         ^~~~~~~~~
1 error generated.
make: *** [compat/CMakeFiles/filegen.dir/filegen.c.o] Error 1
make: *** [compat/CMakeFiles/filegen.dir/all] Error 2
make: *** Waiting for unfinished jobs....

Please have it fixed upstream so it can be built statically since dynamic build won't work. Ideally, they should respect standard cmake flags which are:
-DCMAKE_BUILD_TYPE=Release -DBUILD_SHARED_LIBS:bool=OFF -DCMAKE_POSITION_INDEPENDENT_CODE:bool=ON

@ateucher
Copy link
Author

ateucher commented Jan 6, 2025

Thanks @s-u. I get the same error when specifying -DBUILD_SHARED=OFF, however the build system by default builds both static and dynamic versions of c-blosc. Is there a way to point gdal to use libblosc.a, which is built during default build?

(apologies, this is new territory for me)

@s-u
Copy link
Member

s-u commented Jan 16, 2025

Possibly via Distribution-files:, although I'd like to test if first, because if their build system is so broken I don't really trust the product.

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

Successfully merging this pull request may close these issues.

blosc missing from gdal build Depends
2 participants