diff options
author | amdmi3 <amdmi3@FreeBSD.org> | 2009-04-10 06:16:47 +0800 |
---|---|---|
committer | amdmi3 <amdmi3@FreeBSD.org> | 2009-04-10 06:16:47 +0800 |
commit | a93244698886030d685588cb7857ecceb52cb65f (patch) | |
tree | ce868368820f9f02d46b7a7e2fd062f468e35e61 /games | |
parent | b0653a9ab9e341c08d17668e58652ede4c5bbb02 (diff) | |
download | freebsd-ports-gnome-a93244698886030d685588cb7857ecceb52cb65f.tar.gz freebsd-ports-gnome-a93244698886030d685588cb7857ecceb52cb65f.tar.zst freebsd-ports-gnome-a93244698886030d685588cb7857ecceb52cb65f.zip |
Rigs of Rods (also known as RoR), is a truck, car, airplane and
boat simulator. You can drive, fly or sail in total freedom in an
open environment. What makes RoR different to most simulators is
its unique soft-body physics: vehicles chassis and wheels are
simulated in real-time as flexible objects, giving the simulation
an extremely accurate behavior, while allowing the vehicles to be
simply specified by their structural composition, as a network of
interconnected nodes (forming the chassis and the wheels). Crashing
into walls or terrain can permanently deform a vehicle in a realistic
manner. In addition to its unique soft-body physics, RoR also
features an advanced flight model based on blade element theory,
allowing the accurate simulation of any airplane, base on their
physical dimensions and wing airfoils. It also features an accurate
buoyancy model based on elemental pressure gradients, enabling boats
with complex hulls to move realistically in the swell.
WWW: http://www.rigsofrods.com/
Diffstat (limited to 'games')
20 files changed, 705 insertions, 0 deletions
diff --git a/games/Makefile b/games/Makefile index 4527025ecf34..a02f534afaab 100644 --- a/games/Makefile +++ b/games/Makefile @@ -722,6 +722,7 @@ SUBDIR += race SUBDIR += reminiscence SUBDIR += rfksay + SUBDIR += rgsofrods SUBDIR += ri-li SUBDIR += robocode SUBDIR += robotfindskitten diff --git a/games/rigsofrods/Makefile b/games/rigsofrods/Makefile new file mode 100644 index 000000000000..eb44cb367e40 --- /dev/null +++ b/games/rigsofrods/Makefile @@ -0,0 +1,103 @@ +# New ports collection makefile for: rigsofrods +# Date created: 05 Mar 2009 +# Whom: Dmitry Marakasov <amdmi3@FreeBSD.org> +# +# $FreeBSD$ +# + +PORTNAME= rigsofrods +PORTVERSION= 0.36.1 +CATEGORIES= games +# I've trimmed source tarball by around 10x and bundled rorserver +MASTER_SITES= SF:contents \ + http://mirror.amdmi3.ru:game +DISTFILES= ${PORTNAME}-source-${PORTVERSION}-trimmed${EXTRACT_SUFX}:game \ + ${PORTNAME}-contents-${PORTVERSION}.zip:contents +EXTRACT_ONLY= ${PORTNAME}-source-${PORTVERSION}-trimmed${EXTRACT_SUFX} + +MAINTAINER= amdmi3@FreeBSD.org +COMMENT= Truck, car, airplane and boat simulator with advanced physics + +LIB_DEPENDS= openal.0:${PORTSDIR}/audio/openal \ + zzip.13:${PORTSDIR}/devel/zziplib \ + freetype.9:${PORTSDIR}/print/freetype2 \ + CEGUIBase.3:${PORTSDIR}/graphics/cegui \ + freeimage:${PORTSDIR}/graphics/freeimage +BUILD_DEPENDS= ${LOCALBASE}/lib/libOIS.so:${PORTSDIR}/devel/ois \ + unzip:${PORTSDIR}/archivers/unzip +RUN_DEPENDS= ${LOCALBASE}/lib/libOIS.so:${PORTSDIR}/devel/ois \ + xset:${PORTSDIR}/x11/xset + +USE_XORG= x11 xt xaw sm ice xext +WRKSRC= ${WRKDIR}/${PORTVERSION}/build +USE_WX= 2.6+ +WX_UNICODE= yes +MAKE_JOBS_SAFE= yes + +USE_CMAKE= yes +# CG unavailable for FreeBSD; paged also requires CG +CMAKE_ARGS= -DROR_BUILD_HYDRAX=TRUE \ + -DROR_BUILD_PAGED=FALSE \ + -DROR_BUILD_LUASCRIPT=TRUE \ + -DROR_BUILD_CONFIGURATOR=TRUE \ + -DOGRE_BUILD_PLUGIN_CG=FALSE \ + -DLOCALBASE="${LOCALBASE}" \ + -DwxWidgets_CONFIG_EXECUTABLE="${WX_CONFIG}" +CMAKE_USE_PTHREAD= yes + +PORTDOCS= * + +SUB_FILES= RoR.sh rorconfig.sh + +LIB_FILES= dependencies/ogrenew/OgreMain/libOgreMain.so.1 \ + dependencies/ogrenew/PlugIns/OctreeSceneManager/Plugin_OctreeSceneManager.so \ + dependencies/ogrenew/PlugIns/ParticleFX/Plugin_ParticleFX.so \ + dependencies/ogrenew/RenderSystems/GL/RenderSystem_GL.so \ + dependencies/Caelum-2006-11-09/libcaelum.so \ + dependencies/mygui/libmygui.so \ + dependencies/mysocketw/libmysocketw.so + +post-extract: + @${RM} -rf ${WRKSRC}/dependencies/ogrenew/Dependencies + +post-patch: + @${REINPLACE_CMD} -e 's|%%DATADIR%%|${DATADIR}|; \ + s|%%PREFIX%%|${PREFIX}|' \ + ${WRKSRC}/main/source/Settings.cpp \ + ${WRKSRC}/configurator/source/configurator.cpp + +do-install: +# libs + ${MKDIR} ${PREFIX}/lib/${PORTNAME} +.for f in ${LIB_FILES} + ${INSTALL_PROGRAM} ${WRKSRC}/${f} ${PREFIX}/lib/${PORTNAME} +.endfor + +# binaries + ${MKDIR} ${PREFIX}/libexec/${PORTNAME} + ${INSTALL_PROGRAM} ${WRKSRC}/main/RoR ${PREFIX}/libexec/${PORTNAME} + ${INSTALL_PROGRAM} ${WRKSRC}/configurator/rorconfig ${PREFIX}/libexec/${PORTNAME} + +# data + ${MKDIR} ${DATADIR} + ${SED} -e '/Plugin_CgProgramManager/ s|^|#|' \ + < ${WRKSRC}/bin/release/linux/plugins.cfg \ + > ${DATADIR}/plugins.cfg + unzip -qq -o -d ${DATADIR} ${DISTDIR}/${PORTNAME}-contents-${PORTVERSION}.zip \ + languages/\* resources/\* skeleton/\* streams/\* + +# wrappers + ${INSTALL_SCRIPT} ${WRKDIR}/RoR.sh ${PREFIX}/bin/RoR + ${INSTALL_SCRIPT} ${WRKDIR}/rorconfig.sh ${PREFIX}/bin/rorconfig + +#docs +.if !defined(NOPORTDOCS) + ${MKDIR} ${DOCSDIR} + unzip -qq -o -d ${DOCSDIR} ${DISTDIR}/${PORTNAME}-contents-${PORTVERSION}.zip \ + \*.pdf +.endif + +post-install: + @${CAT} ${PKGMESSAGE} + +.include <bsd.port.mk> diff --git a/games/rigsofrods/distinfo b/games/rigsofrods/distinfo new file mode 100644 index 000000000000..df22dc9b02db --- /dev/null +++ b/games/rigsofrods/distinfo @@ -0,0 +1,6 @@ +MD5 (rigsofrods-source-0.36.1-trimmed.tar.gz) = ae4d305535c780c271da375b2fd42f5c +SHA256 (rigsofrods-source-0.36.1-trimmed.tar.gz) = 4a923bfd652bd8398aa2f21022fe72a083905d1ee7696bf10e3b781478d9b7ed +SIZE (rigsofrods-source-0.36.1-trimmed.tar.gz) = 21781314 +MD5 (rigsofrods-contents-0.36.1.zip) = bfa066124b7e8ca48bc0dce45149c886 +SHA256 (rigsofrods-contents-0.36.1.zip) = c3fe969f67cea9a8b2750271fe2b03f6f522dda9f07bc1a47cb9dda8e95c09e9 +SIZE (rigsofrods-contents-0.36.1.zip) = 122490754 diff --git a/games/rigsofrods/files/RoR.sh.in b/games/rigsofrods/files/RoR.sh.in new file mode 100644 index 000000000000..1b36d310b6be --- /dev/null +++ b/games/rigsofrods/files/RoR.sh.in @@ -0,0 +1,19 @@ +#!/bin/sh + +RORDIR=%%PREFIX%%/lib/rigsofrods +DOTDIR=$HOME/.RigsOfRods + +if [ ! -e "$DOTDIR" ]; then + echo "Populating $DOTDIR..." + cd %%DATADIR%%/skeleton && find . -type d -exec mkdir -p "$DOTDIR/{}" \; + cd %%DATADIR%%/skeleton && find . -type f -exec cp -n {} "$DOTDIR/{}" \; +fi + +LD_LIBRARY_PATH=$RORDIR:$LD_LIBRARY_PATH +export LD_LIBRARY_PATH + +cd $RORDIR +%%PREFIX%%/libexec/rigsofrods/RoR "$@" + +# re-enable key repeat (which is disabled by RoR for some reason) +xset r diff --git a/games/rigsofrods/files/patch-CMakeLists.txt b/games/rigsofrods/files/patch-CMakeLists.txt new file mode 100644 index 000000000000..8568c1382702 --- /dev/null +++ b/games/rigsofrods/files/patch-CMakeLists.txt @@ -0,0 +1,19 @@ +--- CMakeLists.txt.orig 2009-02-22 20:59:55.000000000 +0300 ++++ CMakeLists.txt 2009-03-05 04:01:24.000000000 +0300 +@@ -3,11 +3,11 @@ + project(RoR)
+
+ #detup the default build mode
+-IF(NOT CMAKE_BUILD_TYPE)
+- SET(CMAKE_BUILD_TYPE RelWithDebInfo CACHE STRING
+- "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel."
+- FORCE)
+-ENDIF(NOT CMAKE_BUILD_TYPE)
++#IF(NOT CMAKE_BUILD_TYPE)
++# SET(CMAKE_BUILD_TYPE RelWithDebInfo CACHE STRING
++# "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel."
++# FORCE)
++#ENDIF(NOT CMAKE_BUILD_TYPE)
+
+ # setup path for cmake add-ons
+ SET(RoR_Dependencies_CMAKE_DIR "${RoR_SOURCE_DIR}/dependencies/cmake")
diff --git a/games/rigsofrods/files/patch-configurator-CMakeLists.txt b/games/rigsofrods/files/patch-configurator-CMakeLists.txt new file mode 100644 index 000000000000..7f5ca51b8264 --- /dev/null +++ b/games/rigsofrods/files/patch-configurator-CMakeLists.txt @@ -0,0 +1,26 @@ +--- configurator/CMakeLists.txt.orig 2009-02-22 20:59:55.000000000 +0300 ++++ configurator/CMakeLists.txt 2009-03-07 03:57:31.000000000 +0300 +@@ -22,9 +22,12 @@ + link_directories (${wxWidgets_LIB_DIR}) + include_directories (${RoR_Dependencies_SOURCE_DIR}/rorserver-sf/source) + include_directories (${RoR_Dependencies_SOURCE_DIR}/ogrenew/OgreMain/include) +- include_directories (${RoR_Dependencies_SOURCE_DIR}/ogrenew/Dependencies/include) +- include_directories (${RoR_Dependencies_SOURCE_DIR}/OIS-HEAD/ois/includes) ++ # include_directories (${RoR_Dependencies_SOURCE_DIR}/ogrenew/Dependencies/include) ++ # include_directories (${RoR_Dependencies_SOURCE_DIR}/OIS-HEAD/ois/includes) + include_directories (${RoR_Main_SOURCE_DIR}/source) ++ include_directories (${LOCALBASE}/include/OIS) ++ ++ add_definitions("-D\"strnlen(a,b)=strlen(a)\"") + + SET(config_source ${config_source} ${RoR_SOURCE_DIR}/main/source/InputEngine.cpp) + +@@ -43,7 +46,7 @@ + + add_executable(rorconfig ${config_source} ${config_headers} ${config_res}) + TARGET_LINK_LIBRARIES(rorconfig ${wxWidgets_LIBRARIES} ) +- target_link_libraries(rorconfig OgreMain ois) ++ target_link_libraries(rorconfig OgreMain ${LOCALBASE}/lib/libOIS.so) + + IF(WIN32) + SET_TARGET_PROPERTIES(rorconfig PROPERTIES COMPILE_FLAGS "") diff --git a/games/rigsofrods/files/patch-configurator-source-configurator.cpp b/games/rigsofrods/files/patch-configurator-source-configurator.cpp new file mode 100644 index 000000000000..5bf3db1d82fb --- /dev/null +++ b/games/rigsofrods/files/patch-configurator-source-configurator.cpp @@ -0,0 +1,31 @@ +--- configurator/source/configurator.cpp.orig 2009-02-22 20:59:55.000000000 +0300 ++++ configurator/source/configurator.cpp 2009-04-09 07:25:25.000000000 +0400 +@@ -1109,17 +1109,12 @@ + char procpath[256];
+ char user_path[1024];
+ char program_path[1024];
+- sprintf(procpath, "/proc/%d/exe", pid);
+- int ch = readlink(procpath,program_path,240);
+- if (ch != -1)
+- {
+- program_path[ch] = 0;
+- } else return false;
++ strcpy(program_path, "%%DATADIR%%/");
+ ProgramPath=wxFileName(wxString(conv(program_path))).GetPath();
+ //user path is easy
+ strncpy(user_path, getenv ("HOME"), 240);
+ wxFileName tfn=wxFileName(conv(user_path), wxEmptyString);
+- tfn.AppendDir(_T("RigsOfRods"));
++ tfn.AppendDir(_T(".RigsOfRods"));
+ UserPath=tfn.GetPath();
+ #endif
+ #if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
+@@ -2692,7 +2687,7 @@ + CreateProcess(NULL, wpath, NULL, NULL, false, NORMAL_PRIORITY_CLASS, NULL, NULL, &si, &pi);
+ #endif
+ #if OGRE_PLATFORM == OGRE_PLATFORM_LINUX
+- execl("./RoR.bin", "", (char *) 0);
++ execl("%%PREFIX%%/bin/RoR", "", (char *) 0);
+ #endif
+ #if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
+ FSRef ref;
diff --git a/games/rigsofrods/files/patch-dependencies-CMakeLists.txt b/games/rigsofrods/files/patch-dependencies-CMakeLists.txt new file mode 100644 index 000000000000..53c2fbfe7662 --- /dev/null +++ b/games/rigsofrods/files/patch-dependencies-CMakeLists.txt @@ -0,0 +1,21 @@ +--- dependencies/CMakeLists.txt.orig 2009-02-22 20:59:55.000000000 +0300 ++++ dependencies/CMakeLists.txt 2009-03-05 03:49:28.000000000 +0300 +@@ -6,9 +6,9 @@ + endif(ROR_BUILD_LUASCRIPT)
+
+ add_subdirectory("mysocketw")
+-add_subdirectory("OIS-HEAD")
++#add_subdirectory("OIS-HEAD")
+ #add_subdirectory("openal-soft-1.5.304")
+-add_subdirectory("openal-soft-1.6.372")
++#add_subdirectory("openal-soft-1.6.372")
+
+ set(OGRE_SET_DISABLE_FREEIMAGE 1)
+ add_subdirectory("ogrenew")
+@@ -34,4 +34,4 @@ + add_subdirectory("raknet")
+ endif(ROR_BUILD_NEWNET)
+
+-add_subdirectory("mygui") +\ No newline at end of file ++add_subdirectory("mygui")
diff --git a/games/rigsofrods/files/patch-dependencies-mygui-CMakeLists.txt b/games/rigsofrods/files/patch-dependencies-mygui-CMakeLists.txt new file mode 100644 index 000000000000..28cb009312a6 --- /dev/null +++ b/games/rigsofrods/files/patch-dependencies-mygui-CMakeLists.txt @@ -0,0 +1,14 @@ +--- dependencies/mygui/CMakeLists.txt.orig 2009-02-22 20:59:55.000000000 +0300 ++++ dependencies/mygui/CMakeLists.txt 2009-03-05 05:39:37.000000000 +0300 +@@ -4,8 +4,9 @@ + include_directories (include)
+
+ include_directories (${RoR_Dependencies_SOURCE_DIR}/ogrenew/OgreMain/include)
+-include_directories (${RoR_Dependencies_SOURCE_DIR}/ogrenew/Dependencies/include) # for freetype
+-include_directories (${RoR_Dependencies_SOURCE_DIR}/OIS-HEAD/ois/includes)
++include_directories (${LOCALBASE}/include/freetype2)
++include_directories (${LOCALBASE}/include/OIS)
++include_directories (${LOCALBASE}/include)
+
+ # -DHYDRAX_LIB will give us the correct dllspec export setting
+ add_definitions("-D_USRDLL -DMYGUI_BUILD")
diff --git a/games/rigsofrods/files/patch-dependencies-ogrenew-OgreMain-CMakeLists.txt b/games/rigsofrods/files/patch-dependencies-ogrenew-OgreMain-CMakeLists.txt new file mode 100644 index 000000000000..fdee2df2b828 --- /dev/null +++ b/games/rigsofrods/files/patch-dependencies-ogrenew-OgreMain-CMakeLists.txt @@ -0,0 +1,11 @@ +--- dependencies/ogrenew/OgreMain/CMakeLists.txt.orig 2009-02-22 20:59:55.000000000 +0300 ++++ dependencies/ogrenew/OgreMain/CMakeLists.txt 2009-03-05 05:36:44.000000000 +0300 +@@ -449,7 +449,7 @@ + set(PLATFORM_LIBS ${X11_LIBRARIES} ${X11_Xt_LIB} ${XAW_LIBRARY})
+ set(PLATFORM_HEADER_INSTALL "GLX")
+
+- set(FREEIMAGE_INCLUDE_DIR ${FREEIMAGE_INCLUDE_DIR} /usr/include/freetype2)
++ set(FREEIMAGE_INCLUDE_DIR ${FREEIMAGE_INCLUDE_DIR} ${LOCALBASE}/include/freetype2)
+ elseif (APPLE)
+ include_directories("include/OSX")
+ endif(WIN32)
diff --git a/games/rigsofrods/files/patch-dependencies-ogrenew-OgreMain-include-OgreAxisAlignedBox.h b/games/rigsofrods/files/patch-dependencies-ogrenew-OgreMain-include-OgreAxisAlignedBox.h new file mode 100644 index 000000000000..2561f354cd3c --- /dev/null +++ b/games/rigsofrods/files/patch-dependencies-ogrenew-OgreMain-include-OgreAxisAlignedBox.h @@ -0,0 +1,13 @@ +--- dependencies/ogrenew/OgreMain/include/OgreAxisAlignedBox.h.orig 2009-02-22 20:59:55.000000000 +0300 ++++ dependencies/ogrenew/OgreMain/include/OgreAxisAlignedBox.h 2009-04-08 05:57:39.000000000 +0400 +@@ -235,8 +235,8 @@ + */ + inline void setExtents( const Vector3& min, const Vector3& max ) + { +- assert( (min.x <= max.x && min.y <= max.y && min.z <= max.z) && +- "The minimum corner of the box must be less than or equal to maximum corner" ); ++// assert( (min.x <= max.x && min.y <= max.y && min.z <= max.z) && ++// "The minimum corner of the box must be less than or equal to maximum corner" ); + + mExtent = EXTENT_FINITE; + mMinimum = min; diff --git a/games/rigsofrods/files/patch-dependencies-ogrenew-RenderSystems-GL-CMakeLists.txt b/games/rigsofrods/files/patch-dependencies-ogrenew-RenderSystems-GL-CMakeLists.txt new file mode 100644 index 000000000000..2ba581700064 --- /dev/null +++ b/games/rigsofrods/files/patch-dependencies-ogrenew-RenderSystems-GL-CMakeLists.txt @@ -0,0 +1,31 @@ +--- dependencies/ogrenew/RenderSystems/GL/CMakeLists.txt.orig 2009-02-22 20:59:55.000000000 +0300 ++++ dependencies/ogrenew/RenderSystems/GL/CMakeLists.txt 2009-03-05 04:57:40.000000000 +0300 +@@ -157,16 +157,19 @@ + src/GLX/OgreGLXWindow.cpp + src/GLX/OgreGLXUtils.cpp + ) +- include_directories(src/GLX include/GLX) ++ include_directories(BEFORE src/GLX include/GLX) + elseif (APPLE) + endif () + + +-include_directories( ++include_directories(BEFORE + ${CMAKE_CURRENT_SOURCE_DIR}/include + ${CMAKE_CURRENT_SOURCE_DIR}/src/GLSL/include + ${CMAKE_CURRENT_SOURCE_DIR}/src/atifs/include + ${CMAKE_CURRENT_SOURCE_DIR}/src/nvparse ++) ++ ++include_directories( + ${OPENGL_INCLUDE_DIR} + ) + +@@ -188,4 +191,4 @@ + RUNTIME DESTINATION ${BIN_DIR} + LIBRARY DESTINATION ${BIN_DIR} + ARCHIVE DESTINATION ${LIB_DIR}) +- +\ No newline at end of file ++ diff --git a/games/rigsofrods/files/patch-main-CMakeLists.txt b/games/rigsofrods/files/patch-main-CMakeLists.txt new file mode 100644 index 000000000000..792e0782bf7e --- /dev/null +++ b/games/rigsofrods/files/patch-main-CMakeLists.txt @@ -0,0 +1,68 @@ +--- main/CMakeLists.txt.orig 2009-02-22 20:59:55.000000000 +0300 ++++ main/CMakeLists.txt 2009-03-06 03:01:23.000000000 +0300 +@@ -12,12 +12,13 @@ + include_directories (${RoR_Dependencies_SOURCE_DIR}/Caelum-2006-11-09/include)
+ endif(CAELUM_BUILD_NEW)
+
+-include_directories (${RoR_Dependencies_SOURCE_DIR}/openal-soft-1.6.372/include/AL)
+-include_directories (${RoR_Dependencies_SOURCE_DIR}/openal-soft-1.6.372/include)
+-include_directories (${RoR_Dependencies_SOURCE_DIR}/OIS-HEAD/ois/includes)
+ include_directories (${RoR_Dependencies_SOURCE_DIR}/moFileReader/include)
+ include_directories (${RoR_Dependencies_SOURCE_DIR}/rorserver-sf/source)
+ include_directories (${RoR_Dependencies_SOURCE_DIR}/mygui/include)
++include_directories (${LOCALBASE}/include/OIS)
++include_directories (${LOCALBASE}/include/AL)
++
++add_definitions("-D\"strnlen(a,b)=strlen(a)\"")
+
+ IF(WIN32)
+ add_definitions("-D_CRT_SECURE_NO_WARNINGS")
+@@ -98,7 +99,7 @@ + add_executable(RoR ${ror_src} source/icon.rc)
+
+ # add dependencies
+-add_dependencies(RoR OgreMain caelum mysocketw ois mygui mofilereader)
++add_dependencies(RoR OgreMain caelum mysocketw mygui mofilereader)
+
+ # optional features
+ if(ROR_BUILD_HYDRAX)
+@@ -132,7 +133,6 @@ + caelum
+ mysocketw
+ OgreMain
+- ois
+ mygui
+ mofilereader
+ )
+@@ -152,9 +152,8 @@ +
+ target_link_libraries(RoR openal32)
+ ELSEIF(UNIX)
+- SET_TARGET_PROPERTIES(RoR PROPERTIES COMPILE_FLAGS "-msse2 -msse2 -mmmx -msse -msse3 -mssse3 -m3dnow")
++ SET_TARGET_PROPERTIES(RoR PROPERTIES COMPILE_FLAGS "-msse2 -msse2 -mmmx -msse -msse3 -m3dnow")
+ SET_TARGET_PROPERTIES(RoR PROPERTIES LINK_FLAGS "")
+- target_link_libraries(RoR openal)
+ ELSEIF(APPLE)
+ ENDIF(WIN32)
+
+@@ -191,12 +190,14 @@ + ELSEIF(UNIX)
+ target_link_libraries(RoR
+ # /usr/lib/libossp-uuid_dce.so
+- /usr/lib/libzzip.so
+- /usr/lib/libfreetype.so
+- /usr/lib/libX11.so
+- /usr/lib/libXt.so
+-
+- /usr/lib/libXaw.so
++ ${LOCALBASE}/lib/libzzip.so
++ ${LOCALBASE}/lib/libfreetype.so
++ ${LOCALBASE}/lib/libX11.so
++ ${LOCALBASE}/lib/libXt.so
++
++ ${LOCALBASE}/lib/libXaw.so
++ ${LOCALBASE}/lib/libOIS.so
++ ${LOCALBASE}/lib/libopenal.so
+ )
+ ELSEIF(APPLE)
+ ENDIF(WIN32)
diff --git a/games/rigsofrods/files/patch-main-source-Beam.cpp b/games/rigsofrods/files/patch-main-source-Beam.cpp new file mode 100644 index 000000000000..e12ab89b74af --- /dev/null +++ b/games/rigsofrods/files/patch-main-source-Beam.cpp @@ -0,0 +1,10 @@ +--- main/source/Beam.cpp.orig 2009-02-22 20:59:55.000000000 +0300 ++++ main/source/Beam.cpp 2009-03-07 17:36:32.000000000 +0300 +@@ -293,6 +293,7 @@ + + } + #endif ++ skidNode = 0; + + collisions=icollisions; + diff --git a/games/rigsofrods/files/patch-main-source-InputEngine.cpp b/games/rigsofrods/files/patch-main-source-InputEngine.cpp new file mode 100644 index 000000000000..54f6515f0658 --- /dev/null +++ b/games/rigsofrods/files/patch-main-source-InputEngine.cpp @@ -0,0 +1,35 @@ +--- main/source/InputEngine.cpp.orig 2009-02-22 20:59:55.000000000 +0300 ++++ main/source/InputEngine.cpp 2009-03-06 02:56:37.000000000 +0300 +@@ -46,10 +46,10 @@ + #define OIS_DYNAMIC_LIB + #include <OIS.h> + +-#if OGRE_PLATFORM == OGRE_PLATFORM_LINUX +-#include <X11/Xlib.h> +-#include <linux/LinuxMouse.h> +-#endif ++//#if OGRE_PLATFORM == OGRE_PLATFORM_LINUX ++//#include <X11/Xlib.h> ++//#include <linux/LinuxMouse.h> ++//#endif + + using namespace std; + using namespace Ogre; +@@ -204,7 +204,7 @@ + if((enable && lastmode == 0) || (!enable && lastmode == 1) || (lastmode == -1)) + { + LogManager::getSingleton().logMessage("*** mouse grab: " + StringConverter::toString(enable)); +- ((LinuxMouse *)mMouse)->grab(enable); ++ //((LinuxMouse *)mMouse)->grab(enable); + lastmode = enable?1:0; + } + #endif +@@ -218,7 +218,7 @@ + #if OGRE_PLATFORM == OGRE_PLATFORM_LINUX + if((visible && mode == 0) || (!visible && mode == 1) || mode == -1) + { +- ((LinuxMouse *)mMouse)->hide(visible); ++ //((LinuxMouse *)mMouse)->hide(visible); + mode = visible?1:0; + } + #endif diff --git a/games/rigsofrods/files/patch-main-source-Settings.cpp b/games/rigsofrods/files/patch-main-source-Settings.cpp new file mode 100644 index 000000000000..50c6c9a5a671 --- /dev/null +++ b/games/rigsofrods/files/patch-main-source-Settings.cpp @@ -0,0 +1,22 @@ +--- main/source/Settings.cpp.orig 2009-02-22 20:59:55.000000000 +0300 ++++ main/source/Settings.cpp 2009-04-09 07:24:33.000000000 +0400 +@@ -123,17 +123,10 @@ + //true program path is impossible to get from POSIX functions + //lets hack! + pid_t pid = getpid(); +- char procpath[256]; +- sprintf(procpath, "/proc/%d/exe", pid); +- int ch = readlink(procpath,program_path,240); +- if (ch != -1) +- { +- program_path[ch] = 0; +- path_descend(program_path); +- } else return false; ++ strcpy(program_path, "%%DATADIR%%/"); + //user path is easy + strncpy(user_path, getenv ("HOME"), 240); +- sprintf(user_path, "%s/RigsOfRods/", user_path); ++ sprintf(user_path, "%s/.RigsOfRods/", user_path); + #elif OGRE_PLATFORM == OGRE_PLATFORM_APPLE + //found this code, will look later + std::string path = "./"; diff --git a/games/rigsofrods/files/rorconfig.sh.in b/games/rigsofrods/files/rorconfig.sh.in new file mode 100644 index 000000000000..0ad09b1033f4 --- /dev/null +++ b/games/rigsofrods/files/rorconfig.sh.in @@ -0,0 +1,16 @@ +#!/bin/sh + +RORDIR=%%PREFIX%%/lib/rigsofrods +DOTDIR=$HOME/.RigsOfRods + +if [ ! -e "$DOTDIR" ]; then + echo "Populating $DOTDIR..." + cd %%DATADIR%%/skeleton && find . -type d -exec mkdir -p "$DOTDIR/{}" \; + cd %%DATADIR%%/skeleton && find . -type f -exec cp -n {} "$DOTDIR/{}" \; +fi + +LD_LIBRARY_PATH=$RORDIR:$LD_LIBRARY_PATH +export LD_LIBRARY_PATH + +cd $RORDIR +exec %%PREFIX%%/libexec/rigsofrods/rorconfig "$@" diff --git a/games/rigsofrods/pkg-descr b/games/rigsofrods/pkg-descr new file mode 100644 index 000000000000..fe72406d5177 --- /dev/null +++ b/games/rigsofrods/pkg-descr @@ -0,0 +1,17 @@ +Rigs of Rods (also known as RoR), is a truck, car, airplane and +boat simulator. You can drive, fly or sail in total freedom in an +open environment. What makes RoR different to most simulators is +its unique soft-body physics: vehicles chassis and wheels are +simulated in real-time as flexible objects, giving the simulation +an extremely accurate behavior, while allowing the vehicles to be +simply specified by their structural composition, as a network of +interconnected nodes (forming the chassis and the wheels). Crashing +into walls or terrain can permanently deform a vehicle in a realistic +manner. In addition to its unique soft-body physics, RoR also +features an advanced flight model based on blade element theory, +allowing the accurate simulation of any airplane, base on their +physical dimensions and wing airfoils. It also features an accurate +buoyancy model based on elemental pressure gradients, enabling boats +with complex hulls to move realistically in the swell. + +WWW: http://www.rigsofrods.com/ diff --git a/games/rigsofrods/pkg-message b/games/rigsofrods/pkg-message new file mode 100644 index 000000000000..e4e8ddeb3417 --- /dev/null +++ b/games/rigsofrods/pkg-message @@ -0,0 +1,13 @@ +========================================================================== + +Note that RoR was built without CgProgramManager ogre3d plugin +(which is not avialable for FreeBSD because it depends on proprietary +NVidia CG Toolkit), which means that some visual effects will either +not work or will prevent game from running. You can always run +rorconfig and disable them. + +Also note that there's some sound problems still unresolved. + +Don't forget to run rorconfig before running the game. + +========================================================================== diff --git a/games/rigsofrods/pkg-plist b/games/rigsofrods/pkg-plist new file mode 100644 index 000000000000..6e7f99df5303 --- /dev/null +++ b/games/rigsofrods/pkg-plist @@ -0,0 +1,229 @@ +bin/RoR +bin/rorconfig +lib/rigsofrods/Plugin_OctreeSceneManager.so +lib/rigsofrods/Plugin_ParticleFX.so +lib/rigsofrods/RenderSystem_GL.so +lib/rigsofrods/libOgreMain.so.1 +lib/rigsofrods/libcaelum.so +lib/rigsofrods/libmygui.so +lib/rigsofrods/libmysocketw.so +libexec/rigsofrods/RoR +libexec/rigsofrods/rorconfig +%%DATADIR%%/languages/ar/codes.txt +%%DATADIR%%/languages/ar/ror.mo +%%DATADIR%%/languages/ar/ror.po +%%DATADIR%%/languages/bg/codes.txt +%%DATADIR%%/languages/bg/ror.mo +%%DATADIR%%/languages/bg/ror.po +%%DATADIR%%/languages/bn/codes.txt +%%DATADIR%%/languages/bn/ror.mo +%%DATADIR%%/languages/bn/ror.po +%%DATADIR%%/languages/cs/codes.txt +%%DATADIR%%/languages/cs/ror.mo +%%DATADIR%%/languages/cs/ror.po +%%DATADIR%%/languages/da/codes.txt +%%DATADIR%%/languages/da/ror.mo +%%DATADIR%%/languages/da/ror.po +%%DATADIR%%/languages/de/codes.txt +%%DATADIR%%/languages/de/ror.mo +%%DATADIR%%/languages/de/ror.po +%%DATADIR%%/languages/el/codes.txt +%%DATADIR%%/languages/el/ror.mo +%%DATADIR%%/languages/el/ror.po +%%DATADIR%%/languages/en/codes.txt +%%DATADIR%%/languages/en/ror.mo +%%DATADIR%%/languages/en/ror.po +%%DATADIR%%/languages/es/codes.txt +%%DATADIR%%/languages/es/ror.mo +%%DATADIR%%/languages/es/ror.po +%%DATADIR%%/languages/et/codes.txt +%%DATADIR%%/languages/et/ror.mo +%%DATADIR%%/languages/et/ror.po +%%DATADIR%%/languages/fi/codes.txt +%%DATADIR%%/languages/fi/ror.mo +%%DATADIR%%/languages/fi/ror.po +%%DATADIR%%/languages/fr/codes.txt +%%DATADIR%%/languages/fr/ror.mo +%%DATADIR%%/languages/fr/ror.po +%%DATADIR%%/languages/hi/codes.txt +%%DATADIR%%/languages/hi/ror.mo +%%DATADIR%%/languages/hi/ror.po +%%DATADIR%%/languages/hu/codes.txt +%%DATADIR%%/languages/hu/ror.mo +%%DATADIR%%/languages/hu/ror.po +%%DATADIR%%/languages/id/codes.txt +%%DATADIR%%/languages/id/ror.mo +%%DATADIR%%/languages/id/ror.po +%%DATADIR%%/languages/is/codes.txt +%%DATADIR%%/languages/is/ror.mo +%%DATADIR%%/languages/is/ror.po +%%DATADIR%%/languages/it/codes.txt +%%DATADIR%%/languages/it/ror.mo +%%DATADIR%%/languages/it/ror.po +%%DATADIR%%/languages/ja/codes.txt +%%DATADIR%%/languages/ja/ror.po +%%DATADIR%%/languages/la/codes.txt +%%DATADIR%%/languages/la/ror.mo +%%DATADIR%%/languages/la/ror.po +%%DATADIR%%/languages/lt/codes.txt +%%DATADIR%%/languages/lt/ror.mo +%%DATADIR%%/languages/lt/ror.po +%%DATADIR%%/languages/nl/codes.txt +%%DATADIR%%/languages/nl/ror.mo +%%DATADIR%%/languages/nl/ror.po +%%DATADIR%%/languages/nn/codes.txt +%%DATADIR%%/languages/nn/ror.mo +%%DATADIR%%/languages/nn/ror.po +%%DATADIR%%/languages/pl/codes.txt +%%DATADIR%%/languages/pl/ror.mo +%%DATADIR%%/languages/pl/ror.po +%%DATADIR%%/languages/pt/codes.txt +%%DATADIR%%/languages/pt/ror.mo +%%DATADIR%%/languages/pt/ror.po +%%DATADIR%%/languages/ro/codes.txt +%%DATADIR%%/languages/ro/ror.mo +%%DATADIR%%/languages/ro/ror.po +%%DATADIR%%/languages/ru/codes.txt +%%DATADIR%%/languages/ru/ror.mo +%%DATADIR%%/languages/ru/ror.po +%%DATADIR%%/languages/sk/codes.txt +%%DATADIR%%/languages/sk/ror.mo +%%DATADIR%%/languages/sk/ror.po +%%DATADIR%%/languages/sl/codes.txt +%%DATADIR%%/languages/sl/ror.mo +%%DATADIR%%/languages/sl/ror.po +%%DATADIR%%/languages/sv/codes.txt +%%DATADIR%%/languages/sv/ror.mo +%%DATADIR%%/languages/sv/ror.po +%%DATADIR%%/languages/tr/codes.txt +%%DATADIR%%/languages/tr/ror.mo +%%DATADIR%%/languages/tr/ror.po +%%DATADIR%%/languages/ur/codes.txt +%%DATADIR%%/languages/ur/ror.mo +%%DATADIR%%/languages/ur/ror.po +%%DATADIR%%/languages/zh/codes.txt +%%DATADIR%%/languages/zh/ror.mo +%%DATADIR%%/languages/zh/ror.po +%%DATADIR%%/plugins.cfg +%%DATADIR%%/resources/OgreCore.zip +%%DATADIR%%/resources/airfoils.zip +%%DATADIR%%/resources/hydrax.zip +%%DATADIR%%/resources/materials.zip +%%DATADIR%%/resources/meshes.zip +%%DATADIR%%/resources/mygui.zip +%%DATADIR%%/resources/overlays.zip +%%DATADIR%%/resources/paged.zip +%%DATADIR%%/resources/particles.zip +%%DATADIR%%/resources/scripts.zip +%%DATADIR%%/resources/sounds.zip +%%DATADIR%%/resources/textures.zip +%%DATADIR%%/skeleton/config/RoR.cfg +%%DATADIR%%/skeleton/config/categories.cfg +%%DATADIR%%/skeleton/config/editor.cfg +%%DATADIR%%/skeleton/config/ground_models.cfg +%%DATADIR%%/skeleton/config/input.map +%%DATADIR%%/skeleton/config/inputevents.cfg +%%DATADIR%%/skeleton/config/ogre.cfg +%%DATADIR%%/skeleton/config/wavefield.cfg +%%DATADIR%%/streams/final/terrains/BajaTrack.zip +%%DATADIR%%/streams/final/terrains/BakersRanch.zip +%%DATADIR%%/streams/final/terrains/Flatmap.zip +%%DATADIR%%/streams/final/terrains/aspen.zip +%%DATADIR%%/streams/final/terrains/bajarama.zip +%%DATADIR%%/streams/final/terrains/f1track.zip +%%DATADIR%%/streams/final/terrains/grenoble.zip +%%DATADIR%%/streams/final/terrains/island.zip +%%DATADIR%%/streams/final/terrains/nhelens.zip +%%DATADIR%%/streams/final/terrains/smallisland.zip +%%DATADIR%%/streams/final/vehicles/1stGenDodges.zip +%%DATADIR%%/streams/final/vehicles/767.zip +%%DATADIR%%/streams/final/vehicles/AST1Xplanetowtruck.zip +%%DATADIR%%/streams/final/vehicles/An-12.zip +%%DATADIR%%/streams/final/vehicles/An225.zip +%%DATADIR%%/streams/final/vehicles/BobcatS130.zip +%%DATADIR%%/streams/final/vehicles/C1boat.zip +%%DATADIR%%/streams/final/vehicles/Chemicaltrailer.zip +%%DATADIR%%/streams/final/vehicles/ChevyS10.zip +%%DATADIR%%/streams/final/vehicles/Dodge1500.zip +%%DATADIR%%/streams/final/vehicles/DryVanTrailer.zip +%%DATADIR%%/streams/final/vehicles/HouseBoat.zip +%%DATADIR%%/streams/final/vehicles/Lexus.zip +%%DATADIR%%/streams/final/vehicles/MANTGX.zip +%%DATADIR%%/streams/final/vehicles/MTVR.zip +%%DATADIR%%/streams/final/vehicles/Mig-25.zip +%%DATADIR%%/streams/final/vehicles/P51.zip +%%DATADIR%%/streams/final/vehicles/Panther.zip +%%DATADIR%%/streams/final/vehicles/SprinterVans.zip +%%DATADIR%%/streams/final/vehicles/agora.zip +%%DATADIR%%/streams/final/vehicles/ampliroll.zip +%%DATADIR%%/streams/final/vehicles/concorde.zip +%%DATADIR%%/streams/final/vehicles/cranedaf.zip +%%DATADIR%%/streams/final/vehicles/dafsemi.zip +%%DATADIR%%/streams/final/vehicles/dakardaf.zip +%%DATADIR%%/streams/final/vehicles/dodgecharger.zip +%%DATADIR%%/streams/final/vehicles/dodgepolice.zip +%%DATADIR%%/streams/final/vehicles/dodgeviper.zip +%%DATADIR%%/streams/final/vehicles/hilux.zip +%%DATADIR%%/streams/final/vehicles/jerseybarrier.zip +%%DATADIR%%/streams/final/vehicles/k100.zip +%%DATADIR%%/streams/final/vehicles/kerax.zip +%%DATADIR%%/streams/final/vehicles/liebherr.zip +%%DATADIR%%/streams/final/vehicles/meanmachines.zip +%%DATADIR%%/streams/final/vehicles/renaultcrane.zip +%%DATADIR%%/streams/final/vehicles/scaniawreckers.zip +%%DATADIR%%/streams/final/vehicles/skiploader.zip +%%DATADIR%%/streams/final/vehicles/smit.zip +%%DATADIR%%/streams/final/vehicles/tatra813.zip +%%DATADIR%%/streams/final/vehicles/travelgo.zip +%%DATADIR%%/streams/final/vehicles/turbotwin.zip +%%DATADIR%%/streams/final/vehicles/twinotter.zip +%%DATADIR%%/streams/final/vehicles/wahoo.zip +@dirrm %%DATADIR%%/streams/final/vehicles +@dirrm %%DATADIR%%/streams/final/terrains +@dirrm %%DATADIR%%/streams/final +@dirrm %%DATADIR%%/streams +@dirrm %%DATADIR%%/skeleton/vehicles +@dirrm %%DATADIR%%/skeleton/terrains +@dirrm %%DATADIR%%/skeleton/packs +@dirrm %%DATADIR%%/skeleton/logs +@dirrm %%DATADIR%%/skeleton/config +@dirrm %%DATADIR%%/skeleton/cache +@dirrm %%DATADIR%%/skeleton +@dirrm %%DATADIR%%/resources +@dirrm %%DATADIR%%/languages/zh +@dirrm %%DATADIR%%/languages/ur +@dirrm %%DATADIR%%/languages/tr +@dirrm %%DATADIR%%/languages/sv +@dirrm %%DATADIR%%/languages/sl +@dirrm %%DATADIR%%/languages/sk +@dirrm %%DATADIR%%/languages/ru +@dirrm %%DATADIR%%/languages/ro +@dirrm %%DATADIR%%/languages/pt +@dirrm %%DATADIR%%/languages/pl +@dirrm %%DATADIR%%/languages/nn +@dirrm %%DATADIR%%/languages/nl +@dirrm %%DATADIR%%/languages/lt +@dirrm %%DATADIR%%/languages/la +@dirrm %%DATADIR%%/languages/ja +@dirrm %%DATADIR%%/languages/it +@dirrm %%DATADIR%%/languages/is +@dirrm %%DATADIR%%/languages/id +@dirrm %%DATADIR%%/languages/hu +@dirrm %%DATADIR%%/languages/hi +@dirrm %%DATADIR%%/languages/fr +@dirrm %%DATADIR%%/languages/fi +@dirrm %%DATADIR%%/languages/et +@dirrm %%DATADIR%%/languages/es +@dirrm %%DATADIR%%/languages/en +@dirrm %%DATADIR%%/languages/el +@dirrm %%DATADIR%%/languages/de +@dirrm %%DATADIR%%/languages/da +@dirrm %%DATADIR%%/languages/cs +@dirrm %%DATADIR%%/languages/bn +@dirrm %%DATADIR%%/languages/bg +@dirrm %%DATADIR%%/languages/ar +@dirrm %%DATADIR%%/languages +@dirrm %%DATADIR%% +@dirrm libexec/rigsofrods +@dirrm libexec +@dirrm lib/rigsofrods |