llvm-toolchain/debian
2024-03-20 09:23:21 +01:00
..
patches rebase of the patch 2024-03-20 09:23:11 +01:00
source
tests Fix tests by adding a .1 to clang and llvm versions 2024-02-07 16:06:08 +01:00
bolt-X.Y.install.in
changelog prepare release 2024-03-20 09:23:21 +01:00
clang-format-X.Y.install.in
clang-format-X.Y.lintian-overrides.in
clang-format-X.Y.manpages.in
clang-tidy-X.Y.install.in
clang-tidy-X.Y.links.in
clang-tidy-X.Y.lintian-overrides.in
clang-tidy-X.Y.manpages.in
clang-tools-X.Y.install.in hwasan_symbolize is now built also on i386 2024-01-30 20:46:57 +01:00
clang-tools-X.Y.links.in
clang-tools-X.Y.lintian-overrides.in
clang-tools-X.Y.manpages.in
clang-X.Y-doc.docs.in
clang-X.Y-doc.install.in
clang-X.Y-examples.examples.in
clang-X.Y.install.in
clang-X.Y.links.in
clang-X.Y.lintian-overrides.in
clang-X.Y.manpages.in
clangd-X.Y.install.in
clangd-X.Y.manpages.in
compat
control Build using mold 2024-03-17 10:14:09 +01:00
control.in Build using mold 2024-03-17 10:14:09 +01:00
copyright
debian_path.h
flang-X.Y.install.in
libbolt-X.Y-dev.install.in
libc++1-X.Y.install.in
libc++1-X.Y.links.in
libc++1-X.Y.lintian-overrides.in
libc++-X.Y-dev-wasm32.install.in
libc++-X.Y-dev-wasm32.links.in
libc++-X.Y-dev-wasm32.lintian-overrides.in
libc++-X.Y-dev.install.in Ship libc++-18-dev /usr/lib/llvm-18/lib/libc++.modules.json /usr/lib/llvm-18/include/c++/v1/std.compat.cppm 2024-02-20 22:15:26 +01:00
libc++-X.Y-dev.links.in
libc++-X.Y-dev.lintian-overrides.in
libc++abi1-X.Y.install.in
libc++abi1-X.Y.links.in
libc++abi1-X.Y.lintian-overrides.in
libc++abi-X.Y-dev-wasm32.install.in
libc++abi-X.Y-dev-wasm32.links.in
libc++abi-X.Y-dev-wasm32.lintian-overrides.in
libc++abi-X.Y-dev.install.in
libc++abi-X.Y-dev.links.in
libc++abi-X.Y-dev.lintian-overrides.in
libclang1-X.Y.install.in
libclang1-X.Y.links.in * libclang1-17: Remove the full version symlinks. 2023-12-11 22:56:07 +01:00
libclang1-X.Y.lintian-overrides.in
libclang1-X.Y.symbols.in refresh symbols 2024-03-18 11:54:20 +01:00
libclang-common-X.Y-dev.install.in * Enable compiler-rt runtime again for 32bit time_t64 architectures. 2024-03-08 15:44:50 +01:00
libclang-common-X.Y-dev.links.in
libclang-cppX.Y-dev.install.in
libclang-cppX.Y-dev.links.in
libclang-cppX.Y.install.in adjust some symlinks 2024-03-06 09:22:34 +01:00
libclang-cppX.Y.links.in Try to address a link issue with libclang-cpp.so.18 (GH: #83986) 2024-03-08 21:20:41 +01:00
libclang-rt-X.Y-dev-wasm32.install.in
libclang-rt-X.Y-dev-wasm32.lintian-overrides.in
libclang-rt-X.Y-dev-wasm64.install.in
libclang-rt-X.Y-dev-wasm64.lintian-overrides.in
libclang-rt-X.Y-dev.install.in Install *clang_rt* on sparc and sparc64 2024-02-16 09:54:15 +01:00
libclang-rt-X.Y-dev.lintian-overrides.in
libclang-X.Y-dev.install.in
libclang-X.Y-dev.links.in
libclc-X.Y-dev.install.in
libclc-X.Y.install.in
libflang-X.Y-dev.install.in
liblld-X.Y-dev.install.in
liblld-X.Y.install.in
liblld-X.Y.links.in
liblldb-X.Y-dev.install.in
liblldb-X.Y-dev.links.in
liblldb-X.Y.install.in
liblldb-X.Y.links.in
liblldb-X.Y.lintian-overrides.in
libllvm-X.Y-ocaml-dev.dirs.in
libllvm-X.Y-ocaml-dev.install.in
libllvm-X.Y-ocaml-dev.lintian-overrides.in
libllvm-X.Y-ocaml-dev.META.in
libllvmlibc-X.Y-dev.install.in Ship libc++-18-dev /usr/lib/llvm-18/lib/libc++.modules.json /usr/lib/llvm-18/include/c++/v1/std.compat.cppm 2024-02-20 22:15:26 +01:00
libllvmX.Y.install.in adjust some symlinks 2024-03-06 09:22:34 +01:00
libllvmX.Y.links.in adjust some symlinks 2024-03-06 09:22:34 +01:00
libllvmX.Y.lintian-overrides.in
libmlir-X.Y-dev.install.in
libmlir-X.Y-dev.lintian-overrides.in
libmlir-X.Y.install.in
libmlir-X.Y.lintian-overrides.in
libomp5-X.Y.install.in adjust some symlinks 2024-03-06 09:22:34 +01:00
libomp5-X.Y.links.in
libomp5-X.Y.lintian-overrides.in
libomp5-X.Y.symbols.in remove old missing in symbols 2024-03-18 11:54:44 +01:00
libomp-X.Y-dev.install.in
libomp-X.Y-dev.links.in
libomp-X.Y-doc.docs.in
libomp-X.Y.links.in
libpolly-X.Y-dev.install.in
libpolly-X.Y-dev.lintian-overrides.in
libunwind-X.Y-dev.install.in
libunwind-X.Y-dev.links.in
libunwind-X.Y-dev.lintian-overrides.in
libunwind-X.Y.install.in
libunwind-X.Y.links.in
libunwind-X.Y.lintian-overrides.in
lld-X.Y.install.in
lld-X.Y.manpages.in
lldb-X.Y.install.in
lldb-X.Y.links.in
lldb-X.Y.lintian-overrides.in
lldb-X.Y.manpages.in
lldb-X.Y.postinst.in
llvm-compile-lto-elf.sh fix the call to the llvm ir => .a 2024-03-06 09:22:37 +01:00
llvm-priv-dev.dirs
llvm-X.Y-dev.dirs.in
llvm-X.Y-dev.install.in
llvm-X.Y-dev.links.in adjust some symlinks 2024-03-06 09:22:34 +01:00
llvm-X.Y-doc.dirs.in
llvm-X.Y-doc.install.in
llvm-X.Y-examples.dirs.in
llvm-X.Y-examples.examples.in
llvm-X.Y-linker-tools.install.in adjust some symlinks 2024-03-06 09:22:34 +01:00
llvm-X.Y-linker-tools.links.in
llvm-X.Y-runtime.binfmt.conf.in
llvm-X.Y-runtime.binfmt.in
llvm-X.Y-runtime.install.in
llvm-X.Y-runtime.lintian-overrides.in
llvm-X.Y-runtime.manpages.in
llvm-X.Y-runtime.postinst.in
llvm-X.Y-runtime.prerm.in
llvm-X.Y-tools.dirs.in
llvm-X.Y-tools.install.in
llvm-X.Y.dirs.in
llvm-X.Y.install.in
llvm-X.Y.lintian-overrides.in
llvm-X.Y.manpages.in
mlir-X.Y-tools.install.in
orig-tar.sh
pollycc.in
prepare-new-release.sh Prepare-new-release is now updated for llvm-19 2024-02-07 15:07:47 +01:00
python3-clang-X.Y.install.in
python3-lldb-X.Y.install.in
python3-lldb-X.Y.links.in
qualify-clang.sh add a C++ module test 2024-03-09 08:14:44 +01:00
README
README.source
rules disable mold on bookworm 2024-03-18 11:02:49 +01:00
TODO
unpack.sh prepare 18 upload 2024-01-24 22:14:23 +01:00
watch

Organization of the repository
==============================

The debian package for each LLVM point release is maintained as a git branch.
For example, the 10 release lives at in the "10" branch.

The current snapshot release is maintained in the "snapshot" branch.

The easiest way to get all branches is probably to have one
clone per version:

for f in 14 15 16 17 snapshot; do
    git clone git@salsa.debian.org:pkg-llvm-team/llvm-toolchain.git -b $f $f
done

debian/control is generated from debian/control.in by running:

debian/rules preconfigure


Steps for manually building a snapshot release
==============================================

1) Retrieve the latest snapshot and create original tarballs.

   Run the orig-tar.sh script,

     $ sh snapshot/debian/orig-tar.sh

   which will retrieve the latest version for each LLVM subproject (llvm,
   clang, lldb, etc.) from the main development (upstream github). and repack it
   as a set of tarballs.

2) Unpack the original tarballs and apply quilt debian patches.

   From the branches/ directory run the unpack.sh script,

     $ sh unpack.sh

   which will unpack the source tree inside a new directory such as
   branches/llvm-toolchain-snapshot_3.9~+20191018225217+3b123a2be6d.
   (date+hour+short git hash).
   Depending on the current snapshot version number and git release,
   the directory name will be
   different.

   Quilt patches will then be applied.

3) Build the binary packages using,

     $ fakeroot debian/rules binary

When debugging, successive builds can be recompiled faster by using tools such
as ccache (PATH=/usr/lib/ccache:$PATH fakeroot debian/rules binary).

Retrieving a specific branch or release candidate with orig-tar.sh
==================================================================

When using orig-tar.sh, if you need to retrieve a specific branch, you can pass
the branch name as the first argument. For example, to get the 10 release
branch at
  https://github.com/llvm/llvm-project/branches
you should use,

  $ sh 10/debian/orig-tar.sh release/10.x

To retrieve a specific release candidate, you can pass the branch name as the
first argument, and the tag rc number as the second argument. For example, to
get the 9.0.1 release candidate rc3 at
  https://github.com/llvm/llvm-project/tags
you should use,

  $ sh 10/debian/orig-tar.sh 10.0.1 rc3

For a stable release, the syntax is:

 $ sh 10/debian/orig-tar.sh 10.0.0


Additional maintainer scripts
=============================

The script qualify-clang.sh that is found at the git debian/ directory
should be used to quickly test a newly built package. It runs a short
set of sanity-check tests and regression tests.
It is executed in autopkgtest.

The script releases/snapshot/debian/prepare-new-release.sh is used when
preparing a new point release. It automatically replaces version numbers
in various files of the package.

Making a change to all versions
===============================

Sometimes, we want to make a change on all branches.
In that case, start to make the change from the older
version (example: 8), then, change branch (example: 9) and
$ git merge origin/8
to retrieve the changes


Change in major upstream version
================================
TODO update with the git commands

$ svn copy snapshot VERSION
$ svn commit -m "VERSION branched" VERSION
$ cd VERSION
$ sed -i -e '0,/llvm-toolchain-snapshot/s/llvm-toolchain-snapshot/llvm-toolchain-VERSION/' debian/changelog debian/control
$ svn commit -m "snapshot => VERSION"
$ cd ../snapshot
$ emacs debian/prepare-new-release.sh
# Change the version
$ bash debian/prepare-new-release.sh
$ svn commit -m "new snapshot release"

Now, try build build it.