[PATCH] Add patch level to llvm version in CMake and Autoconf
Tom Stellard
tom at stellard.net
Fri Feb 21 11:44:44 PST 2014
On Fri, Feb 21, 2014 at 11:31:55AM -0800, Eric Christopher wrote:
> Admittedly bikeshedding here but not a fan of "patch" - what do other
> programs use?
"patch" appeared to be the CPACK convention, so I just went with that. It looks
like gcc uses "patchlevel".
It doesn't matter to me what it's called. I'm open to suggestions.
-Tom
>
> -eric
> On Feb 21, 2014 1:11 PM, "Tom Stellard" <thomas.stellard at amd.com> wrote:
>
> > The shared library generated by autoconf will now be called
> >
> > libLLVM-$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_PATCH)$(VERSION_SUFFIX).so
> > and a symlink named
> > libLLVM-$(VERSION_MAJOR).$(VERSION_MINOR)$(VERSION_SUFFIX).so will
> > also be created in the install directory.
> > ---
> > CMakeLists.txt | 4 ++-
> > Makefile.config.in | 2 ++
> > Makefile.rules | 11 +++++++-
> > autoconf/configure.ac | 19 +++++++++++---
> > configure | 56
> > +++++++++++++++++++++++++----------------
> > include/llvm/Config/config.h.in | 3 +++
> > tools/llvm-shlib/Makefile | 2 ++
> > 7 files changed, 70 insertions(+), 27 deletions(-)
> >
> > diff --git a/CMakeLists.txt b/CMakeLists.txt
> > index cd8b363..dc20b1f 100644
> > --- a/CMakeLists.txt
> > +++ b/CMakeLists.txt
> > @@ -12,9 +12,10 @@ set(CMAKE_MODULE_PATH
> >
> > set(LLVM_VERSION_MAJOR 3)
> > set(LLVM_VERSION_MINOR 5)
> > +set(LLVM_VERSION_PATCH 0)
> >
> > if (NOT PACKAGE_VERSION)
> > - set(PACKAGE_VERSION "${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}svn")
> > + set(PACKAGE_VERSION
> > "${LLVM_VERSION_MAJOR}.${LLVM_VERSION_MINOR}.${LLVM_VERSION_PATCH}svn")
> > endif()
> >
> > option(LLVM_INSTALL_TOOLCHAIN_ONLY "Only include toolchain files in the
> > 'install' target." OFF)
> > @@ -45,6 +46,7 @@ set(CPACK_PACKAGE_INSTALL_DIRECTORY "LLVM")
> > set(CPACK_PACKAGE_VENDOR "LLVM")
> > set(CPACK_PACKAGE_VERSION_MAJOR ${LLVM_VERSION_MAJOR})
> > set(CPACK_PACKAGE_VERSION_MINOR ${LLVM_VERSION_MINOR})
> > +set(CPACK_PACKAGE_VERSION_PATCH ${LLVM_VERSION_PATCH})
> > set(CPACK_PACKAGE_VERSION ${PACKAGE_VERSION})
> > set(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_SOURCE_DIR}/LICENSE.TXT")
> > if(WIN32 AND NOT UNIX)
> > diff --git a/Makefile.config.in b/Makefile.config.in
> > index 7633be2..8a46b42 100644
> > --- a/Makefile.config.in
> > +++ b/Makefile.config.in
> > @@ -17,6 +17,8 @@ LLVMPackageName := @PACKAGE_TARNAME@
> > LLVMVersion := @PACKAGE_VERSION@
> > LLVM_VERSION_MAJOR := @LLVM_VERSION_MAJOR@
> > LLVM_VERSION_MINOR := @LLVM_VERSION_MINOR@
> > +LLVM_VERSION_PATCH := @LLVM_VERSION_PATCH@
> > +LLVM_VERSION_SUFFIX := @LLVM_VERSION_SUFFIX@
> > LLVM_CONFIGTIME := @LLVM_CONFIGTIME@
> >
> >
> > ###########################################################################
> > diff --git a/Makefile.rules b/Makefile.rules
> > index d668b23..770c0a6 100644
> > --- a/Makefile.rules
> > +++ b/Makefile.rules
> > @@ -783,7 +783,7 @@ else
> > Ranlib = ranlib
> > endif
> >
> > -AliasTool = ln -s
> > +AliasTool = ln -sf
> >
> > #----------------------------------------------------------
> > # Get the list of source files and compute object file
> > @@ -1147,15 +1147,19 @@ ifdef LIBRARYNAME
> >
> > # Make sure there isn't any extraneous whitespace on the LIBRARYNAME
> > option
> > LIBRARYNAME := $(strip $(LIBRARYNAME))
> > +LIBRARYALIASNAME := $(strip $(LIBRARYALIASNAME))
> > ifdef LOADABLE_MODULE
> > BaseLibName.A := $(LIBRARYNAME).a
> > BaseLibName.SO := $(LIBRARYNAME)$(SHLIBEXT)
> > +BaseAliasName.SO := $(LIBRARYALIASNAME)$(SHLIBEXT)
> > else
> > BaseLibName.A := lib$(LIBRARYNAME).a
> > BaseLibName.SO := $(SharedPrefix)$(LIBRARYNAME)$(SHLIBEXT)
> > +BaseAliasName.SO := $(SharedPrefix)$(LIBRARYALIASNAME)$(SHLIBEXT)
> > endif
> > LibName.A := $(LibDir)/$(BaseLibName.A)
> > LibName.SO := $(SharedLibDir)/$(BaseLibName.SO)
> > +AliasName.SO := $(SharedLibDir)/$(BaseAliasName.SO)
> > LibName.O := $(LibDir)/$(LIBRARYNAME).o
> >
> > #---------------------------------------------------------
> > @@ -1209,12 +1213,17 @@ else
> > DestSharedLibDir := $(DESTDIR)$(PROJ_libdir)
> > endif
> > DestSharedLib := $(DestSharedLibDir)/$(BaseLibName.SO)
> > +DestSharedAlias := $(DestSharedLibDir)/$(BaseAliasName.SO)
> >
> > install-local:: $(DestSharedLib)
> >
> > $(DestSharedLib): $(LibName.SO) $(DestSharedLibDir)
> > $(Echo) Installing $(BuildMode) Shared Library $(DestSharedLib)
> > $(Verb) $(INSTALL) $(LibName.SO) $(DestSharedLib)
> > +ifdef SHARED_ALIAS
> > + $(Echo) Creating alias from $(DestSharedLib) to $(DestSharedAlias)
> > + $(Verb) $(AliasTool) $(DestSharedLib) $(DestSharedAlias)
> > +endif
> >
> > uninstall-local::
> > $(Echo) Uninstalling $(BuildMode) Shared Library $(DestSharedLib)
> > diff --git a/autoconf/configure.ac b/autoconf/configure.ac
> > index f376e03..4685649 100644
> > --- a/autoconf/configure.ac
> > +++ b/autoconf/configure.ac
> > @@ -31,9 +31,22 @@ dnl===
> >
> > dnl===-----------------------------------------------------------------------===
> > dnl Initialize autoconf and define the package name, version number and
> > dnl address for reporting bugs.
> > -AC_INIT([LLVM],[3.5svn],[http://llvm.org/bugs/])
> > -LLVM_DEFINE_SUBST([LLVM_VERSION_MAJOR], [3], [Major version of the LLVM
> > API])
> > -LLVM_DEFINE_SUBST([LLVM_VERSION_MINOR], [5], [Minor version of the LLVM
> > API])
> > +
> > +AC_INIT([LLVM],[3.5.0svn],[http://llvm.org/bugs/])
> > +
> > +LLVM_VERSION_MAJOR=3
> > +LLVM_VERSION_MINOR=5
> > +LLVM_VERSION_PATCH=0
> > +LLVM_VERSION_SUFFIX=svn
> > +
> > +AC_DEFINE_UNQUOTED([LLVM_VERSION_MAJOR], $LLVM_VERSION_MAJOR, [Major
> > version of the LLVM API])
> > +AC_DEFINE_UNQUOTED([LLVM_VERSION_MINOR], $LLVM_VERSION_MINOR, [Minor
> > version of the LLVM API])
> > +AC_DEFINE_UNQUOTED([LLVM_VERSION_PATCH], $LLVM_VERSION_PATCH, [Patch
> > version of the LLVM API])
> > +
> > +AC_SUBST([LLVM_VERSION_MAJOR])
> > +AC_SUBST([LLVM_VERSION_MINOR])
> > +AC_SUBST([LLVM_VERSION_PATCH])
> > +AC_SUBST([LLVM_VERSION_SUFFIX])
> >
> > dnl Provide a copyright substitution and ensure the copyright notice is
> > included
> > dnl in the output of --version option of the generated configure script.
> > diff --git a/configure b/configure
> > index 46d557d..d23311f 100755
> > --- a/configure
> > +++ b/configure
> > @@ -1,6 +1,6 @@
> > #! /bin/sh
> > # Guess values for system-dependent variables and create Makefiles.
> > -# Generated by GNU Autoconf 2.60 for LLVM 3.5svn.
> > +# Generated by GNU Autoconf 2.60 for LLVM 3.5.0svn.
> > #
> > # Report bugs to <http://llvm.org/bugs/>.
> > #
> > @@ -561,8 +561,8 @@ SHELL=${CONFIG_SHELL-/bin/sh}
> > # Identity of this package.
> > PACKAGE_NAME='LLVM'
> > PACKAGE_TARNAME='llvm'
> > -PACKAGE_VERSION='3.5svn'
> > -PACKAGE_STRING='LLVM 3.5svn'
> > +PACKAGE_VERSION='3.5.0svn'
> > +PACKAGE_STRING='LLVM 3.5.0svn'
> > PACKAGE_BUGREPORT='http://llvm.org/bugs/'
> >
> > ac_unique_file="lib/IR/Module.cpp"
> > @@ -641,6 +641,8 @@ host_alias
> > target_alias
> > LLVM_VERSION_MAJOR
> > LLVM_VERSION_MINOR
> > +LLVM_VERSION_PATCH
> > +LLVM_VERSION_SUFFIX
> > LLVM_COPYRIGHT
> > CC
> > CFLAGS
> > @@ -1330,7 +1332,7 @@ if test "$ac_init_help" = "long"; then
> > # Omit some internal or obsolete options to make the list less imposing.
> > # This message is too long to be a string in the A/UX 3.1 sh.
> > cat <<_ACEOF
> > -\`configure' configures LLVM 3.5svn to adapt to many kinds of systems.
> > +\`configure' configures LLVM 3.5.0svn to adapt to many kinds of systems.
> >
> > Usage: $0 [OPTION]... [VAR=VALUE]...
> >
> > @@ -1396,7 +1398,7 @@ fi
> >
> > if test -n "$ac_init_help"; then
> > case $ac_init_help in
> > - short | recursive ) echo "Configuration of LLVM 3.5svn:";;
> > + short | recursive ) echo "Configuration of LLVM 3.5.0svn:";;
> > esac
> > cat <<\_ACEOF
> >
> > @@ -1568,7 +1570,7 @@ fi
> > test -n "$ac_init_help" && exit $ac_status
> > if $ac_init_version; then
> > cat <<\_ACEOF
> > -LLVM configure 3.5svn
> > +LLVM configure 3.5.0svn
> > generated by GNU Autoconf 2.60
> >
> > Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001,
> > @@ -1584,7 +1586,7 @@ cat >config.log <<_ACEOF
> > This file contains any messages produced by compilers while
> > running configure, to aid debugging if configure makes a mistake.
> >
> > -It was created by LLVM $as_me 3.5svn, which was
> > +It was created by LLVM $as_me 3.5.0svn, which was
> > generated by GNU Autoconf 2.60. Invocation command line was
> >
> > $ $0 $@
> > @@ -1938,21 +1940,29 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
> >
> >
> >
> > +LLVM_VERSION_MAJOR=3
> > +LLVM_VERSION_MINOR=5
> > +LLVM_VERSION_PATCH=0
> > +LLVM_VERSION_SUFFIX=svn
> >
> > -cat >>confdefs.h <<\_ACEOF
> > -#define LLVM_VERSION_MAJOR 3
> > -_ACEOF
> >
> > -LLVM_VERSION_MAJOR='3'
> > +cat >>confdefs.h <<_ACEOF
> > +#define LLVM_VERSION_MAJOR $LLVM_VERSION_MAJOR
> > +_ACEOF
> >
> >
> > +cat >>confdefs.h <<_ACEOF
> > +#define LLVM_VERSION_MINOR $LLVM_VERSION_MINOR
> > +_ACEOF
> >
> >
> > -cat >>confdefs.h <<\_ACEOF
> > -#define LLVM_VERSION_MINOR 5
> > +cat >>confdefs.h <<_ACEOF
> > +#define LLVM_VERSION_PATCH $LLVM_VERSION_PATCH
> > _ACEOF
> >
> > -LLVM_VERSION_MINOR='5'
> > +
> > +
> > +
> >
> >
> >
> > @@ -10710,7 +10720,7 @@ else
> > lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
> > lt_status=$lt_dlunknown
> > cat > conftest.$ac_ext <<EOF
> > -#line 10713 "configure"
> > +#line 10723 "configure"
> > #include "confdefs.h"
> >
> > #if HAVE_DLFCN_H
> > @@ -23073,7 +23083,7 @@ exec 6>&1
> > # report actual input values of CONFIG_FILES etc. instead of their
> > # values after options handling.
> > ac_log="
> > -This file was extended by LLVM $as_me 3.5svn, which was
> > +This file was extended by LLVM $as_me 3.5.0svn, which was
> > generated by GNU Autoconf 2.60. Invocation command line was
> >
> > CONFIG_FILES = $CONFIG_FILES
> > @@ -23126,7 +23136,7 @@ Report bugs to <bug-autoconf at gnu.org>."
> > _ACEOF
> > cat >>$CONFIG_STATUS <<_ACEOF
> > ac_cs_version="\\
> > -LLVM config.status 3.5svn
> > +LLVM config.status 3.5.0svn
> > configured by $0, generated by GNU Autoconf 2.60,
> > with options \\"`echo "$ac_configure_args" | sed 's/^ //;
> > s/[\\""\`\$]/\\\\&/g'`\\"
> >
> > @@ -23366,6 +23376,8 @@ host_alias!$host_alias$ac_delim
> > target_alias!$target_alias$ac_delim
> > LLVM_VERSION_MAJOR!$LLVM_VERSION_MAJOR$ac_delim
> > LLVM_VERSION_MINOR!$LLVM_VERSION_MINOR$ac_delim
> > +LLVM_VERSION_PATCH!$LLVM_VERSION_PATCH$ac_delim
> > +LLVM_VERSION_SUFFIX!$LLVM_VERSION_SUFFIX$ac_delim
> > LLVM_COPYRIGHT!$LLVM_COPYRIGHT$ac_delim
> > CC!$CC$ac_delim
> > CFLAGS!$CFLAGS$ac_delim
> > @@ -23422,8 +23434,6 @@
> > ENABLE_EXPENSIVE_CHECKS!$ENABLE_EXPENSIVE_CHECKS$ac_delim
> > EXPENSIVE_CHECKS!$EXPENSIVE_CHECKS$ac_delim
> > DEBUG_RUNTIME!$DEBUG_RUNTIME$ac_delim
> > DEBUG_SYMBOLS!$DEBUG_SYMBOLS$ac_delim
> > -KEEP_SYMBOLS!$KEEP_SYMBOLS$ac_delim
> > -JIT!$JIT$ac_delim
> > _ACEOF
> >
> > if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 97;
> > then
> > @@ -23465,6 +23475,8 @@ _ACEOF
> > ac_delim='%!_!# '
> > for ac_last_try in false false false false false :; do
> > cat >conf$$subs.sed <<_ACEOF
> > +KEEP_SYMBOLS!$KEEP_SYMBOLS$ac_delim
> > +JIT!$JIT$ac_delim
> > TARGET_HAS_JIT!$TARGET_HAS_JIT$ac_delim
> > TARGETS_WITH_JIT!$TARGETS_WITH_JIT$ac_delim
> > ENABLE_DOCS!$ENABLE_DOCS$ac_delim
> > @@ -23560,8 +23572,6 @@ SHLIBPATH_VAR!$SHLIBPATH_VAR$ac_delim
> > LLVM_PREFIX!$LLVM_PREFIX$ac_delim
> > LLVM_BINDIR!$LLVM_BINDIR$ac_delim
> > LLVM_DATADIR!$LLVM_DATADIR$ac_delim
> > -LLVM_DOCSDIR!$LLVM_DOCSDIR$ac_delim
> > -LLVM_ETCDIR!$LLVM_ETCDIR$ac_delim
> > _ACEOF
> >
> > if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 97;
> > then
> > @@ -23603,6 +23613,8 @@ _ACEOF
> > ac_delim='%!_!# '
> > for ac_last_try in false false false false false :; do
> > cat >conf$$subs.sed <<_ACEOF
> > +LLVM_DOCSDIR!$LLVM_DOCSDIR$ac_delim
> > +LLVM_ETCDIR!$LLVM_ETCDIR$ac_delim
> > LLVM_INCLUDEDIR!$LLVM_INCLUDEDIR$ac_delim
> > LLVM_INFODIR!$LLVM_INFODIR$ac_delim
> > LLVM_MANDIR!$LLVM_MANDIR$ac_delim
> > @@ -23618,7 +23630,7 @@ LIBOBJS!$LIBOBJS$ac_delim
> > LTLIBOBJS!$LTLIBOBJS$ac_delim
> > _ACEOF
> >
> > - if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 13;
> > then
> > + if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 15;
> > then
> > break
> > elif $ac_last_try; then
> > { { echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
> > diff --git a/include/llvm/Config/config.h.in b/include/llvm/Config/
> > config.h.in
> > index 8565696..069f1a4 100644
> > --- a/include/llvm/Config/config.h.in
> > +++ b/include/llvm/Config/config.h.in
> > @@ -642,6 +642,9 @@
> > /* Minor version of the LLVM API */
> > #undef LLVM_VERSION_MINOR
> >
> > +/* Patch version of the LLVM API */
> > +#undef LLVM_VERSION_PATCH
> > +
> > /* Define if the OS needs help to load dependent libraries for dlopen().
> > */
> > #undef LTDL_DLOPEN_DEPLIBS
> >
> > diff --git a/tools/llvm-shlib/Makefile b/tools/llvm-shlib/Makefile
> > index 317da51..cd26a24 100644
> > --- a/tools/llvm-shlib/Makefile
> > +++ b/tools/llvm-shlib/Makefile
> > @@ -10,10 +10,12 @@
> > LEVEL := ../..
> >
> > LIBRARYNAME = LLVM-$(LLVMVersion)
> > +LIBRARYALIASNAME =
> > LLVM-$(LLVM_VERSION_MAJOR).$(LLVM_VERSION_MINOR)$(LLVM_VERSION_SUFFIX)
> >
> > NO_BUILD_ARCHIVE := 1
> > LINK_LIBS_IN_SHARED := 1
> > SHARED_LIBRARY := 1
> > +SHARED_ALIAS := 1
> >
> > include $(LEVEL)/Makefile.config
> >
> > --
> > 1.8.1.4
> >
> >
> >
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
More information about the llvm-commits
mailing list