X-Git-Url: http://git.jankratochvil.net/?p=lldb-experimental.git;a=blobdiff_plain;f=lldb-experimental.spec;h=83858365d209854d293f2b35827428e60795acb2;hp=bed88233ea6ebdca0c461f8cc932fe77d03ac893;hb=bd1a0a99c99394047cafcd554cb0c940a7b6a01b;hpb=829ce8864bd00a42e40114d8cf600488bac9f0ff diff --git a/lldb-experimental.spec b/lldb-experimental.spec index bed8823..8385836 100644 --- a/lldb-experimental.spec +++ b/lldb-experimental.spec @@ -1,4 +1,6 @@ -%global fast 0 +# https://download.copr.fedorainfracloud.org/results/jankratochvil/lldb/fedora-rawhide-x86_64/01574351-lldb-experimental/builder-live.log.gz +# No space left on device. +%global fast 1 %global use_jankratochvil_dwz 1 %global use_jankratochvil_rust 0 %global pkg_prefix /opt/%{name} @@ -12,28 +14,31 @@ %endif Name: lldb-experimental Version: 11.0.0 -Release: 0.20200424snap3%{?dist} +Release: 0.20200726snap0%{?dist} Summary: Next generation high-performance debugger - experimental trunk snapshot License: NCSA URL: http://lldb.llvm.org/ +Patch1: cmake-old1.patch +Patch2: cmake-old2.patch ExclusiveArch: x86_64 -BuildRequires: gcc-c++ git libedit-devel swig libatomic ninja-build libxml2-devel zlib-devel valgrind-devel libpfm-devel +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 %if !0%{?rhel:1} || 0%{?rhel} > 8 BuildRequires: z3-devel %endif -BuildRequires: cmake +BuildRequires: cmake swig BuildRequires: python3-devel python3-pygments python3-pyyaml # removed in F31+ #BuildRequires: xar-devel -%global ninjabuild ninja %endif %description @@ -63,6 +68,11 @@ 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 @@ -70,9 +80,10 @@ OPTS="--depth 10000" %endif REF="reference" # RHEL-7 does not support: --reference-if-able -test -d ../$REF/ && OPTS="$OPTS --reference ../$REF" +CLONEOPTS="--single-branch" +test -d ../$REF/ && CLONEOPTS="$CLONEOPTS --reference ../$REF" # 2500 = 1 month in 2019 -git clone --single-branch $OPTS 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 @@ -89,11 +100,10 @@ git merge jankratochvil/dwz # '-c merge.renameLimit=0' has no effect. git -c merge.renameLimit=1 merge jankratochvil/rust %endif +%patch2 -p1 -R +%patch1 -p1 -R %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] @@ -112,7 +122,7 @@ FLAGS="$FLAGS -g0" # -fno-reorder-blocks-and-partition: # -gsplit-dwarf: Error: can't resolve `.text.unlikely' - `.LVL414' # https://bugzilla.redhat.com/show_bug.cgi?id=1573647 -FLAGS="$FLAGS -gsplit-dwarf -fno-reorder-blocks-and-partition" +FLAGS="$FLAGS -fdebug-types-section" %endif CFLAGS="$FLAGS" @@ -122,9 +132,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 \ @@ -145,7 +154,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} @@ -160,8 +173,12 @@ 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 +# It runs a new configure without installing anything: DESTDIR="%{buildroot}" #__cmake --install . +%make_install +%else +%cmake_install +%endif mkdir -p %{buildroot}%{_bindir} # lldb-mi for i in lldb;do