X-Git-Url: https://git.jankratochvil.net/?p=lldb-experimental.git;a=blobdiff_plain;f=lldb-experimental.spec;h=b6f451f66ea43e3045670b7826220094978c7695;hp=811b7ad36ec4534b36b2df30b3a96aae983c849c;hb=dff635ccb5ab12367ad54bef69253143b62abe9a;hpb=269800c0dc6c3dbf0fdd5cf93a06a36ca90b9ccd diff --git a/lldb-experimental.spec b/lldb-experimental.spec index 811b7ad..b6f451f 100644 --- a/lldb-experimental.spec +++ b/lldb-experimental.spec @@ -1,6 +1,7 @@ %global fast 0 %global use_jankratochvil_dwz 1 %global use_jankratochvil_uniqaddr 1 +%global use_jankratochvil_ocaml_doc 1 %global use_jankratochvil_rust 0 %global pkg_prefix /opt/%{name} %global _unpackaged_files_terminate_build 0 @@ -18,7 +19,7 @@ %endif Name: lldb-experimental Version: 13.0.0 -Release: 0.20210604snap3%{?dist} +Release: 0.20210619snap0%{?dist} Summary: Next generation high-performance debugger - experimental trunk snapshot License: NCSA URL: http://lldb.llvm.org/ @@ -29,6 +30,9 @@ Source0: empty.tar BuildRequires: clang git libedit-devel libatomic libxml2-devel zlib-devel valgrind-devel libpfm-devel # https://src.fedoraproject.org/rpms/epydoc #BuildRequires: epydoc +%if 0%{?rhel} > 8 || 0%{?fedora} >= 34 +BuildRequires: ocaml-findlib ocaml-ctypes ocaml-ocamldoc +%endif %if 0%{?rhel:1} && 0%{?rhel} <= 7 #+ /usr/lib/rpm/brp-python-bytecompile /usr/bin/python 1 #Compiling /quad/home/jkratoch/redhat/lldb-experimental/BUILDROOT/lldb-experimental-13.0.0-0.20210206snap1.el7.x86_64/opt/lldb-experimental/lib64/python3.8/site-packages/lldb/__init__.py ... @@ -37,7 +41,7 @@ BuildRequires: clang git libedit-devel libatomic libxml2-devel zlib-devel valgri # ^ #SyntaxError: invalid syntax %global __python /usr/bin/python3 -BuildRequires: devtoolset-8-gcc-c++ +BuildRequires: llvm-toolset-7.0-clang llvm-toolset-7.0-lld # swig on rhel7: /builddir/build/BUILD/lldb-experimental-11.0.0/lldb/bindings/./python/python-typemaps.swig:496: Error: Syntax error in input(3). BuildRequires: swig3 BuildRequires: rh-git218-git-core @@ -93,6 +97,10 @@ This package contains off-trunk DWZ support for Fedora debuginfos such as: This package contains off-trunk: Support for libstdc++11 std::unique_ptr: [[no_unique_address]] %endif +%if %{use_jankratochvil_ocaml_doc} +This package contains off-trunk: + ocaml_doc fix +%endif %if %{use_jankratochvil_rust} This package contains off-trunk Rust support: https://github.com/rust-lang-nursery/lldb @@ -164,7 +172,7 @@ CLONEOPTS="--single-branch" test -d ../$REF/ && CLONEOPTS="$CLONEOPTS --reference ../$REF" # 2500 = 1 month in 2019 git clone $OPTS $CLONEOPTS https://github.com/llvm/llvm-project.git . -%if %{use_jankratochvil_dwz} || %{use_jankratochvil_rust} +%if 1 git remote remove jankratochvil || : #git remote add jankratochvil git://git.jankratochvil.net/lldb git remote add jankratochvil https://github.com/jankratochvil/llvm-project.git @@ -176,7 +184,10 @@ git config user.name jankratochvil git merge jankratochvil/dwz %endif %if %{use_jankratochvil_uniqaddr} -git merge jankratochvil/layout3 +git merge jankratochvil/layout5 +%endif +%if %{use_jankratochvil_ocaml_doc} +git merge jankratochvil/ocaml_doc %endif %if %{use_jankratochvil_rust} # '-c merge.renames=false' is F-29+. @@ -191,7 +202,7 @@ FLAGS="%{optflags}" FLAGS="$FLAGS -Wno-error=format-security" %if (0%{?rhel:1} && 0%{?rhel} <= 7) -. /opt/rh/devtoolset-8/enable +. /opt/rh/llvm-toolset-7.0/enable . /opt/rh/rh-python38/enable %endif %if %{fast} @@ -207,10 +218,19 @@ FLAGS="$FLAGS -fdebug-types-section" # clang-12: error: unsupported argument 'auto' to option 'flto=' # clang-12: warning: optimization flag '-ffat-lto-objects' is not supported [-Wignored-optimization-argument] -FLAGS="$(echo $FLAGS|sed 's/-flto=auto -ffat-lto-objects/-flto/')" +FLAGS="$(echo $FLAGS|sed 's/ -flto=auto -ffat-lto-objects / -flto /')" +# ld.lld: error: relocation R_X86_64_PC32 cannot be used against symbol ...; recompile with -fPIC +FLAGS="$FLAGS -fPIC" +%if 0%{?rhel:1} && 0%{?rhel} <= 7 +# clang: error: unknown argument: '-fstack-protector-strong' +FLAGS="$(echo $FLAGS|sed 's/ -fstack-protector-strong / /')" +%endif + +export CFLAGS="$FLAGS" +export CXXFLAGS="$FLAGS" -CFLAGS="$FLAGS" -CXXFLAGS="$FLAGS" +export LDFLAGS="%{build_ldflags}" +LDFLAGS="$LDFLAGS -flto -Wl,--build-id=sha1" # This is default - changing it breaks the testsuite: -DLLVM_LINK_LLVM_DYLIB=OFF # It does not work: -DDCMAKE_EXECUTABLE_SUFFIX=-experimental @@ -247,7 +267,7 @@ CXXFLAGS="$FLAGS" %install mkdir -p %{buildroot}%{pkg_prefix} (function revline { - echo "$(cd $1;git rev-parse ${2:-origin/master}) ${2:-$1}" + echo "$(cd $1;git rev-parse ${2:-origin/main}) ${2:-$1}" } revline . %if %{use_jankratochvil_dwz} @@ -256,7 +276,7 @@ mkdir -p %{buildroot}%{pkg_prefix} %if %{use_jankratochvil_rust} revline . jankratochvil/rust %endif -) >%{buildroot}%{pkg_prefix}/HEAD +) >%{buildroot}%{pkg_prefix}/commit %cmake_install mkdir -p %{buildroot}%{_bindir} # lldb-mi @@ -277,7 +297,7 @@ du -shc $PWD %{buildroot} %files %{_bindir}/lldb-experimental #{_bindir}/lldb-mi-experimental -%{pkg_prefix}/HEAD +%{pkg_prefix}/commit %{pkg_prefix}/bin/lldb %{pkg_prefix}/bin/lldb-server #{pkg_prefix}/bin/lldb-mi