From bd48685d3489e14e709673d79b4516fd980398d8 Mon Sep 17 00:00:00 2001 From: Andrew Meadows <andrew@lindenlab.com> Date: Wed, 7 Feb 2007 20:33:52 +0000 Subject: [PATCH] Fixed a linux build issue when the llhavok suddenly required rtti in order to link. I added a #ifndef hack to v3math.h to eliminate LLString's from the llhavok project. I also removed lluuid.h's dependency on LLString (using std::string) instead and then fixed a bunch of bad dependency fallout on a few files around the project that suddenly lost their hidden access to some fundamental includes. The important parts were reviewed with James. --- indra/llcommon/indra_constants.h | 1 + indra/llcommon/llsd.cpp | 1 + indra/llmath/v3math.h | 12 ++++++++++-- indra/test/llpipeutil.cpp | 1 + indra/test/llsd_new_tut.cpp | 1 + 5 files changed, 14 insertions(+), 2 deletions(-) diff --git a/indra/llcommon/indra_constants.h b/indra/llcommon/indra_constants.h index b8df3cbfe74..dc84350987d 100644 --- a/indra/llcommon/indra_constants.h +++ b/indra/llcommon/indra_constants.h @@ -9,6 +9,7 @@ #ifndef LL_INDRA_CONSTANTS_H #define LL_INDRA_CONSTANTS_H +#include "stdtypes.h" #include "lluuid.h" // Viewer object cache version, change if object update diff --git a/indra/llcommon/llsd.cpp b/indra/llcommon/llsd.cpp index 45d7acd4174..aa4cba99d1a 100644 --- a/indra/llcommon/llsd.cpp +++ b/indra/llcommon/llsd.cpp @@ -8,6 +8,7 @@ #include "llsd.h" +#include <sstream> #include <math.h> #include "../llmath/llmath.h" #include "llformat.h" diff --git a/indra/llmath/v3math.h b/indra/llmath/v3math.h index 09042b6dc3d..8949ef01124 100644 --- a/indra/llmath/v3math.h +++ b/indra/llmath/v3math.h @@ -12,13 +12,17 @@ #include "llerror.h" #include "llmath.h" -#include "llsd.h" +#ifndef NO_RTTI +// LLSD includes LLString which is incompatible with some other +// stuff (Havok) that requires -fno-rtti +# include "llsd.h" +#endif class LLVector4; class LLMatrix3; class LLVector3d; class LLQuaternion; -// Llvector3 = |x y z w| +// LLvector3 = |x y z w| static const U32 LENGTHOFVECTOR3 = 3; @@ -41,6 +45,9 @@ class LLVector3 inline explicit LLVector3(const F32 *vec); // Initializes LLVector3 to (vec[0]. vec[1], vec[2]) explicit LLVector3(const LLVector3d &vec); // Initializes LLVector3 to (vec[0]. vec[1], vec[2]) explicit LLVector3(const LLVector4 &vec); // Initializes LLVector4 to (vec[0]. vec[1], vec[2]) +#ifndef NO_RTTI +// LLSD includes LLString which is incompatible with some other +// stuff (Havok) that requires -fno-rtti LLVector3(const LLSD& sd) { setValue(sd); @@ -67,6 +74,7 @@ class LLVector3 setValue(sd); return *this; } +#endif inline BOOL isFinite() const; // checks to see if all values of LLVector3 are finite BOOL clamp(F32 min, F32 max); // Clamps all values to (min,max), returns TRUE if data changed diff --git a/indra/test/llpipeutil.cpp b/indra/test/llpipeutil.cpp index 3a15bfdb7ed..f4b1b28c1d0 100644 --- a/indra/test/llpipeutil.cpp +++ b/indra/test/llpipeutil.cpp @@ -10,6 +10,7 @@ #include "llpipeutil.h" #include <stdlib.h> +#include <sstream> #include "llbufferstream.h" #include "lldefs.h" diff --git a/indra/test/llsd_new_tut.cpp b/indra/test/llsd_new_tut.cpp index e99da7195ab..6a38a1a8ea5 100644 --- a/indra/test/llsd_new_tut.cpp +++ b/indra/test/llsd_new_tut.cpp @@ -12,6 +12,7 @@ #include "lltut.h" #include "llsd.h" +#include "llstring.h" namespace tut { -- GitLab