diff --git a/package/RedHat/flightgear.spec b/package/RedHat/flightgear.spec index 6feac439a..7c03fc1e4 100644 --- a/package/RedHat/flightgear.spec +++ b/package/RedHat/flightgear.spec @@ -6,17 +6,17 @@ Summary: The FlightGear Flight Simulator Name: %{name} Version: %{version} Release: %{release} -License: GPL +License: GPL-2.0 URL: http://www.flightgear.org Group: Games/Other BuildRoot: %{_tmppath}/%{name}-buildroot Source: http://mirrors.ibiblio.org/pub/mirrors/flightgear/ftp/Source/flightgear-%{version}.tar.bz2 Source1: http://mirrors.ibiblio.org/pub/mirrors/flightgear/ftp/Shared/FlightGear-data-%{version}.tar.bz2 Source3: flightgear.desktop +BuildRequires: gcc, gcc-c++, cmake BuildRequires: plib >= 1.8.0, SimGear = %{version} -BuildRequires: XFree86-devel, XFree86-Mesa-libGL, XFree86-Mesa-libGLU, gcc, zlib-devel +BuildRequires: XFree86-devel, XFree86-Mesa-libGL, XFree86-Mesa-libGLU, zlib-devel BuildRequires: OpenSceneGraph >= 3.0.0 -Requires: XFree86-devel, XFree86-Mesa-libGL, XFree86-Mesa-libGLU, gcc, zlib-devel Obsoletes: FlightGear Provides: FlightGear = %{version}-%{release} diff --git a/package/openSUSE/FlightGear.desktop b/package/openSUSE/FlightGear.desktop new file mode 100644 index 000000000..9fa442f5b --- /dev/null +++ b/package/openSUSE/FlightGear.desktop @@ -0,0 +1,7 @@ +[Desktop Entry] +Type=Application +Name=FlightGear +Comment=FlightGear Flight Simulator +Exec=fgfs +Icon=FlightGear +Categories=Game;Simulation; diff --git a/package/openSUSE/FlightGear.spec b/package/openSUSE/FlightGear.spec new file mode 100644 index 000000000..be2010d52 --- /dev/null +++ b/package/openSUSE/FlightGear.spec @@ -0,0 +1,78 @@ +Summary: The FlightGear Flight Simulator +Name: FlightGear +Version: 2.8.0 +Release: 1 +License: GPL-2.0 +URL: http://www.flightgear.org +Group: Amusements/Games/3D/Simulation +BuildRoot: %{_tmppath}/%{name}-buildroot +Source0: http://mirrors.ibiblio.org/pub/mirrors/flightgear/ftp/Source/flightgear-%{version}.tar.bz2 +Source1: %{name}.desktop + +BuildRequires: gcc, gcc-c++, cmake +BuildRequires: update-desktop-files +BuildRequires: SimGear = %{version}, SimGear-devel = %{version} +BuildRequires: libOpenSceneGraph-devel >= 3.0 +BuildRequires: subversion-devel, libapr1-devel +BuildRequires: freealut, freealut-devel +BuildRequires: libopenal1-soft, openal-soft +BuildRequires: zlib, zlib-devel +BuildRequires: libfreetype6 +BuildRequires: libjpeg62, libjpeg62-devel +BuildRequires: libudev-devel +BuildRequires: boost-devel >= 1.37 + +Requires: OpenSceneGraph-plugins >= 3.0 +Requires: FlightGear-data = %{version} +Requires: SimGear = %{version} + +%description +The FlightGear project is working to create a sophisticated flight simulator +framework for the development and pursuit of interesting flight simulator +ideas. We are developing a solid basic sim that can be expanded and improved +upon by anyone interested in contributing. + +%prep +%setup -q -n flightgear-%{version} -T -b 0 +rm -f docs-mini/* +# remove unnecessary DATE/TIME dependency +sed -i 's/__DATE__" "__TIME__//' src/FDM/JSBSim/FGJSBBase.cpp + +%build +export CFLAGS="$RPM_OPT_FLAGS" +export CXXFLAGS="$RPM_OPT_FLAGS" +export BUILD_ID=OpenSuSE +export BUILD_NUMBER=0 +cmake -DCMAKE_INSTALL_PREFIX=%{_prefix} -DSIMGEAR_SHARED:BOOL=ON -DENABLE_TESTS:BOOL=OFF -DFG_DATA_DIR:STRING="/usr/share/flightgear" -DJPEG_FACTORY:BOOL=ON +make %{?_smp_mflags} + +%install +make %{?_smp_mflags} install DESTDIR=$RPM_BUILD_ROOT +# install desktop link +mkdir -p $RPM_BUILD_ROOT/%{_datadir}/applications/ +cp %{SOURCE1} $RPM_BUILD_ROOT/%{_datadir}/applications/ +%suse_update_desktop_file -i %{name} +# move docs into doc/packages subfolder +mkdir -p $RPM_BUILD_ROOT/usr/share/doc/packages/FlightGear +cp README $RPM_BUILD_ROOT/usr/share/doc/packages/FlightGear/. +cp COPYING $RPM_BUILD_ROOT/usr/share/doc/packages/FlightGear/. +cp AUTHORS $RPM_BUILD_ROOT/usr/share/doc/packages/FlightGear/. +# install icon +mkdir -p $RPM_BUILD_ROOT%{_datadir}/pixmaps +cp icons/fg-128.png $RPM_BUILD_ROOT%{_datadir}/pixmaps/FlightGear.png +# remove obsolete/test utilities +cd $RPM_BUILD_ROOT/usr/bin && rm -f GPSsmooth MIDGsmooth UGsmooth metar + +%files +%defattr(-, root, root, -) +%dir /usr/share/doc/packages/FlightGear +/usr/share/doc/packages/FlightGear/* +%{_bindir}/* +%_mandir/man1/* +%{_datadir}/pixmaps/FlightGear.png +%{_datadir}/applications/%{name}.desktop + +%changelog +* Thu Jun 30 2012 thorstenb@flightgear.org +- Initial version + diff --git a/package/openSUSE/README b/package/openSUSE/README new file mode 100644 index 000000000..36f3e1e2b --- /dev/null +++ b/package/openSUSE/README @@ -0,0 +1,28 @@ +Building a FlightGear RPM package for openSUSE + +(Last tested with openSUSE 11.4+12.1) + +This directory contains the files which, along with +the source code tar files, can be used to build +an RPM package targeted at an openSUSE Linux system. + +To build FlightGear from source do the following: + +1. obtain flightgear-2.8.0.tar.bz2 (adapt version if + necessary) and copy it into ~/rpmbuild/SOURCES + +2. copy FlightGear.desktop to ~/rpmbuild/SOURCES + +3. obtain (or build) and install SimGear (exact + match with FlightGear's version required). + +4. look in the BuildRequires section of FlightGear.spec + and check that all the packages referred to are + installed (note, some of these packages may be part + of openSUSE's "games" repository). + +5. run 'rpmbuild -ba FlightGear.spec' and find the RPM + build result in ~/rpmbuild/RPMS + +That's all! + diff --git a/src/Canvas/ShivaVG/src/shDefs.h b/src/Canvas/ShivaVG/src/shDefs.h index d6e57a782..d0f3bb84d 100644 --- a/src/Canvas/ShivaVG/src/shDefs.h +++ b/src/Canvas/ShivaVG/src/shDefs.h @@ -159,6 +159,7 @@ SHfloat getMaxFloat(); #if defined(VG_API_LINUX) #include #include + #include #elif defined(VG_API_MACOSX) #include #include diff --git a/src/Canvas/ShivaVG/src/shGeometry.c b/src/Canvas/ShivaVG/src/shGeometry.c index 71ab463b0..3a711b37b 100644 --- a/src/Canvas/ShivaVG/src/shGeometry.c +++ b/src/Canvas/ShivaVG/src/shGeometry.c @@ -347,7 +347,7 @@ static void shSubdivideSegment(SHPath *p, VGPathSegment segment, void shFlattenPath(SHPath *p, SHint surfaceSpace) { SHint contourStart = -1; - SHint surfSpace = surfaceSpace; +// SHint surfSpace = surfaceSpace; SHint *userData[2]; SHint processFlags = SH_PROCESS_SIMPLIFY_LINES | diff --git a/src/Canvas/ShivaVG/src/shPaint.c b/src/Canvas/ShivaVG/src/shPaint.c index 2e1ba4ad2..406a889b8 100644 --- a/src/Canvas/ShivaVG/src/shPaint.c +++ b/src/Canvas/ShivaVG/src/shPaint.c @@ -405,7 +405,7 @@ int shDrawLinearGradientMesh(SHPaint *p, SHVector2 *min, SHVector2 *max, SHVector2 c, ux, uy; SHVector2 cc, uux, uuy; - SHMatrix3x3 *m; + SHMatrix3x3 *m = 0; SHMatrix3x3 mi; SHint invertible; SHVector2 corners[4]; @@ -521,7 +521,7 @@ int shDrawRadialGradientMesh(SHPaint *p, SHVector2 *min, SHVector2 *max, SHVector2 c, f; SHVector2 cf; - SHMatrix3x3 *m; + SHMatrix3x3 *m = 0; SHMatrix3x3 mi; SHint invertible; SHVector2 corners[4]; @@ -722,7 +722,7 @@ int shDrawRadialGradientMesh(SHPaint *p, SHVector2 *min, SHVector2 *max, int shDrawPatternMesh(SHPaint *p, SHVector2 *min, SHVector2 *max, VGPaintMode mode, GLenum texUnit) { - SHMatrix3x3 *m; + SHMatrix3x3 *m = 0; SHMatrix3x3 mi; SHfloat migl[16]; SHint invertible; diff --git a/src/Canvas/ShivaVG/src/shParams.c b/src/Canvas/ShivaVG/src/shParams.c index 3ed90fe84..2535c1497 100644 --- a/src/Canvas/ShivaVG/src/shParams.c +++ b/src/Canvas/ShivaVG/src/shParams.c @@ -839,9 +839,9 @@ static void shSetParameter(VGContext *context, VGHandle object, SHResourceType rtype, VGint ptype, SHint count, const void *values, SHint floats) { - SHfloat fvalue = 0.0f; +// SHfloat fvalue = 0.0f; SHint ivalue = 0; - VGboolean bvalue = VG_FALSE; +// VGboolean bvalue = VG_FALSE; int i; /* Check for negative count */ @@ -852,9 +852,9 @@ static void shSetParameter(VGContext *context, VGHandle object, /* Pre-convert first value for non-vector params */ if (count == 1) { - fvalue = shParamToFloat(values, floats, 0); +// fvalue = shParamToFloat(values, floats, 0); ivalue = shParamToInt(values, floats, 0); - bvalue = (ivalue ? VG_TRUE : VG_FALSE); +// bvalue = (ivalue ? VG_TRUE : VG_FALSE); } switch (rtype) diff --git a/src/Canvas/ShivaVG/src/shPipeline.c b/src/Canvas/ShivaVG/src/shPipeline.c index a03ced057..1e07bc56a 100644 --- a/src/Canvas/ShivaVG/src/shPipeline.c +++ b/src/Canvas/ShivaVG/src/shPipeline.c @@ -148,7 +148,7 @@ static void shDrawBoundBox(VGContext *c, SHPath *p, VGPaintMode mode) static void shDrawPaintMesh(VGContext *c, SHVector2 *min, SHVector2 *max, VGPaintMode mode, GLenum texUnit) { - SHPaint *p; + SHPaint *p = 0; SHVector2 pmin, pmax; SHfloat K = 1.0f; @@ -199,7 +199,7 @@ VGboolean shIsTessCacheValid (VGContext *c, SHPath *p) { SHfloat nX, nY; SHVector2 X, Y; - SHMatrix3x3 mi, mchange; + SHMatrix3x3 mi;//, mchange; VGboolean valid = VG_TRUE; if (p->cacheDataValid == VG_FALSE) { @@ -214,7 +214,7 @@ VGboolean shIsTessCacheValid (VGContext *c, SHPath *p) else { /* TODO: Compare change matrix for any scale or shear */ - MULMATMAT( c->pathTransform, mi, mchange ); +// MULMATMAT( c->pathTransform, mi, mchange ); SET2( X, mi.m[0][0], mi.m[1][0] ); SET2( Y, mi.m[0][1], mi.m[1][1] ); nX = NORM2( X ); nY = NORM2( Y ); diff --git a/src/Canvas/canvas.cxx b/src/Canvas/canvas.cxx index f1a6ef983..7f2c85902 100644 --- a/src/Canvas/canvas.cxx +++ b/src/Canvas/canvas.cxx @@ -434,15 +434,17 @@ void Canvas::clearPlacements(int index) osg::ref_ptr group = placements.back(); placements.pop_back(); - assert( group->getNumParents() == 1 ); assert( group->getNumChildren() == 1 ); - - osg::Group *parent = group->getParent(0); osg::Node *child = group->getChild(0); - parent->addChild(child); + if( group->getNumParents() ) + { + osg::Group *parent = group->getParent(0); + parent->addChild(child); + parent->removeChild(group); + } + group->removeChild(child); - parent->removeChild(group); } }