X-Git-Url: http://git.jankratochvil.net/?p=lldb-experimental.git;a=blobdiff_plain;f=lldb-experimental.spec;h=6c58f04aa042dad59be256b567bfab58f34a8e95;hp=04917c0e2aeaca97fb30bd4e1dd051eaca24f22e;hb=8545ccaff27d8095fbcbc11851d46536b50d9d3e;hpb=f9b5b95c6d88373b5b959f7f2af23be7aa697ce1 diff --git a/lldb-experimental.spec b/lldb-experimental.spec index 04917c0..6c58f04 100644 --- a/lldb-experimental.spec +++ b/lldb-experimental.spec @@ -11,24 +11,31 @@ %global debug_package %{nil} %endif Name: lldb-experimental -Version: 10.0.0 -Release: 0.20190817snap3%{?dist} +Version: 11.0.0 +Release: 0.20200722snap1%{?dist} Summary: Next generation high-performance debugger - experimental trunk snapshot License: NCSA URL: http://lldb.llvm.org/ +Patch1: cmake-old.patch ExclusiveArch: x86_64 -BuildRequires: gcc-c++ git libedit-devel swig libatomic ninja-build libxml2-devel zlib-devel valgrind-devel libpfm-devel epydoc +BuildRequires: gcc-c++ git libedit-devel libatomic libxml2-devel zlib-devel valgrind-devel libpfm-devel +# https://src.fedoraproject.org/rpms/epydoc +#BuildRequires: epydoc %if 0%{?rhel:1} && 0%{?rhel} <= 7 BuildRequires: llvm-toolset-7-cmake devtoolset-8-gcc-c++ python-devel python2-pyyaml +# 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 # https://bugzilla.redhat.com/show_bug.cgi?id=1511892 %global __cmake /opt/rh/llvm-toolset-7/root/usr/bin/cmake3 -%global ninjabuild ninja-build %else -BuildRequires: cmake z3-devel +%if !0%{?rhel:1} || 0%{?rhel} > 8 +BuildRequires: z3-devel +%endif +BuildRequires: cmake swig BuildRequires: python3-devel python3-pygments python3-pyyaml # removed in F31+ #BuildRequires: xar-devel -%global ninjabuild ninja %endif %description @@ -58,13 +65,27 @@ The package contains header files for %{name}. %ldconfig_scriptlets %prep +%if 0%{?rhel:1} && 0%{?rhel} <= 7 +# git clone --depth 10000 --single-branch --reference ../reference https://github.com/llvm/llvm-project.git . +# fatal: git fetch-pack: expected shallow list +. /opt/rh/rh-git218/enable +%endif %setup -q -c -T +OPTS="--depth 10000" +%if !0%{?rhel:1} || 0%{?rhel} > 7 + OPTS="$OPTS --no-tags" +%endif +REF="reference" +# RHEL-7 does not support: --reference-if-able +CLONEOPTS="--single-branch" +test -d ../$REF/ && CLONEOPTS="$CLONEOPTS --reference ../$REF" # 2500 = 1 month in 2019 -git clone --depth 10000 --no-tags --single-branch --reference-if-able reference https://github.com/llvm/llvm-project.git . +git clone $OPTS $CLONEOPTS https://github.com/llvm/llvm-project.git . %if %{use_jankratochvil_dwz} || %{use_jankratochvil_rust} git remote remove jankratochvil || : -git remote add jankratochvil git://git.jankratochvil.net/lldb -git fetch jankratochvil +#git remote add jankratochvil git://git.jankratochvil.net/lldb +git remote add jankratochvil https://github.com/jankratochvil/llvm-project.git +git fetch $OPTS jankratochvil git config user.email jankratochvil@copr.fedorainfracloud.org git config user.name jankratochvil %endif @@ -76,11 +97,9 @@ git merge jankratochvil/dwz # '-c merge.renameLimit=0' has no effect. git -c merge.renameLimit=1 merge jankratochvil/rust %endif +%patch1 -p1 %build -mkdir build-release -cd build-release - FLAGS="%{optflags}" # lldb/scripts/LLDBWrapPython.cpp:23699:70: error: format not a string literal and no format arguments [-Werror=format-security] @@ -109,9 +128,8 @@ CXXFLAGS="$FLAGS" # It does not work: -DDCMAKE_EXECUTABLE_SUFFIX=-experimental # -fdebug-types-section && -DLLVM_USE_LINKER=gold: # ../../../../lib64/libclangLex.a(PreprocessingRecord.cpp.o)(.debug_types+0xfe): error: undefined reference to 'clang::SourceRange::getBegin() const' -%cmake ../llvm \ - -GNinja \ - -DCMAKE_INSTALL_PREFIX=%{buildroot}%{pkg_prefix} \ +%cmake llvm \ + -DCMAKE_INSTALL_PREFIX=%{pkg_prefix} \ -DBUILD_SHARED_LIBS=OFF \ %if %{fast} -DCMAKE_BUILD_TYPE=Release \ @@ -132,7 +150,11 @@ CXXFLAGS="$FLAGS" -DLLDB_DISABLE_LIBEDIT=OFF \ -DLLDB_DISABLE_PYTHON=OFF \ # -%{ninjabuild} -v +%if 0%{?rhel:1} && 0%{?rhel} <= 8 +%__cmake --build . -- %{?_smp_mflags} +%else +%cmake_build +%endif %install mkdir -p %{buildroot}%{pkg_prefix} @@ -147,8 +169,11 @@ mkdir -p %{buildroot}%{pkg_prefix} revline . jankratochvil/rust %endif ) >%{buildroot}%{pkg_prefix}/HEAD -cd build-release -%{ninjabuild} -v install +%if 0%{?rhel:1} && 0%{?rhel} <= 8 +DESTDIR="%{buildroot}" %__cmake --install . +%else +%cmake_install +%endif mkdir -p %{buildroot}%{_bindir} # lldb-mi for i in lldb;do @@ -164,9 +189,6 @@ rm -fv %{buildroot}%{_libdir}/*.a ln -vsf "$(dirname $(readlink _lldb.so))/$(readlink $(readlink _lldb.so))" _lldb.so ) -# FIXME: Port it to Python 3: remove bundled six.py - Python 2<->3 -rm -f %{buildroot}%{pkg_prefix}/%{_lib}/python*/site-packages/six.py* - %files %{_bindir}/lldb-experimental #{_bindir}/lldb-mi-experimental