mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 21:26:40 +00:00
Merge branch 'openmw-28'
Conflicts: CMakeLists.txt
This commit is contained in:
commit
053b3dc371
7 changed files with 172 additions and 39 deletions
|
@ -4,10 +4,6 @@ if (APPLE)
|
|||
set(APP_BUNDLE_NAME "${CMAKE_PROJECT_NAME}.app")
|
||||
|
||||
set(APP_BUNDLE_DIR "${OpenMW_BINARY_DIR}/${APP_BUNDLE_NAME}")
|
||||
|
||||
set(CMAKE_EXE_LINKER_FLAGS "-F /Library/Frameworks")
|
||||
set(CMAKE_SHARED_LINKER_FLAGS "-F /Library/Frameworks")
|
||||
set(CMAKE_MODULE_LINKER_FLAGS "-F /Library/Frameworks")
|
||||
endif (APPLE)
|
||||
|
||||
# Macros
|
||||
|
@ -206,10 +202,6 @@ if (MSVC10)
|
|||
set(PLATFORM_INCLUDE_DIR "")
|
||||
endif()
|
||||
|
||||
if (APPLE)
|
||||
set(Boost_USE_STATIC_LIBS ON)
|
||||
endif (APPLE)
|
||||
|
||||
# Dependencies
|
||||
|
||||
# Fix for not visible pthreads functions for linker with glibc 2.15
|
||||
|
@ -261,9 +253,15 @@ if (APPLE)
|
|||
# List used Ogre plugins
|
||||
SET(USED_OGRE_PLUGINS ${OGRE_RenderSystem_GL_LIBRARY_REL}
|
||||
${OGRE_Plugin_OctreeSceneManager_LIBRARY_REL}
|
||||
${OGRE_Plugin_CgProgramManager_LIBRARY_REL}
|
||||
${OGRE_Plugin_ParticleFX_LIBRARY_REL})
|
||||
|
||||
# Actually we must use OGRE_Plugin_CgProgramManager_FOUND but it's
|
||||
# not reliable and equals TRUE even if there's no Ogre Cg plugin
|
||||
if (Cg_FOUND)
|
||||
set(USED_OGRE_PLUGINS ${USED_OGRE_PLUGINS}
|
||||
${OGRE_Plugin_CgProgramManager_LIBRARY_REL})
|
||||
endif ()
|
||||
|
||||
if (${OGRE_PLUGIN_DIR_REL}})
|
||||
set(OGRE_PLUGINS_REL_FOUND TRUE)
|
||||
endif ()
|
||||
|
@ -301,7 +299,8 @@ endif()
|
|||
add_definitions(-DOGRE_PLUGIN_DIR_REL="${OGRE_PLUGIN_DIR_REL}")
|
||||
add_definitions(-DOGRE_PLUGIN_DIR_DBG="${OGRE_PLUGIN_DIR_DBG}")
|
||||
if (APPLE AND OPENMW_OSX_DEPLOYMENT)
|
||||
add_definitions(-DOGRE_PLUGIN_DIR="${APP_BUNDLE_NAME}/Contents/Plugins")
|
||||
# make it empty so plugin loading code can check this and try to find plugins inside app bundle
|
||||
add_definitions(-DOGRE_PLUGIN_DIR="")
|
||||
else()
|
||||
add_definitions(-DOGRE_PLUGIN_DIR="${OGRE_PLUGIN_DIR}")
|
||||
endif()
|
||||
|
@ -662,9 +661,9 @@ if (APPLE)
|
|||
|
||||
set(OPENMW_APP "\${CMAKE_INSTALL_PREFIX}/${INSTALL_SUBDIR}/${APP_BUNDLE_NAME}")
|
||||
|
||||
set(OPENCS_APP "\${CMAKE_INSTALL_PREFIX}/${INSTALL_SUBDIR}/OpenCS.app")
|
||||
set(OPENCS_BUNDLE_NAME "OpenCS.app")
|
||||
set(OPENCS_APP "\${CMAKE_INSTALL_PREFIX}/${INSTALL_SUBDIR}/${OPENCS_BUNDLE_NAME}")
|
||||
|
||||
set(PLUGINS "")
|
||||
set(ABSOLUTE_PLUGINS "")
|
||||
|
||||
foreach (PLUGIN ${USED_OGRE_PLUGINS})
|
||||
|
@ -672,13 +671,26 @@ if (APPLE)
|
|||
set(ABSOLUTE_PLUGINS ${PLUGIN_ABS} ${ABSOLUTE_PLUGINS})
|
||||
endforeach ()
|
||||
|
||||
set(PLUGIN_INSTALL_BASE "\${CMAKE_INSTALL_PREFIX}/${INSTALL_SUBDIR}/${APP_BUNDLE_NAME}/Contents/Plugins")
|
||||
install(FILES ${ABSOLUTE_PLUGINS} DESTINATION "${INSTALL_SUBDIR}/${APP_BUNDLE_NAME}/Contents/Plugins" COMPONENT Runtime)
|
||||
# installs used plugins in bundle at given path (bundle_path must be relative to ${CMAKE_INSTALL_PREFIX})
|
||||
# and returns list of install paths for all installed plugins
|
||||
function (install_plugins_for_bundle bundle_path plugins_var)
|
||||
set(RELATIVE_PLUGIN_INSTALL_BASE "${bundle_path}/Contents/Plugins")
|
||||
install(FILES ${ABSOLUTE_PLUGINS} DESTINATION ${RELATIVE_PLUGIN_INSTALL_BASE} COMPONENT Runtime)
|
||||
|
||||
set(PLUGINS "")
|
||||
set(PLUGIN_INSTALL_BASE "\${CMAKE_INSTALL_PREFIX}/${RELATIVE_PLUGIN_INSTALL_BASE}")
|
||||
|
||||
foreach (PLUGIN ${ABSOLUTE_PLUGINS})
|
||||
get_filename_component(PLUGIN_RELATIVE ${PLUGIN} NAME)
|
||||
set(PLUGINS ${PLUGINS} "${PLUGIN_INSTALL_BASE}/${PLUGIN_RELATIVE}")
|
||||
endforeach ()
|
||||
|
||||
set(${plugins_var} ${PLUGINS} PARENT_SCOPE)
|
||||
endfunction (install_plugins_for_bundle)
|
||||
|
||||
install_plugins_for_bundle("${INSTALL_SUBDIR}/${APP_BUNDLE_NAME}" PLUGINS)
|
||||
install_plugins_for_bundle("${INSTALL_SUBDIR}/${OPENCS_BUNDLE_NAME}" OPENCS_PLUGINS)
|
||||
|
||||
#For now, search unresolved dependencies only in default system paths, so if you put unresolveable (i.e. with @executable_path in id name) lib or framework somewhere else, it would fail
|
||||
set(DIRS "")
|
||||
|
||||
|
@ -725,7 +737,7 @@ if (APPLE)
|
|||
set(BU_CHMOD_BUNDLE_ITEMS ON)
|
||||
include(BundleUtilities)
|
||||
fixup_bundle(\"${OPENMW_APP}\" \"${PLUGINS}\" \"${DIRS}\")
|
||||
fixup_bundle(\"${OPENCS_APP}\" \"\" \"${DIRS}\")
|
||||
fixup_bundle(\"${OPENCS_APP}\" \"${OPENCS_PLUGINS}\" \"${DIRS}\")
|
||||
" COMPONENT Runtime)
|
||||
include(CPack)
|
||||
endif (APPLE)
|
||||
|
|
|
@ -210,6 +210,8 @@ int CS::Editor::run()
|
|||
if (mLocal.empty())
|
||||
return 1;
|
||||
|
||||
// temporarily disable OGRE-integration (need to fix path problem first)
|
||||
#if 0
|
||||
// TODO: setting
|
||||
Ogre::Root::getSingleton().setRenderSystem(Ogre::Root::getSingleton().getRenderSystemByName("OpenGL Rendering Subsystem"));
|
||||
|
||||
|
@ -221,8 +223,12 @@ int CS::Editor::run()
|
|||
params.insert(std::make_pair("FSAA", "0"));
|
||||
params.insert(std::make_pair("vsync", "false"));
|
||||
params.insert(std::make_pair("hidden", "true"));
|
||||
#if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
|
||||
params.insert(std::make_pair("macAPI", "cocoa"));
|
||||
#endif
|
||||
Ogre::RenderWindow* hiddenWindow = Ogre::Root::getSingleton().createRenderWindow("InactiveHidden", 1, 1, false, ¶ms);
|
||||
hiddenWindow->setActive(false);
|
||||
#endif
|
||||
|
||||
mStartup.show();
|
||||
|
||||
|
|
|
@ -44,8 +44,11 @@ int main(int argc, char *argv[])
|
|||
// SceneWidget destructor will delete the created render window, which would be called _after_ Root has shut down :(
|
||||
|
||||
Application mApplication (argc, argv);
|
||||
// temporarily disable OGRE-integration (need to fix path problem first)
|
||||
#if 0
|
||||
OgreInit::OgreInit ogreInit;
|
||||
ogreInit.init("./opencsOgre.log"); // TODO log path?
|
||||
#endif
|
||||
|
||||
#ifdef Q_OS_MAC
|
||||
QDir dir(QCoreApplication::applicationDirPath());
|
||||
|
|
|
@ -67,6 +67,10 @@ namespace CSVRender
|
|||
params.insert(std::make_pair("title", windowTitle.str()));
|
||||
params.insert(std::make_pair("FSAA", "0")); // TODO setting
|
||||
params.insert(std::make_pair("vsync", "false")); // TODO setting
|
||||
#if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
|
||||
params.insert(std::make_pair("macAPI", "cocoa"));
|
||||
params.insert(std::make_pair("macAPICocoaUseNSView", "true"));
|
||||
#endif
|
||||
|
||||
mWindow = Ogre::Root::getSingleton().createRenderWindow(windowTitle.str(), this->width(), this->height(), false, ¶ms);
|
||||
mWindow->addViewport(mCamera)->setBackgroundColour(Ogre::ColourValue(0.3,0.3,0.3,1));
|
||||
|
|
|
@ -43,12 +43,26 @@ toolbar->addTool (new SceneToolMode (toolbar));
|
|||
toolbar->addTool (new SceneToolMode (toolbar));
|
||||
layout2->addWidget (toolbar, 0);
|
||||
|
||||
|
||||
// temporarily disable OGRE-integration (need to fix path problem first)
|
||||
#if 0
|
||||
CSVRender::SceneWidget* sceneWidget = new CSVRender::SceneWidget(this);
|
||||
|
||||
layout2->addWidget (sceneWidget, 1);
|
||||
|
||||
layout->insertLayout (0, layout2, 1);
|
||||
#endif
|
||||
/// \todo replace with rendering widget
|
||||
QPalette palette2 (palette());
|
||||
palette2.setColor (QPalette::Background, Qt::white);
|
||||
QLabel *placeholder = new QLabel ("Here goes the 3D scene", this);
|
||||
placeholder->setAutoFillBackground (true);
|
||||
placeholder->setPalette (palette2);
|
||||
placeholder->setAlignment (Qt::AlignHCenter);
|
||||
|
||||
layout2->addWidget (placeholder, 1);
|
||||
|
||||
layout->insertLayout (0, layout2, 1);
|
||||
|
||||
|
||||
CSVFilter::FilterBox *filterBox = new CSVFilter::FilterBox (document.getData(), this);
|
||||
|
||||
|
|
|
@ -6,6 +6,10 @@
|
|||
#include <OgreParticleEmitterFactory.h>
|
||||
#include <OgreParticleSystemManager.h>
|
||||
|
||||
#if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
|
||||
#include <OSX/macUtils.h>
|
||||
#endif
|
||||
|
||||
#include <components/nifogre/particles.hpp>
|
||||
|
||||
#include "ogreplugin.hpp"
|
||||
|
@ -127,6 +131,9 @@ namespace OgreInit
|
|||
#endif
|
||||
#if OGRE_PLATFORM == OGRE_PLATFORM_APPLE
|
||||
pluginDir = OGRE_PLUGIN_DIR;
|
||||
// if path is not specified try to find plugins inside the app bundle
|
||||
if (pluginDir.empty())
|
||||
pluginDir = Ogre::macPluginPath();
|
||||
#endif
|
||||
#if OGRE_PLATFORM == OGRE_PLATFORM_LINUX
|
||||
pluginDir = OGRE_PLUGIN_DIR_REL;
|
||||
|
|
89
readme.txt
89
readme.txt
|
@ -3,7 +3,7 @@ OpenMW: A reimplementation of The Elder Scrolls III: Morrowind
|
|||
OpenMW is an attempt at recreating the engine for the popular role-playing game
|
||||
Morrowind by Bethesda Softworks. You need to own and install the original game for OpenMW to work.
|
||||
|
||||
Version: 0.27.0
|
||||
Version: 0.28.0
|
||||
License: GPL (see GPL3.txt for more information)
|
||||
Website: http://www.openmw.org
|
||||
|
||||
|
@ -91,6 +91,93 @@ Allowed options:
|
|||
|
||||
CHANGELOG
|
||||
|
||||
0.28.0
|
||||
|
||||
Bug #399: Inventory changes are not visible immediately
|
||||
Bug #417: Apply weather instantly when teleporting
|
||||
Bug #566: Global Map position marker not updated for interior cells
|
||||
Bug #712: Looting corpse delay
|
||||
Bug #716: Problem with the "Vurt's Ascadian Isles Mod" mod
|
||||
Bug #805: Two TR meshes appear black (v0.24RC)
|
||||
Bug #841: Third-person activation distance taken from camera rather than head
|
||||
Bug #845: NPCs hold torches during the day
|
||||
Bug #855: Vvardenfell Visages Volume I some hairs don´t appear since 0,24
|
||||
Bug #856: Maormer race by Mac Kom - The heads are way up
|
||||
Bug #864: Walk locks during loading in 3rd person
|
||||
Bug #871: active weapon/magic item icon is not immediately made blank if item is removed during dialog
|
||||
Bug #882: Hircine's Ring doesn't always work
|
||||
Bug #909: [Tamriel Rebuilt] crashes in Akamora
|
||||
Bug #922: Launcher writing merged openmw.cfg files
|
||||
Bug #943: Random magnitude should be calculated per effect
|
||||
Bug #948: Negative fatigue level should be allowed
|
||||
Bug #949: Particles in world space
|
||||
Bug #950: Hard crash on x64 Linux running --new-game (on startup)
|
||||
Bug #951: setMagicka and setFatigue have no effect
|
||||
Bug #954: Problem with equipping inventory items when using a keyboard shortcut
|
||||
Bug #955: Issues with equipping torches
|
||||
Bug #966: Shield is visible when casting spell
|
||||
Bug #967: Game crashes when equipping silver candlestick
|
||||
Bug #970: Segmentation fault when starting at Bal Isra
|
||||
Bug #977: Pressing down key in console doesn't go forward in history
|
||||
Bug #979: Tooltip disappears when changing inventory
|
||||
Bug #980: Barter: item category is remembered, but not shown
|
||||
Bug #981: Mod: replacing model has wrong position/orientation
|
||||
Bug #982: Launcher: Addon unchecking is not saved
|
||||
Bug #983: Fix controllers to affect objects attached to the base node
|
||||
Bug #985: Player can talk to NPCs who are in combat
|
||||
Bug #989: OpenMW crashes when trying to include mod with capital .ESP
|
||||
Bug #991: Merchants equip items with harmful constant effect enchantments
|
||||
Bug #994: Don't cap skills/attributes when set via console
|
||||
Bug #998: Setting the max health should also set the current health
|
||||
Bug #1005: Torches are visible when casting spells and during hand to hand combat.
|
||||
Bug #1006: Many NPCs have 0 skill
|
||||
Bug #1007: Console fills up with text
|
||||
Bug #1013: Player randomly loses health or dies
|
||||
Bug #1014: Persuasion window is not centered in maximized window
|
||||
Bug #1015: Player status window scroll state resets on status change
|
||||
Bug #1016: Notification window not big enough for all skill level ups
|
||||
Bug #1020: Saved window positions are not rescaled appropriately on resolution change
|
||||
Bug #1022: Messages stuck permanently on screen when they pile up
|
||||
Bug #1023: Journals doesn't open
|
||||
Bug #1026: Game loses track of torch usage.
|
||||
Bug #1028: Crash on pickup of jug in Unexplored Shipwreck, Upper level
|
||||
Bug #1029: Quick keys menu: Select compatible replacement when tool used up
|
||||
Bug #1042: TES3 header data wrong encoding
|
||||
Bug #1045: OS X: deployed OpenCS won't launch
|
||||
Bug #1046: All damaged weaponry is worth 1 gold
|
||||
Bug #1048: Links in "locked" dialogue are still clickable
|
||||
Bug #1052: Using color codes when naming your character actually changes the name's color
|
||||
Bug #1054: Spell effects not visible in front of water
|
||||
Bug #1055: Power-Spell animation starts even though you already casted it that day
|
||||
Bug #1059: Cure disease potion removes all effects from player, even your race bonus and race ability
|
||||
Bug #1063: Crash upon checking out game start ship area in Seyda Neen
|
||||
Bug #1064: openmw binaries link to unnecessary libraries
|
||||
Bug #1065: Landing from a high place in water still causes fall damage
|
||||
Bug #1072: Drawing weapon increases torch brightness
|
||||
Bug #1073: Merchants sell stacks of gold
|
||||
Feature #43: Visuals for Magic Effects
|
||||
Feature #51: Ranged Magic
|
||||
Feature #52: Touch Range Magic
|
||||
Feature #53: Self Range Magic
|
||||
Feature #54: Spell Casting
|
||||
Feature #70: Vampirism
|
||||
Feature #100: Combat AI
|
||||
Feature #171: Implement NIF record NiFlipController
|
||||
Feature #410: Window to restore enchanted item charge
|
||||
Feature #647: Enchanted item glow
|
||||
Feature #723: Invisibility/Chameleon magic effects
|
||||
Feature #737: Resist Magicka magic effect
|
||||
Feature #758: GetLOS
|
||||
Feature #926: Editor: Info-Record tables
|
||||
Feature #958: Material controllers
|
||||
Feature #959: Terrain bump, specular, & parallax mapping
|
||||
Feature #990: Request: unlock mouse when in any menu
|
||||
Feature #1018: Do not allow view mode switching while performing an action
|
||||
Feature #1027: Vertex morph animation (NiGeomMorpherController)
|
||||
Feature #1031: Handle NiBillboardNode
|
||||
Feature #1051: Implement NIF texture slot DarkTexture
|
||||
Task #873: Unify OGRE initialisation
|
||||
|
||||
0.27.0
|
||||
|
||||
Bug #597: Assertion `dialogue->mId == id' failed in esmstore.cpp
|
||||
|
|
Loading…
Reference in a new issue