aboutsummaryrefslogtreecommitdiffstats
path: root/games
diff options
context:
space:
mode:
authorjbeich <jbeich@FreeBSD.org>2017-10-06 23:08:56 +0800
committerjbeich <jbeich@FreeBSD.org>2017-10-06 23:08:56 +0800
commit32ab65fecdc068c433220eb8453b6b9c7766b69d (patch)
tree5730e89e36625a49b6b2b33a393c332ff9211226 /games
parentcb05bbfefe6a8bc407b67eb4bc0184cacad33898 (diff)
downloadfreebsd-ports-gnome-32ab65fecdc068c433220eb8453b6b9c7766b69d.tar.gz
freebsd-ports-gnome-32ab65fecdc068c433220eb8453b6b9c7766b69d.tar.zst
freebsd-ports-gnome-32ab65fecdc068c433220eb8453b6b9c7766b69d.zip
games/pioneer: update to 0.0.20171001
- Remove already applied patch for assimp-4.0.0 - Move USES before USE_* per Porter's Handbook style (found by portlint) - Add SERVERAGENT port's option - Apply upstream patch to "Fix SAR selection of ship sizes for missions" Note, saved games from previous version are not compatible. Changes: https://github.com/pioneerspacesim/pioneer/blob/20171001/Changelog.txt https://github.com/pioneerspacesim/pioneer/compare/20170304...20171001 PR: 222823 Submitted by: lightside@gmx.com (maintainer) MFH: 2017Q4
Diffstat (limited to 'games')
-rw-r--r--games/pioneer/Makefile17
-rw-r--r--games/pioneer/distinfo8
-rw-r--r--games/pioneer/files/patch-data_modules_SearchRescue_SearchRescue.lua83
3 files changed, 94 insertions, 14 deletions
diff --git a/games/pioneer/Makefile b/games/pioneer/Makefile
index 40cdbf2d7903..c5c42234350f 100644
--- a/games/pioneer/Makefile
+++ b/games/pioneer/Makefile
@@ -3,12 +3,8 @@
PORTNAME= pioneer
PORTVERSION= 0.0.${GH_TAGNAME}
-PORTREVISION= 4
CATEGORIES= games
-PATCH_SITES= https://github.com/${GH_ACCOUNT}/${GH_PROJECT}/commit/
-PATCHFILES= a53fdbe8b046.patch:-p1
-
MAINTAINER= lightside@gmx.com
COMMENT= Space adventure game set in the Milky Way galaxy
@@ -31,18 +27,18 @@ LICENSE_PERMS_IUP= dist-mirror dist-sell pkg-mirror pkg-sell auto-accept
LICENSE_PERMS_SIL= dist-mirror dist-sell pkg-mirror pkg-sell auto-accept
BUILD_DEPENDS= ${LOCALBASE}/include/GL/glu.h:graphics/libGLU
-LIB_DEPENDS= libcurl.so:ftp/curl \
- libsigc-2.0.so:devel/libsigc++20 \
+LIB_DEPENDS= libsigc-2.0.so:devel/libsigc++20 \
libfreetype.so:print/freetype2 \
libvorbisfile.so:audio/libvorbis \
libpng.so:graphics/png \
libassimp.so:multimedia/assimp
+USES= autoreconf compiler:c++11-lib gmake pkgconfig
+
USE_GITHUB= yes
GH_ACCOUNT= pioneerspacesim
-GH_TAGNAME= 20170304
+GH_TAGNAME= 20171001
-USES= autoreconf compiler:c++11-lib gmake pkgconfig
USE_GL= gl
USE_SDL= image2 sdl2
@@ -63,7 +59,7 @@ DESKTOP_ENTRIES="Pioneer" "${COMMENT}" \
SUB_FILES= pkg-message
-OPTIONS_DEFINE= DOCS MODELCOMPILER NOGPUJOBS PROFILER
+OPTIONS_DEFINE= DOCS MODELCOMPILER NOGPUJOBS PROFILER SERVERAGENT
OPTIONS_DEFAULT= MODELCOMPILER
DOCS_SUB_LIST= QUICKSTART_PATH="${DOCSDIR}"
DOCS_SUB_LIST_OFF= \
@@ -73,6 +69,9 @@ MODELCOMPILER_PLIST_FILES= bin/${PORTNAME}-modelcompiler
NOGPUJOBS_DESC= Disable EnableGPUJobs for config.ini by default
PROFILER_DESC= Build with internal profiler
PROFILER_CONFIGURE_ON= --enable-profiler
+SERVERAGENT_DESC= Build with server agent
+SERVERAGENT_CONFIGURE_WITH= server-agent
+SERVERAGENT_LIB_DEPENDS= libcurl.so:ftp/curl
.include <bsd.port.pre.mk>
diff --git a/games/pioneer/distinfo b/games/pioneer/distinfo
index 1b7fa0d02e1a..c64d333c8fdd 100644
--- a/games/pioneer/distinfo
+++ b/games/pioneer/distinfo
@@ -1,5 +1,3 @@
-TIMESTAMP = 1488555232
-SHA256 (pioneerspacesim-pioneer-0.0.20170304-20170304_GH0.tar.gz) = 45d448a5ac53c9e230522600f03dad7abc70788367d09c3edcb4ae4285050004
-SIZE (pioneerspacesim-pioneer-0.0.20170304-20170304_GH0.tar.gz) = 194776151
-SHA256 (a53fdbe8b046.patch) = f9b438480642ad4a9a71cd976c007bc9c5a0fa82d3dc2d4d0892c1d6e00b78d7
-SIZE (a53fdbe8b046.patch) = 1109
+TIMESTAMP = 1506816107
+SHA256 (pioneerspacesim-pioneer-0.0.20171001-20171001_GH0.tar.gz) = 154118bd3dac2f9b8ea43a837bcb967abcc8c3a8ee5ab61d35183bae85e8b0db
+SIZE (pioneerspacesim-pioneer-0.0.20171001-20171001_GH0.tar.gz) = 210900753
diff --git a/games/pioneer/files/patch-data_modules_SearchRescue_SearchRescue.lua b/games/pioneer/files/patch-data_modules_SearchRescue_SearchRescue.lua
new file mode 100644
index 000000000000..05fe8d3e0997
--- /dev/null
+++ b/games/pioneer/files/patch-data_modules_SearchRescue_SearchRescue.lua
@@ -0,0 +1,83 @@
+Fix SAR selection of ship sizes for missions
+https://github.com/pioneerspacesim/pioneer/commit/008e30a857036a8cc40c42bf89ef68e65b47a41e
+
+--- data/modules/SearchRescue/SearchRescue.lua.orig 2017-10-01 00:01:47 UTC
++++ data/modules/SearchRescue/SearchRescue.lua
+@@ -613,7 +613,20 @@ local createTargetShipParameters = funct
+ ---- loading drive, weapons etc.
+ if flavour.id == 1 or flavour.id == 6 then
+ for i,shipdef in pairs(shipdefs) do
+- if shipdef.capacity / 10 < 1 then shipdefs[i] = nil end
++
++ -- get mass of hyperdrive if this ship has a default drive
++ -- if no default drive assume lowest mass drive
++ -- higher mass drives will only be fitted later at ship creation if capacity is huge
++ local drive = Equipment.hyperspace['hyperdrive_'..tostring(shipdef.hyperdriveClass)]
++ if not drive then
++ local drives = {}
++ for i = 9, 1, -1 do
++ table.insert(drives, Equipment.hyperspace['hyperdrive_'..tostring(i)])
++ end
++ table.sort(drives, function (a,b) return a.capabilities.mass < b.capabilities.mass end)
++ drive = drives[1]
++ end
++ if (shipdef.capacity-drive.capabilities.mass) / 10 < 1 then shipdefs[i] = nil end
+ end
+ elseif flavour.pickup_pass > 0 then
+ for i,shipdef in pairs(shipdefs) do
+@@ -661,7 +674,16 @@ local createTargetShipParameters = funct
+ if flavour.id == 1 or flavour.id == 6 then
+ local any_pass = rand:Integer(0,1)
+ if any_pass > 0 then
+- pickup_pass = rand:Integer(1, math.min((shipdef.capacity / 10)+1, max_pass))
++ local drive = Equipment.hyperspace['hyperdrive_'..tostring(shipdef.hyperdriveClass)]
++ if not drive then
++ local drives = {}
++ for i = 9, 1, -1 do
++ table.insert(drives, Equipment.hyperspace['hyperdrive_'..tostring(i)])
++ end
++ table.sort(drives, function (a,b) return a.capabilities.mass < b.capabilities.mass end)
++ drive = drives[1]
++ end
++ pickup_pass = rand:Integer(1, math.min(((shipdef.capacity-drive.capabilities.mass) / 10)+1, max_pass))
+ else
+ pickup_pass = 0
+ end
+@@ -709,22 +731,25 @@ local createTargetShip = function (missi
+ ship:SetPattern(pattern)
+
+ -- load a hyperdrive
+- local default_drive = Equipment.hyperspace['hyperdrive_'..tostring(shipdef.hyperdriveClass)]
+- if default_drive then
+- ship:AddEquip(default_drive)
+- else
+- local drive
++ -- 1st try: default drive for this ship class
++ -- 2nd try: largest drive possible that doesn't take more than a 10th of available room
++ -- fallback: smallest drive
++ local drives = {}
++ local drive = Equipment.hyperspace['hyperdrive_'..tostring(shipdef.hyperdriveClass)]
++ if not drive then
+ for i = 9, 1, -1 do
+- drive = Equipment.hyperspace['hyperdrive_'..tostring(i)]
+- if shipdef.capacity / 10 > drive.capabilities.mass then
+- ship:AddEquip(drive)
+- break
+- end
++ table.insert(drives, Equipment.hyperspace['hyperdrive_'..tostring(i)])
+ end
+- if not drive then
+- ship:AddEquip(Equipment.hyperspace['hyperdrive_1'])
++ table.sort(drives, function (a,b) return a.capabilities.mass < b.capabilities.mass end)
++ for i = #drives, 1, -1 do
++ local test_drive = drives[i]
++ if shipdef.capacity / 10 > test_drive.capabilities.mass then
++ drive = test_drive
++ end
+ end
+ end
++ if not drive then drive = drives[1] end
++ ship:AddEquip(drive)
+
+ -- add thruster fuel
+ if mission.flavour.id == 2 or mission.flavour.id == 4 or mission.flavour.id == 5 then