Kaydet (Commit) 62532ad4 authored tarafından Luboš Luňák's avatar Luboš Luňák

do not set our clang timestamp to the timestamp of the clang binary

If the clang binary comes from a package which had been built before
any of our clang related sources were changed the last time, the timestamp
would be older and so there would be no rebuild. So do the stamp handling
the usual way, clang upgrades will work fine, downgrades will not, but
that's the same problem like with downgrading a library and its headers.

To somewhat mitigate the problem (Clang plugin doesn't get cleaned by
'make clean'), include the full Clang version (which includes SVN revision)
in config_clang.h and make all Clang plugin code include that, so
at least configure re-run will trigger a rebuild if necessary.

Change-Id: I993197f79e92e36105092c92c33b2e1db343e975
üst a4298f86
......@@ -69,6 +69,6 @@ $(CLANGOUTDIR)/plugin.so: $(CLANGOBJS)
# Clang most probably doesn't maintain binary compatibility, so rebuild when clang changes.
$(CLANGOUTDIR)/clang-timestamp: $(CLANGDIR)/bin/clang
touch $@ -r $^
touch $@
# vim: set noet sw=4 ts=4:
......@@ -26,8 +26,6 @@
#include "sallogareas.hxx"
#include "unusedvariablecheck.hxx"
#include <config_clang.h>
namespace loplugin
{
......
......@@ -11,6 +11,8 @@
#ifndef PLUGIN_H
#define PLUGIN_H
#include <config_clang.h>
#include <clang/AST/RecursiveASTVisitor.h>
#if __clang_major__ < 3 || __clang_major__ == 3 && __clang_minor__ < 2
......
......@@ -16,8 +16,6 @@
#include <fstream>
#include <config_clang.h>
namespace loplugin
{
......
......@@ -12,4 +12,8 @@ Settings related to Clang compiler plugins.
#undef SRCDIR
#undef WORKDIR
/* This is actually unused, but it should change whenever Clang changes,
thus causing update of this .h file and triggerring rebuild of our Clang plugin. */
#undef CLANG_FULL_VERSION
#endif
......@@ -2906,6 +2906,7 @@ if test "$GCC" = "yes"; then
CLANG_FULL_VERSION=`echo __clang_version__ | $CC -E -P -`
CLANGVER=`echo $clang_version | $AWK -F. '{ print \$1*10000+\$2*100+\$3 }'`
AC_MSG_RESULT([Clang $CLANG_FULL_VERSION, $CLANGVER])
AC_DEFINE_UNQUOTED(CLANG_FULL_VERSION,$CLANG_FULL_VERSION)
fi
fi
AC_SUBST(COM_GCC_IS_CLANG)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment