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

emsdk compile error: typedef redefinition with different types #631

Closed
linuxaged opened this issue Dec 6, 2023 · 5 comments
Closed

emsdk compile error: typedef redefinition with different types #631

linuxaged opened this issue Dec 6, 2023 · 5 comments

Comments

@linuxaged
Copy link
Contributor

emsdk version 3.1.50

C:\workspace\emsdk\upstream\emscripten\cache\sysroot/include\emscripten/html5_webgl.h:17:18: error: typedef redefinition with different types ('intptr_t' (aka 'long') vs 'int')
   17 | typedef intptr_t EMSCRIPTEN_WEBGL_CONTEXT_HANDLE;
      |                  ^
C:/workspace/BonViewer/magnum/src/Magnum/Platform\EmscriptenApplication.h:65:13: note: previous definition is here
   65 | typedef int EMSCRIPTEN_WEBGL_CONTEXT_HANDLE;
      |             ^
1 error generated
@mosra
Copy link
Owner

mosra commented Dec 6, 2023

This changed in 3.1.49 and I already have a fix pending (8048b65, in the next branch), unfortunately on ArchLinux I still only have 3.1.48 in the repos so I can't easily test myself.

Is it possible for you to try with the next branch and confirm that the fix works? If you confirm, I'll push that commit to master. Thank you! :)

@mosra mosra added this to the 2023.0a milestone Dec 6, 2023
@linuxaged
Copy link
Contributor Author

try next branch and get the Configuring error:

C:\workspace\BonViewer\build-emscripten>cmake .. -G Ninja ^
More? -DCMAKE_MAKE_PROGRAM="C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\CommonExtensions\Microsoft\CMake\Ninja\ninja.exe" ^
More? -DCMAKE_TOOLCHAIN_FILE="../toolchains/generic/Emscripten-wasm.cmake" ^
More? -DCMAKE_BUILD_TYPE=Release ^
More? -DWITH_EMSCRIPTENAPPLICATION=ON ^
More? -DTARGET_GLES2=OFF ^
More? -DWITH_STBIMAGEIMPORTER=ON ^
More? -DWITH_IMGUI=ON ^
More? -DIMGUI_DIR="C:/workspace/imgui" ^
More? -DEMSCRIPTEN_PREFIX="C:/workspace/emsdk/upstream/emscripten" ^
More? -DMAGNUM_DEPLOY_PREFIX="C:/http/magnum" ^
More? -DCMAKE_FIND_ROOT_PATH="C:/lib/emscripten/system"
-- The C compiler identification is Clang 18.0.0
-- The CXX compiler identification is Clang 18.0.0
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Check for working C compiler: C:/workspace/emsdk/upstream/emscripten/emcc.bat - skipped
-- Detecting C compile features
-- Detecting C compile features - done
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Check for working CXX compiler: C:/workspace/emsdk/upstream/emscripten/em++.bat - skipped
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- The LIB_SUFFIX variable is not defined. It will be autodetected now.
-- You can set it manually with -DLIB_SUFFIX=<value> (64 for example).
-- LIB_SUFFIX autodetected as '', libraries will be installed into C:/Program Files (x86)/BonViewer/lib
-- Found Git: C:/Program Files/Git/cmd/git.exe (found version "2.41.0.windows.1")
-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility
-- Found OpenGLES3: GL
CMake Error at magnum/src/Magnum/Platform/CMakeLists.txt:204 (message):
  Emscripten 1.39.5+, which enables
  DISABLE_DEPRECATED_FIND_EVENT_TARGET_BEHAVIOR by default, is required to
  build EmscriptenApplication and Sdl2Application.  Found version .


-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility Main TestSuite
-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility PluginManager
-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility
-- Found Magnum: C:/workspace/BonViewer/magnum/src
-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility PluginManager
-- Found Magnum: C:/workspace/BonViewer/magnum/src  found components: Trade
CMake Warning (dev) at C:/Program Files/CMake/share/cmake-3.28/Modules/GNUInstallDirs.cmake:243 (message):
  Unable to determine default CMAKE_INSTALL_LIBDIR directory because no
  target architecture is known.  Please enable at least one language before
  including GNUInstallDirs.
Call Stack (most recent call first):
  fmt/CMakeLists.txt:67 (include)
This warning is for project developers.  Use -Wno-dev to suppress it.

-- Module support is disabled.
-- Version: 9.1.0
-- Build type: Release
-- CXX_STANDARD: 20
-- Performing Test has_std_20_flag
-- Performing Test has_std_20_flag - Success
-- Performing Test has_std_2a_flag
-- Performing Test has_std_2a_flag - Success
-- Required features: cxx_variadic_templates
-- Performing Test HAS_NULLPTR_WARNING
-- Performing Test HAS_NULLPTR_WARNING - Success
CMAKE_PREFIX_PATH:
-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility Main
-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility PluginManager
-- Found Magnum: C:/workspace/BonViewer/magnum/src  found components: Trade GL MeshTools Primitives SceneGraph Shaders
-- Found Corrade: C:/workspace/BonViewer/corrade/src  found components: Containers rc Utility
-- Found Magnum: C:/workspace/BonViewer/magnum/src  found components: GL EmscriptenApplication
-- Configuring incomplete, errors occurred!

@mosra
Copy link
Owner

mosra commented Dec 8, 2023

Is your toolchains submodule up-to-date? There were recent changes to it (querying the Emscripten version, etc) and the Found version . error happens if it's not updated.

@mosra
Copy link
Owner

mosra commented Dec 8, 2023

I got 3.1.50 in Arch repos today, and can confirm the patch from 8048b65 works. So it's in master now.

If you still have issues, comment here or just pop in the chat :)

@pezcode
Copy link
Contributor

pezcode commented Sep 23, 2024

The typedef got changed again in 3.1.54: emscripten-core/emscripten#21281

Oops, I was looking at an old version of Magnum we're using locally. It's already fixed in master 👍 Sorry for the noise

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Development

No branches or pull requests

3 participants