Browse Source

Merge pull request #87 from dpogue/linux

Make plPythonPack work on Linux

--HG--
rename : Sources/Plasma/PubUtilLib/plUUID/plUUID.h => Sources/Plasma/NucleusLib/pnUUID/pnUUID.h
rename : Sources/Plasma/PubUtilLib/plUUID/plUUID_Unix.cpp => Sources/Plasma/NucleusLib/pnUUID/pnUUID_Unix.cpp
rename : Sources/Plasma/PubUtilLib/plUUID/plUUID_Win32.cpp => Sources/Plasma/NucleusLib/pnUUID/pnUUID_Win32.cpp
Adam Johnson 13 years ago
parent
commit
1a524d1a0c
  1. 8
      CMakeLists.txt
  2. 1
      Sources/Plasma/Apps/CMakeLists.txt
  3. 2
      Sources/Plasma/Apps/plClient/CMakeLists.txt
  4. 3
      Sources/Plasma/Apps/plFileEncrypt/CMakeLists.txt
  5. 1
      Sources/Plasma/Apps/plFileEncrypt/main.cpp
  6. 3
      Sources/Plasma/Apps/plFileSecure/CMakeLists.txt
  7. 1
      Sources/Plasma/Apps/plFileSecure/main.cpp
  8. 3
      Sources/Plasma/Apps/plLogDecrypt/CMakeLists.txt
  9. 4
      Sources/Plasma/Apps/plLogDecrypt/plLogDecrypt.cpp
  10. 18
      Sources/Plasma/Apps/plPageInfo/CMakeLists.txt
  11. 20
      Sources/Plasma/Apps/plPageInfo/plAllCreatables.cpp
  12. 21
      Sources/Plasma/Apps/plPageInfo/plPageInfo.cpp
  13. 52
      Sources/Plasma/Apps/plPythonPack/main.cpp
  14. 3
      Sources/Plasma/CoreLib/CMakeLists.txt
  15. 19
      Sources/Plasma/CoreLib/hsCritSect.cpp
  16. 3
      Sources/Plasma/CoreLib/hsCritSect.h
  17. 6
      Sources/Plasma/CoreLib/hsMatrix44.cpp
  18. 10
      Sources/Plasma/CoreLibExe/hsExeError.cpp
  19. 4
      Sources/Plasma/CoreLibExe/hsExeMalloc.cpp
  20. 21
      Sources/Plasma/FeatureLib/pfAnimation/pfObjectFlocker.cpp
  21. 3
      Sources/Plasma/FeatureLib/pfAnimation/plBlower.cpp
  22. 3
      Sources/Plasma/FeatureLib/pfAnimation/plFollowMod.cpp
  23. 1
      Sources/Plasma/FeatureLib/pfPython/cyMisc.cpp
  24. 2
      Sources/Plasma/FeatureLib/pfPython/pyNetServerSessionInfo.h
  25. 2
      Sources/Plasma/FeatureLib/pfSurface/CMakeLists.txt
  26. 1
      Sources/Plasma/NucleusLib/CMakeLists.txt
  27. 1
      Sources/Plasma/NucleusLib/inc/CMakeLists.txt
  28. 4
      Sources/Plasma/NucleusLib/pnAddrInfo/CMakeLists.txt
  29. 3
      Sources/Plasma/NucleusLib/pnDispatch/CMakeLists.txt
  30. 1
      Sources/Plasma/NucleusLib/pnFactory/CMakeLists.txt
  31. 2
      Sources/Plasma/NucleusLib/pnInputCore/plOSMsg.h
  32. 1
      Sources/Plasma/NucleusLib/pnKeyedObject/CMakeLists.txt
  33. 1
      Sources/Plasma/NucleusLib/pnMessage/CMakeLists.txt
  34. 2
      Sources/Plasma/NucleusLib/pnNetCommon/CMakeLists.txt
  35. 61
      Sources/Plasma/NucleusLib/pnNetCommon/plCreatableUuid.h
  36. 3
      Sources/Plasma/NucleusLib/pnNetCommon/pnNetCommonCreatable.h
  37. 2
      Sources/Plasma/NucleusLib/pnProduct/CMakeLists.txt
  38. 3
      Sources/Plasma/NucleusLib/pnProduct/Pch.h
  39. 3
      Sources/Plasma/NucleusLib/pnProduct/Private/pnPrAllIncludes.h
  40. 6
      Sources/Plasma/NucleusLib/pnProduct/Private/pnPrProductId.cpp
  41. 2
      Sources/Plasma/NucleusLib/pnProduct/Private/pnPrProductId.h
  42. 1
      Sources/Plasma/NucleusLib/pnTimer/CMakeLists.txt
  43. 28
      Sources/Plasma/NucleusLib/pnUUID/CMakeLists.txt
  44. 48
      Sources/Plasma/NucleusLib/pnUUID/pnUUID.cpp
  45. 27
      Sources/Plasma/NucleusLib/pnUUID/pnUUID.h
  46. 2
      Sources/Plasma/NucleusLib/pnUUID/pnUUID_Unix.cpp
  47. 26
      Sources/Plasma/NucleusLib/pnUUID/pnUUID_Win32.cpp
  48. 1
      Sources/Plasma/PubUtilLib/CMakeLists.txt
  49. 4
      Sources/Plasma/PubUtilLib/plAgeLoader/plAgeLoader.cpp
  50. 2
      Sources/Plasma/PubUtilLib/plAgeLoader/plAgeLoader.h
  51. 2
      Sources/Plasma/PubUtilLib/plAudio/CMakeLists.txt
  52. 8
      Sources/Plasma/PubUtilLib/plAudioCore/CMakeLists.txt
  53. 6
      Sources/Plasma/PubUtilLib/plAvatar/plAGAnimInstance.cpp
  54. 2
      Sources/Plasma/PubUtilLib/plAvatar/plAnimStage.cpp
  55. 3
      Sources/Plasma/PubUtilLib/plContainer/plConfigInfo.cpp
  56. 6
      Sources/Plasma/PubUtilLib/plDrawable/plCluster.cpp
  57. 3
      Sources/Plasma/PubUtilLib/plDrawable/plDrawableGenerator.cpp
  58. 5
      Sources/Plasma/PubUtilLib/plDrawable/plDrawableSpans.cpp
  59. 2
      Sources/Plasma/PubUtilLib/plDrawable/plDynaBulletMgr.cpp
  60. 10
      Sources/Plasma/PubUtilLib/plDrawable/plDynaDecalMgr.cpp
  61. 4
      Sources/Plasma/PubUtilLib/plDrawable/plDynaDecalMgr.h
  62. 4
      Sources/Plasma/PubUtilLib/plDrawable/plDynaFootMgr.cpp
  63. 2
      Sources/Plasma/PubUtilLib/plDrawable/plDynaPuddleMgr.cpp
  64. 7
      Sources/Plasma/PubUtilLib/plDrawable/plDynaRippleMgr.cpp
  65. 5
      Sources/Plasma/PubUtilLib/plDrawable/plDynaRippleMgrVS.cpp
  66. 2
      Sources/Plasma/PubUtilLib/plDrawable/plDynaTorpedoMgr.cpp
  67. 5
      Sources/Plasma/PubUtilLib/plDrawable/plDynaWakeMgr.cpp
  68. 18
      Sources/Plasma/PubUtilLib/plDrawable/plParticleFiller.cpp
  69. 3
      Sources/Plasma/PubUtilLib/plDrawable/plSpaceTreeMaker.cpp
  70. 2
      Sources/Plasma/PubUtilLib/plFile/CMakeLists.txt
  71. 1
      Sources/Plasma/PubUtilLib/plFile/hsFiles.h
  72. 39
      Sources/Plasma/PubUtilLib/plFile/plFileUtils.cpp
  73. 2
      Sources/Plasma/PubUtilLib/plFile/plFileUtils.h
  74. 74
      Sources/Plasma/PubUtilLib/plFile/plSecureStream.cpp
  75. 10
      Sources/Plasma/PubUtilLib/plFile/plSecureStream.h
  76. 4
      Sources/Plasma/PubUtilLib/plFile/plStreamSource.cpp
  77. 2
      Sources/Plasma/PubUtilLib/plInputCore/CMakeLists.txt
  78. 2
      Sources/Plasma/PubUtilLib/plInputCore/plInputManager.h
  79. 5
      Sources/Plasma/PubUtilLib/plInterp/plAnimPath.cpp
  80. 1
      Sources/Plasma/PubUtilLib/plMessage/plAgeLoadedMsg.h
  81. 8
      Sources/Plasma/PubUtilLib/plMessage/plInputIfaceMgrMsg.h
  82. 2
      Sources/Plasma/PubUtilLib/plMessage/plLoadAgeMsg.h
  83. 2
      Sources/Plasma/PubUtilLib/plNetCommon/plClientGuid.h
  84. 2
      Sources/Plasma/PubUtilLib/plNetCommon/plNetCommon.cpp
  85. 4
      Sources/Plasma/PubUtilLib/plNetCommon/plNetCommonCreatable.h
  86. 2
      Sources/Plasma/PubUtilLib/plNetCommon/plNetServerSessionInfo.h
  87. 3
      Sources/Plasma/PubUtilLib/plParticleSystem/plConvexVolume.cpp
  88. 3
      Sources/Plasma/PubUtilLib/plParticleSystem/plParticleEffect.cpp
  89. 6
      Sources/Plasma/PubUtilLib/plParticleSystem/plParticleEmitter.cpp
  90. 3
      Sources/Plasma/PubUtilLib/plParticleSystem/plParticleGenerator.cpp
  91. 2
      Sources/Plasma/PubUtilLib/plPhysical/plCollisionDetector.h
  92. 2
      Sources/Plasma/PubUtilLib/plPipeline/CMakeLists.txt
  93. 2
      Sources/Plasma/PubUtilLib/plPipeline/hsG3DDeviceSelector.h
  94. 4
      Sources/Plasma/PubUtilLib/plProgressMgr/plProgressMgr.cpp
  95. 4
      Sources/Plasma/PubUtilLib/plProgressMgr/plProgressMgr.h
  96. 1
      Sources/Plasma/PubUtilLib/plResMgr/CMakeLists.txt
  97. 4
      Sources/Plasma/PubUtilLib/plSDL/plSDL.h
  98. 4
      Sources/Plasma/PubUtilLib/plSDL/plSDLParser.cpp
  99. 3
      Sources/Plasma/PubUtilLib/plScene/plSceneNode.cpp
  100. 1
      Sources/Plasma/PubUtilLib/plStatusLog/CMakeLists.txt
  101. Some files were not shown because too many files have changed in this diff Show More

8
CMakeLists.txt

@ -10,13 +10,17 @@ find_package(OpenAL REQUIRED)
find_package(PythonLibs REQUIRED) find_package(PythonLibs REQUIRED)
find_package(EXPAT REQUIRED) find_package(EXPAT REQUIRED)
find_package(ZLIB REQUIRED) find_package(ZLIB REQUIRED)
find_package(PhysX REQUIRED) #TODO: Not required if we aren't building the client
find_package(PNG REQUIRED) find_package(PNG REQUIRED)
find_package(Ogg REQUIRED) #TODO: Not required if we aren't building the client find_package(Ogg REQUIRED) #TODO: Not required if we aren't building the client
find_package(Vorbis REQUIRED) #TODO: Not required if we aren't building the client find_package(Vorbis REQUIRED) #TODO: Not required if we aren't building the client
find_package(Speex REQUIRED) #TODO: Not required if we aren't building the client find_package(Speex REQUIRED) #TODO: Not required if we aren't building the client
find_package(DirectX REQUIRED)
find_package(CURL REQUIRED) find_package(CURL REQUIRED)
if(WIN32)
find_package(PhysX REQUIRED) #TODO: Not required if we aren't building the client
find_package(DirectX REQUIRED)
endif(WIN32)
find_package(MaxSDK) #TODO: Only find this if we are building PlasmaMax find_package(MaxSDK) #TODO: Only find this if we are building PlasmaMax
find_package(Bink) #TODO: Find Bink, but don't require it if plPipeline isn't built... find_package(Bink) #TODO: Find Bink, but don't require it if plPipeline isn't built...
# Or better yet, just eliminate bink altogether # Or better yet, just eliminate bink altogether

1
Sources/Plasma/Apps/CMakeLists.txt

@ -5,3 +5,4 @@ add_subdirectory(plUruLauncher)
add_subdirectory(plFileSecure) add_subdirectory(plFileSecure)
add_subdirectory(plFileEncrypt) add_subdirectory(plFileEncrypt)
add_subdirectory(plLogDecrypt) add_subdirectory(plLogDecrypt)
add_subdirectory(plPageInfo)

2
Sources/Plasma/Apps/plClient/CMakeLists.txt

@ -135,7 +135,6 @@ target_link_libraries(plClient plStreamLogger)
target_link_libraries(plClient plSurface) target_link_libraries(plClient plSurface)
target_link_libraries(plClient plTransform) target_link_libraries(plClient plTransform)
target_link_libraries(plClient plUnifiedTime) target_link_libraries(plClient plUnifiedTime)
target_link_libraries(plClient plUUID)
target_link_libraries(plClient plVault) target_link_libraries(plClient plVault)
target_link_libraries(plClient pnAddrInfo) target_link_libraries(plClient pnAddrInfo)
target_link_libraries(plClient pnAsyncCore) target_link_libraries(plClient pnAsyncCore)
@ -161,6 +160,7 @@ target_link_libraries(plClient pnSimpleNet)
target_link_libraries(plClient pnTimer) target_link_libraries(plClient pnTimer)
target_link_libraries(plClient pnUtils) target_link_libraries(plClient pnUtils)
target_link_libraries(plClient pnUtilsExe) target_link_libraries(plClient pnUtilsExe)
target_link_libraries(plClient pnUUID)
if(PYTHON_DEBUG_LIBRARY) if(PYTHON_DEBUG_LIBRARY)
target_link_libraries(plClient debug ${PYTHON_DEBUG_LIBRARY}) target_link_libraries(plClient debug ${PYTHON_DEBUG_LIBRARY})

3
Sources/Plasma/Apps/plFileEncrypt/CMakeLists.txt

@ -12,7 +12,6 @@ set(plFileEncrypt_SOURCES
) )
add_executable(plFileEncrypt ${plFileEncrypt_SOURCES}) add_executable(plFileEncrypt ${plFileEncrypt_SOURCES})
target_link_libraries(plFileEncrypt CoreLib CoreLibExe plFile plUnifiedTime pnProduct pnUtils) target_link_libraries(plFileEncrypt CoreLib CoreLibExe pnProduct plFile)
target_link_libraries(plFileEncrypt Rpcrt4)
source_group("Source Files" FILES ${plFileEncrypt_SOURCES}) source_group("Source Files" FILES ${plFileEncrypt_SOURCES})

1
Sources/Plasma/Apps/plFileEncrypt/main.cpp

@ -41,7 +41,6 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
*==LICENSE==*/ *==LICENSE==*/
#include "plFile/hsFiles.h" #include "plFile/hsFiles.h"
#include "plFile/plEncryptedStream.h" #include "plFile/plEncryptedStream.h"
#include "pnUtils/pnUtils.h"
#include "pnProduct/pnProduct.h" #include "pnProduct/pnProduct.h"
#include "hsUtils.h" #include "hsUtils.h"

3
Sources/Plasma/Apps/plFileSecure/CMakeLists.txt

@ -12,7 +12,6 @@ set(plFileSecure_SOURCES
) )
add_executable(plFileSecure ${plFileSecure_SOURCES}) add_executable(plFileSecure ${plFileSecure_SOURCES})
target_link_libraries(plFileSecure CoreLib CoreLibExe plFile plUnifiedTime pnProduct pnUtils) target_link_libraries(plFileSecure CoreLib CoreLibExe pnProduct plFile)
target_link_libraries(plFileSecure Rpcrt4)
source_group("Source Files" FILES ${plFileSecure_SOURCES}) source_group("Source Files" FILES ${plFileSecure_SOURCES})

1
Sources/Plasma/Apps/plFileSecure/main.cpp

@ -42,7 +42,6 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "plFile/hsFiles.h" #include "plFile/hsFiles.h"
#include "plFile/plFileUtils.h" #include "plFile/plFileUtils.h"
#include "plFile/plSecureStream.h" #include "plFile/plSecureStream.h"
#include "pnUtils/pnUtils.h"
#include "pnProduct/pnProduct.h" #include "pnProduct/pnProduct.h"
#include "hsUtils.h" #include "hsUtils.h"

3
Sources/Plasma/Apps/plLogDecrypt/CMakeLists.txt

@ -12,7 +12,6 @@ set(plLogDecrypt_SOURCES
) )
add_executable(plLogDecrypt ${plLogDecrypt_SOURCES}) add_executable(plLogDecrypt ${plLogDecrypt_SOURCES})
target_link_libraries(plLogDecrypt CoreLib CoreLibExe plFile plUnifiedTime plStatusLog pnProduct pnUtils) target_link_libraries(plLogDecrypt CoreLib CoreLibExe plStatusLog pnProduct)
target_link_libraries(plLogDecrypt Rpcrt4)
source_group("Source Files" FILES ${plLogDecrypt_SOURCES}) source_group("Source Files" FILES ${plLogDecrypt_SOURCES})

4
Sources/Plasma/Apps/plLogDecrypt/plLogDecrypt.cpp

@ -45,8 +45,10 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
* *
***/ ***/
#include <stdio.h> #include <cstdio>
#include <cstring>
#include "hsTypes.h" #include "hsTypes.h"
#include "hsUtils.h"
#include "plStatusLog/plEncryptLogLine.h" #include "plStatusLog/plEncryptLogLine.h"
void IProcessFile(const char *path) void IProcessFile(const char *path)

18
Sources/Plasma/Apps/plPageInfo/CMakeLists.txt

@ -0,0 +1,18 @@
include_directories("../../Apps")
include_directories("../../CoreLib")
include_directories("../../FeatureLib/inc")
include_directories("../../FeatureLib")
include_directories("../../NucleusLib/inc")
include_directories("../../NucleusLib")
include_directories("../../PubUtilLib/inc")
include_directories("../../PubUtilLib")
set(plPageInfo_SOURCES
plAllCreatables.cpp
plPageInfo.cpp
)
add_executable(plPageInfo ${plPageInfo_SOURCES})
target_link_libraries(plPageInfo CoreLib CoreLibExe pnProduct plResMgr plAudioCore)
source_group("Source Files" FILES ${plPageInfo_SOURCES})

20
Sources/Plasma/Apps/plPageInfo/plAllCreatables.cpp

@ -41,7 +41,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
*==LICENSE==*/ *==LICENSE==*/
#include "hsTypes.h" #include "hsTypes.h"
#include "../pnFactory/plCreator.h" #include "pnFactory/plCreator.h"
#include "plAudible.h" #include "plAudible.h"
REGISTER_NONCREATABLE( plAudible ); REGISTER_NONCREATABLE( plAudible );
@ -55,16 +55,16 @@ REGISTER_NONCREATABLE( plPhysical );
#include "plgDispatch.h" #include "plgDispatch.h"
REGISTER_NONCREATABLE( plDispatchBase ); REGISTER_NONCREATABLE( plDispatchBase );
#include "../pnDispatch/pnDispatchCreatable.h" #include "pnDispatch/pnDispatchCreatable.h"
#include "../pnKeyedObject/pnKeyedObjectCreatable.h" #include "pnKeyedObject/pnKeyedObjectCreatable.h"
#include "../pnMessage/pnMessageCreatable.h" #include "pnMessage/pnMessageCreatable.h"
#include "../pnModifier/pnModifierCreatable.h" #include "pnModifier/pnModifierCreatable.h"
#include "../pnNetCommon/pnNetCommonCreatable.h" #include "pnNetCommon/pnNetCommonCreatable.h"
#include "../pnTimer/pnTimerCreatable.h" #include "pnTimer/pnTimerCreatable.h"
#include "../plResMgr/plResMgrCreatable.h" #include "plResMgr/plResMgrCreatable.h"
#include "../plMessage/plResMgrHelperMsg.h" #include "plMessage/plResMgrHelperMsg.h"
REGISTER_CREATABLE(plResMgrHelperMsg); REGISTER_CREATABLE(plResMgrHelperMsg);
#include "../plAudioCore/plAudioCoreCreatable.h" #include "plAudioCore/plAudioCoreCreatable.h"

21
Sources/Plasma/Apps/plPageInfo/plPageInfo.cpp

@ -41,21 +41,20 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
*==LICENSE==*/ *==LICENSE==*/
#include "hsUtils.h" #include "hsUtils.h"
#include "hsTimer.h" #include "hsTimer.h"
#include "../plFile/hsFiles.h" #include "plFile/hsFiles.h"
#include "../plFile/plFileUtils.h" #include "plFile/plFileUtils.h"
#include "../plResMgr/plResManager.h" #include "plResMgr/plResManager.h"
#include "../plResMgr/plResMgrSettings.h" #include "plResMgr/plResMgrSettings.h"
#include "../plAgeDescription/plAgeManifest.h" #include "plAgeDescription/plAgeManifest.h"
#include "../plResMgr/plRegistryHelpers.h" #include "plResMgr/plRegistryHelpers.h"
#include "../plResMgr/plRegistryNode.h" #include "plResMgr/plRegistryNode.h"
#include "../plAudioCore/plSoundBuffer.h" #include "plAudioCore/plSoundBuffer.h"
#include "hsStream.h" #include "hsStream.h"
#include "../pnUtils/pnUtils.h" #include "pnProduct/pnProduct.h"
#include "../pnProduct/pnProduct.h"
//// Globals ///////////////////////////////////////////////////////////////// //// Globals /////////////////////////////////////////////////////////////////
@ -70,7 +69,7 @@ void PrintVersion()
{ {
wchar productString[256]; wchar productString[256];
ProductString(productString, arrsize(productString)); ProductString(productString, arrsize(productString));
_putws(productString); printf("%S\n\n", productString);
} }
//// PrintHelp /////////////////////////////////////////////////////////////// //// PrintHelp ///////////////////////////////////////////////////////////////

52
Sources/Plasma/Apps/plPythonPack/main.cpp

@ -48,10 +48,26 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include <string> #include <string>
#include <algorithm> #include <algorithm>
#if HS_BUILD_FOR_WIN32
# include <direct.h> # include <direct.h>
# define getcwd _getcwd
# define chdir _chdir
# ifndef MAXPATHLEN
# define MAXPATHLEN MAX_PATH
# endif
#elif HS_BUILD_FOR_UNIX
# include <unistd.h>
# include <sys/param.h>
#endif
static const char* kPackFileName = "python.pak"; static const char* kPackFileName = "python.pak";
#if HS_BUILD_FOR_WIN32
static const char* kGlueFile = ".\\plasma\\glue.py"; static const char* kGlueFile = ".\\plasma\\glue.py";
#else
static const char* kGlueFile = "./plasma/glue.py";
#endif
static char* glueFile = (char*)kGlueFile; static char* glueFile = (char*)kGlueFile;
void WritePythonFile(std::string fileName, std::string path, hsStream *s) void WritePythonFile(std::string fileName, std::string path, hsStream *s)
@ -267,16 +283,22 @@ void FindSubDirs(std::vector<std::string> &dirnames, const char *path)
// adds or removes the ending slash in a path as necessary // adds or removes the ending slash in a path as necessary
std::string AdjustEndingSlash(std::string path, bool endingSlash = false) std::string AdjustEndingSlash(std::string path, bool endingSlash = false)
{ {
#if HS_BUILD_FOR_WIN32
char slash = '\\';
#else
char slash = '/';
#endif
std::string retVal = path; std::string retVal = path;
bool endSlashExists = false; bool endSlashExists = false;
char temp = path[path.length()-1]; char temp = path[path.length()-1];
if (temp == '\\') if (temp == slash)
endSlashExists = true; endSlashExists = true;
if (endingSlash) if (endingSlash)
{ {
if (!endSlashExists) if (!endSlashExists)
retVal += "\\"; retVal += slash;
} }
else else
{ {
@ -294,17 +316,23 @@ std::string AdjustEndingSlash(std::string path, bool endingSlash = false)
// appends partialPath onto the end of fullPath, inserting or removing slashes as necesssary // appends partialPath onto the end of fullPath, inserting or removing slashes as necesssary
std::string ConcatDirs(std::string fullPath, std::string partialPath) std::string ConcatDirs(std::string fullPath, std::string partialPath)
{ {
#if HS_BUILD_FOR_WIN32
char slash = '\\';
#else
char slash = '/';
#endif
bool fullSlash = false, partialSlash = false; bool fullSlash = false, partialSlash = false;
char temp = fullPath[fullPath.length()-1]; char temp = fullPath[fullPath.length()-1];
if (temp == '\\') if (temp == slash)
fullSlash = true; fullSlash = true;
temp = partialPath[0]; temp = partialPath[0];
if (temp == '\\') if (temp == slash)
partialSlash = true; partialSlash = true;
std::string retVal = ""; std::string retVal = "";
if (!fullSlash) if (!fullSlash)
retVal = fullPath + "\\"; retVal = fullPath + slash;
if (partialSlash) if (partialSlash)
{ {
std::string temp = ""; std::string temp = "";
@ -346,7 +374,7 @@ void PackDirectory(std::string dir, std::string rootPath, std::string pakName, s
printf("\nCreating %s using the contents of %s\n",pakName.c_str(),dir.c_str()); printf("\nCreating %s using the contents of %s\n",pakName.c_str(),dir.c_str());
printf("Changing working directory to %s\n",rootPath.c_str()); printf("Changing working directory to %s\n",rootPath.c_str());
if (_chdir(rootPath.c_str())) if (chdir(rootPath.c_str()))
{ {
printf("ERROR: Directory change to %s failed for some reason\n",rootPath.c_str()); printf("ERROR: Directory change to %s failed for some reason\n",rootPath.c_str());
printf("Unable to continue with the packing of this directory, aborting...\n"); printf("Unable to continue with the packing of this directory, aborting...\n");
@ -428,12 +456,12 @@ void PrintUsage()
printf(" must be a relative path to the current working directory\n"); printf(" must be a relative path to the current working directory\n");
} }
void main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
printf("The Python Pack Utility\n"); printf("The Python Pack Utility\n");
char buffer[_MAX_PATH]; char buffer[MAXPATHLEN];
_getcwd(buffer,_MAX_PATH); getcwd(buffer, MAXPATHLEN);
std::string baseWorkingDir = buffer; std::string baseWorkingDir = buffer;
// are they asking for usage? // are they asking for usage?
@ -445,14 +473,14 @@ void main(int argc, char *argv[])
|| (temp == "-h") || (temp == "/h")) || (temp == "-h") || (temp == "/h"))
{ {
PrintUsage(); PrintUsage();
return; return -1;
} }
} }
// wrong number of args, print usage // wrong number of args, print usage
if (argc > 2) if (argc > 2)
{ {
PrintUsage(); PrintUsage();
return; return -1;
} }
std::vector<std::string> dirNames; std::vector<std::string> dirNames;
@ -476,4 +504,6 @@ void main(int argc, char *argv[])
{ {
PackDirectory(dirNames[i],rootPath,rootPath+dirNames[i]+".pak",dirNames); PackDirectory(dirNames[i],rootPath,rootPath+dirNames[i]+".pak",dirNames);
} }
return 0;
} }

3
Sources/Plasma/CoreLib/CMakeLists.txt

@ -87,6 +87,9 @@ set(CoreLib_HEADERS
) )
add_library(CoreLib STATIC ${CoreLib_SOURCES} ${CoreLib_HEADERS}) add_library(CoreLib STATIC ${CoreLib_SOURCES} ${CoreLib_HEADERS})
if(UNIX)
target_link_libraries(CoreLib pthread)
endif(UNIX)
source_group("Source Files" FILES ${CoreLib_SOURCES}) source_group("Source Files" FILES ${CoreLib_SOURCES})
source_group("Header Files" FILES ${CoreLib_HEADERS}) source_group("Header Files" FILES ${CoreLib_HEADERS})

19
Sources/Plasma/CoreLib/hsCritSect.cpp

@ -80,4 +80,23 @@ void CCritSect::Enter () {
void CCritSect::Leave () { void CCritSect::Leave () {
LeaveCriticalSection(&m_handle); LeaveCriticalSection(&m_handle);
} }
#elif HS_BUILD_FOR_UNIX
//===========================================================================
CCritSect::CCritSect () {
m_handle = PTHREAD_MUTEX_INITIALIZER;
}
//===========================================================================
CCritSect::~CCritSect () {
}
//===========================================================================
void CCritSect::Enter () {
pthread_mutex_lock(&m_handle);
}
//===========================================================================
void CCritSect::Leave () {
pthread_mutex_unlock(&m_handle);
}
#endif #endif

3
Sources/Plasma/CoreLib/hsCritSect.h

@ -61,6 +61,9 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#ifdef HS_BUILD_FOR_WIN32 #ifdef HS_BUILD_FOR_WIN32
typedef CRITICAL_SECTION CritSectHandle; typedef CRITICAL_SECTION CritSectHandle;
#elif HS_BUILD_FOR_UNIX
# include <pthread.h>
typedef pthread_mutex_t CritSectHandle;
#else #else
# error "CCritSect: Not implemented on this platform" # error "CCritSect: Not implemented on this platform"
#endif #endif

6
Sources/Plasma/CoreLib/hsMatrix44.cpp

@ -404,7 +404,8 @@ void hsMatrix44::MakeZRotation(hsScalar radians)
// //
hsMatrix44& hsMatrix44::Make(const hsPoint3* f, const hsPoint3* at, const hsVector3* up) hsMatrix44& hsMatrix44::Make(const hsPoint3* f, const hsPoint3* at, const hsVector3* up)
{ {
MakeTranslateMat(&hsVector3(f->fX, f->fY, f->fZ)); hsVector3 trans(f->fX, f->fY, f->fZ);
MakeTranslateMat(&trans);
hsVector3 back (f,at); // Z hsVector3 back (f,at); // Z
back.Normalize(); back.Normalize();
@ -435,7 +436,8 @@ hsMatrix44& hsMatrix44::Make(const hsPoint3* f, const hsPoint3* at, const hsVect
// //
hsMatrix44& hsMatrix44::MakeUpPreserving(const hsPoint3* f, const hsPoint3* at, const hsVector3* up) hsMatrix44& hsMatrix44::MakeUpPreserving(const hsPoint3* f, const hsPoint3* at, const hsVector3* up)
{ {
MakeTranslateMat(&hsVector3(f->fX, f->fY, f->fZ)); hsVector3 trans(f->fX, f->fY, f->fZ);
MakeTranslateMat(&trans);
hsVector3 topHead = *up; hsVector3 topHead = *up;
topHead.Normalize(); topHead.Normalize();

10
Sources/Plasma/CoreLibExe/hsExeError.cpp

@ -56,7 +56,9 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
***/ ***/
static bool s_skipBreak; static bool s_skipBreak;
#if HS_BUILD_FOR_WIN32
static CCritSect * s_critsect; static CCritSect * s_critsect;
#endif
// User options // User options
static bool s_options[kNumErrorOptions]; static bool s_options[kNumErrorOptions];
@ -69,12 +71,14 @@ static bool s_options[kNumErrorOptions];
***/ ***/
//=========================================================================== //===========================================================================
#if HS_BUILD_FOR_WIN32
AUTO_INIT_FUNC(hsExeErrorInit) { AUTO_INIT_FUNC(hsExeErrorInit) {
// The critical section has to be initialized // The critical section has to be initialized
// before program startup and never freed // before program startup and never freed
static byte rawMemory[sizeof(CCritSect)]; static byte rawMemory[sizeof(CCritSect)];
s_critsect = new(rawMemory) CCritSect; s_critsect = new(rawMemory) CCritSect;
} }
#endif
//============================================================================ //============================================================================
static void DoAssert (int line, const char file[], const char msg[]) { static void DoAssert (int line, const char file[], const char msg[]) {
@ -118,7 +122,7 @@ static void DoAssert (int line, const char file[], const char msg[]) {
//============================================================================ //============================================================================
#pragma auto_inline(off) #pragma auto_inline(off)
void __cdecl ErrorFatal (int line, const char file[], const char fmt[], ...) { void CDECL ErrorFatal (int line, const char file[], const char fmt[], ...) {
char buffer[256]; char buffer[256];
va_list args; va_list args;
va_start(args, fmt); va_start(args, fmt);
@ -135,7 +139,7 @@ void __cdecl ErrorFatal (int line, const char file[], const char fmt[], ...) {
//============================================================================ //============================================================================
#pragma auto_inline(off) #pragma auto_inline(off)
void __cdecl ErrorAssert (int line, const char file[], const char fmt[], ...) { void CDECL ErrorAssert (int line, const char file[], const char fmt[], ...) {
char buffer[256]; char buffer[256];
va_list args; va_list args;
va_start(args, fmt); va_start(args, fmt);
@ -250,7 +254,7 @@ void DebugMsgV (const char fmt[], va_list args) {
} }
//============================================================================ //============================================================================
void __cdecl DebugMsg (const char fmt[], ...) { void CDECL DebugMsg (const char fmt[], ...) {
#ifdef HS_DEBUGGING #ifdef HS_DEBUGGING
va_list args; va_list args;

4
Sources/Plasma/CoreLibExe/hsExeMalloc.cpp

@ -591,14 +591,16 @@ void * MemRealloc (void * ptr, unsigned bytes, unsigned flags, const char file[]
//=========================================================================== //===========================================================================
unsigned MemSize (void * ptr) { unsigned MemSize (void * ptr) {
ASSERT(ptr); ASSERT(ptr);
unsigned result; unsigned result = 0;
#ifdef MEM_DEBUG #ifdef MEM_DEBUG
const _CrtMemBlockHeader * pHead = pHdr(ptr); const _CrtMemBlockHeader * pHead = pHdr(ptr);
unsigned block = pHead->nBlockUse; unsigned block = pHead->nBlockUse;
#endif #endif
#if HS_BUILD_FOR_WIN32
result = (unsigned)_msize_dbg(ptr, block); result = (unsigned)_msize_dbg(ptr, block);
#endif
return result; return result;
} }

21
Sources/Plasma/FeatureLib/pfAnimation/pfObjectFlocker.cpp

@ -206,7 +206,7 @@ void pfVehicle::IMeasurePathCurvature(const float elapsedTime)
{ {
if (elapsedTime > 0) if (elapsedTime > 0)
{ {
const hsVector3 deltaPosition(&fLastPos, &Position()); const hsVector3 deltaPosition(&fLastPos, &fPos);
const hsVector3 deltaForward = (fLastForward - Forward()) / deltaPosition.Magnitude(); const hsVector3 deltaForward = (fLastForward - Forward()) / deltaPosition.Magnitude();
const hsVector3 lateral = PerpendicularComponent(deltaForward, Forward()); const hsVector3 lateral = PerpendicularComponent(deltaForward, Forward());
const float sign = ((lateral * Side()) < 0) ? 1.0f : -1.0f; const float sign = ((lateral * Side()) < 0) ? 1.0f : -1.0f;
@ -529,7 +529,9 @@ hsBool pfBoid::IInBoidNeighborhood(const pfVehicle &other, const float minDistan
return false; return false;
else else
{ {
const hsVector3 offset(&(other.Position()), &Position()); hsPoint3 selfpos = Position();
hsPoint3 otherpos = other.Position();
const hsVector3 offset(&otherpos, &selfpos);
const float distanceSquared = offset.MagnitudeSquared(); const float distanceSquared = offset.MagnitudeSquared();
// definitely in neighborhood if inside minDistance sphere // definitely in neighborhood if inside minDistance sphere
@ -576,14 +578,17 @@ hsVector3 pfBoid::ISteerForSeek(const hsPoint3 &target)
plDebugGeometry::Instance()->DrawLine(Position(), target, DEBUG_COLOR_RED); plDebugGeometry::Instance()->DrawLine(Position(), target, DEBUG_COLOR_RED);
#endif #endif
const hsVector3 desiredVelocity(&target, &Position()); hsPoint3 pos = Position();
const hsVector3 desiredVelocity(&target, &pos);
return desiredVelocity - Velocity(); return desiredVelocity - Velocity();
} }
hsVector3 pfBoid::ISteerToGoal(pfBoidGoal &goal, float maxPredictionTime) hsVector3 pfBoid::ISteerToGoal(pfBoidGoal &goal, float maxPredictionTime)
{ {
// offset from this to quarry, that distance, unit vector toward quarry // offset from this to quarry, that distance, unit vector toward quarry
const hsVector3 offset(&goal.Position(), &Position()); hsPoint3 gpos = goal.Position();
hsPoint3 pos = Position();
const hsVector3 offset(&gpos, &pos);
const float distance = offset.Magnitude(); const float distance = offset.Magnitude();
if (distance == 0) // nowhere to go if (distance == 0) // nowhere to go
return hsVector3(0, 0, 0); return hsVector3(0, 0, 0);
@ -680,7 +685,9 @@ hsVector3 pfBoid::ISteerForSeparation(const float maxDistance, const float cosMa
// add in steering contribution // add in steering contribution
// (opposite of the offset direction, divided once by distance // (opposite of the offset direction, divided once by distance
// to normalize, divided another time to get 1/d falloff) // to normalize, divided another time to get 1/d falloff)
const hsVector3 offset(&((**other).Position()), &Position()); hsPoint3 pos = Position();
hsPoint3 otherpos = (**other).Position();
const hsVector3 offset(&otherpos, &pos);
const float distanceSquared = offset * offset; const float distanceSquared = offset * offset;
steering += (offset / -distanceSquared); steering += (offset / -distanceSquared);
@ -727,7 +734,9 @@ hsVector3 pfBoid::ISteerForCohesion(const float maxDistance, const float cosMaxA
// correcting direction, then normalize to pure direction // correcting direction, then normalize to pure direction
if (neighbors > 0) if (neighbors > 0)
{ {
hsVector3 posVector(&(Position()), &(hsPoint3(0,0,0))); // quick hack to turn a point into a vector hsPoint3 pos = Position();
hsPoint3 zero(0, 0, 0);
hsVector3 posVector(&pos, &zero); // quick hack to turn a point into a vector
steering = ((steering / (float)neighbors) - posVector); steering = ((steering / (float)neighbors) - posVector);
steering.Normalize(); steering.Normalize();
} }

3
Sources/Plasma/FeatureLib/pfAnimation/plBlower.cpp

@ -168,8 +168,9 @@ void plBlower::ISetTargetTransform()
hsPoint3 pos = l2p.GetTranslate(); hsPoint3 pos = l2p.GetTranslate();
pos += fCurrDel; pos += fCurrDel;
hsPoint3 neg = -pos;
l2p.SetTranslate(&pos); l2p.SetTranslate(&pos);
p2l.SetTranslate(&-pos); p2l.SetTranslate(&neg);
ci->SetLocalToParent(l2p, p2l); ci->SetLocalToParent(l2p, p2l);
} }

3
Sources/Plasma/FeatureLib/pfAnimation/plFollowMod.cpp

@ -81,8 +81,9 @@ hsBool plFollowMod::MsgReceive(plMessage* msg)
{ {
hsVector3 pos; hsVector3 pos;
pos.Set(list->GetPosition().fX, list->GetPosition().fY, list->GetPosition().fZ); pos.Set(list->GetPosition().fX, list->GetPosition().fY, list->GetPosition().fZ);
hsVector3 neg = -pos;
fLeaderL2W.MakeTranslateMat(&pos); fLeaderL2W.MakeTranslateMat(&pos);
fLeaderW2L.MakeTranslateMat(&-pos); fLeaderW2L.MakeTranslateMat(&neg);
fLeaderSet = true; fLeaderSet = true;
return true; return true;

1
Sources/Plasma/FeatureLib/pfPython/cyMisc.cpp

@ -61,6 +61,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "pnMessage/plCameraMsg.h" #include "pnMessage/plCameraMsg.h"
#include "pnTimer/plTimerCallbackManager.h" #include "pnTimer/plTimerCallbackManager.h"
#include "plVault/plVault.h" #include "plVault/plVault.h"
#include "pnNetCommon/plCreatableUuid.h"
#include "plNetClient/plNetClientMgr.h" #include "plNetClient/plNetClientMgr.h"
#include "plNetClient/plNetLinkingMgr.h" #include "plNetClient/plNetLinkingMgr.h"
#include "plNetTransport/plNetTransport.h" #include "plNetTransport/plNetTransport.h"

2
Sources/Plasma/FeatureLib/pfPython/pyNetServerSessionInfo.h

@ -44,7 +44,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "hsTypes.h" #include "hsTypes.h"
#include "plNetCommon/plNetServerSessionInfo.h" #include "plNetCommon/plNetServerSessionInfo.h"
#include "plUUID/plUUID.h" #include "pnUUID/pnUUID.h"
#include <Python.h> #include <Python.h>
#include "pyGlueHelpers.h" #include "pyGlueHelpers.h"

2
Sources/Plasma/FeatureLib/pfSurface/CMakeLists.txt

@ -6,9 +6,9 @@ include_directories(../../PubUtilLib)
if(Bink_SDK_AVAILABLE) if(Bink_SDK_AVAILABLE)
include_directories(${Bink_INCLUDE_DIR}) include_directories(${Bink_INCLUDE_DIR})
endif() endif()
include_directories(${DirectX_INCLUDE_DIR})
if(WIN32) if(WIN32)
include_directories(${DirectX_INCLUDE_DIR})
add_definitions(-DWIN32) add_definitions(-DWIN32)
endif(WIN32) endif(WIN32)

1
Sources/Plasma/NucleusLib/CMakeLists.txt

@ -32,3 +32,4 @@ add_subdirectory(pnSimpleNet)
add_subdirectory(pnTimer) add_subdirectory(pnTimer)
add_subdirectory(pnUtils) add_subdirectory(pnUtils)
add_subdirectory(pnUtilsExe) add_subdirectory(pnUtilsExe)
add_subdirectory(pnUUID)

1
Sources/Plasma/NucleusLib/inc/CMakeLists.txt

@ -30,6 +30,7 @@ set(pnNucleusInc_SOURCES
) )
add_library(pnNucleusInc STATIC ${pnNucleusInc_HEADERS} ${pnNucleusInc_SOURCES}) add_library(pnNucleusInc STATIC ${pnNucleusInc_HEADERS} ${pnNucleusInc_SOURCES})
target_link_libraries(pnNucleusInc CoreLib pnTimer)
source_group("Header Files" FILES ${pnNucleusInc_HEADERS}) source_group("Header Files" FILES ${pnNucleusInc_HEADERS})
source_group("Source Files" FILES ${pnNucleusInc_SOURCES}) source_group("Source Files" FILES ${pnNucleusInc_SOURCES})

4
Sources/Plasma/NucleusLib/pnAddrInfo/CMakeLists.txt

@ -9,6 +9,10 @@ set(pnAddrInfo_HEADERS
) )
add_library(pnAddrInfo STATIC ${pnAddrInfo_SOURCES} ${pnAddrInfo_HEADERS}) add_library(pnAddrInfo STATIC ${pnAddrInfo_SOURCES} ${pnAddrInfo_HEADERS})
target_link_libraries(pnAddrInfo CoreLib)
if(WIN32)
target_link_libraries(pnAddrInfo ws2_32)
endif(WIN32)
source_group("Source Files" FILES ${pnAddrInfo_SOURCES}) source_group("Source Files" FILES ${pnAddrInfo_SOURCES})
source_group("Header Files" FILES ${pnAddrInfo_HEADERS}) source_group("Header Files" FILES ${pnAddrInfo_HEADERS})

3
Sources/Plasma/NucleusLib/pnDispatch/CMakeLists.txt

@ -1,7 +1,7 @@
include_directories(../../CoreLib) include_directories(../../CoreLib)
include_directories(../../NucleusLib) include_directories(../../NucleusLib)
include_directories(../../NucleusLib/inc) include_directories(../../NucleusLib/inc)
include_directories("../../PubUtilLib") include_directories(../../PubUtilLib)
set(pnDispatch_SOURCES set(pnDispatch_SOURCES
plDispatch.cpp plDispatch.cpp
@ -15,6 +15,7 @@ set(pnDispatch_HEADERS
) )
add_library(pnDispatch STATIC ${pnDispatch_SOURCES} ${pnDispatch_HEADERS}) add_library(pnDispatch STATIC ${pnDispatch_SOURCES} ${pnDispatch_HEADERS})
target_link_libraries(pnDispatch pnNucleusInc)
source_group("Source Files" FILES ${pnDispatch_SOURCES}) source_group("Source Files" FILES ${pnDispatch_SOURCES})
source_group("Header Files" FILES ${pnDispatch_HEADERS}) source_group("Header Files" FILES ${pnDispatch_HEADERS})

1
Sources/Plasma/NucleusLib/pnFactory/CMakeLists.txt

@ -13,6 +13,7 @@ set(pnFactory_HEADERS
) )
add_library(pnFactory STATIC ${pnFactory_SOURCES} ${pnFactory_HEADERS}) add_library(pnFactory STATIC ${pnFactory_SOURCES} ${pnFactory_HEADERS})
target_link_libraries(pnFactory CoreLib)
source_group("Source Files" FILES ${pnFactory_SOURCES}) source_group("Source Files" FILES ${pnFactory_SOURCES})
source_group("Header Files" FILES ${pnFactory_HEADERS}) source_group("Header Files" FILES ${pnFactory_HEADERS})

2
Sources/Plasma/NucleusLib/pnInputCore/plOSMsg.h

@ -42,7 +42,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#ifndef plOSMsg_inc #ifndef plOSMsg_inc
#define plOSMsg_inc #define plOSMsg_inc
#include <windows.h> #include "hsWindows.h"
// //
// This enum wraps all of the OS messages // This enum wraps all of the OS messages

1
Sources/Plasma/NucleusLib/pnKeyedObject/CMakeLists.txt

@ -24,6 +24,7 @@ set(pnKeyedObject_SOURCES
) )
add_library(pnKeyedObject STATIC ${pnKeyedObject_HEADERS} ${pnKeyedObject_SOURCES}) add_library(pnKeyedObject STATIC ${pnKeyedObject_HEADERS} ${pnKeyedObject_SOURCES})
target_link_libraries(pnKeyedObject CoreLib pnMessage)
source_group("Header Files" FILES ${pnKeyedObject_HEADERS}) source_group("Header Files" FILES ${pnKeyedObject_HEADERS})
source_group("Source Files" FILES ${pnKeyedObject_SOURCES}) source_group("Source Files" FILES ${pnKeyedObject_SOURCES})

1
Sources/Plasma/NucleusLib/pnMessage/CMakeLists.txt

@ -59,6 +59,7 @@ set(pnMessage_SOURCES
) )
add_library(pnMessage STATIC ${pnMessage_HEADERS} ${pnMessage_SOURCES}) add_library(pnMessage STATIC ${pnMessage_HEADERS} ${pnMessage_SOURCES})
target_link_libraries(pnMessage CoreLib pnNetCommon)
source_group("Header Files" FILES ${pnMessage_HEADERS}) source_group("Header Files" FILES ${pnMessage_HEADERS})
source_group("Source Files" FILES ${pnMessage_SOURCES}) source_group("Source Files" FILES ${pnMessage_SOURCES})

2
Sources/Plasma/NucleusLib/pnNetCommon/CMakeLists.txt

@ -4,6 +4,7 @@ include_directories("../../NucleusLib/inc")
include_directories("../../PubUtilLib") include_directories("../../PubUtilLib")
set(pnNetCommon_HEADERS set(pnNetCommon_HEADERS
plCreatableUuid.h
plGenericVar.h plGenericVar.h
plNetAddress.h plNetAddress.h
plNetApp.h plNetApp.h
@ -33,6 +34,7 @@ set(pnNetCommon_SOURCES
) )
add_library(pnNetCommon STATIC ${pnNetCommon_HEADERS} ${pnNetCommon_SOURCES}) add_library(pnNetCommon STATIC ${pnNetCommon_HEADERS} ${pnNetCommon_SOURCES})
target_link_libraries(pnNetCommon pnAddrInfo plStatusLog)
source_group("Header Files" FILES ${pnNetCommon_HEADERS}) source_group("Header Files" FILES ${pnNetCommon_HEADERS})
source_group("Source Files" FILES ${pnNetCommon_SOURCES}) source_group("Source Files" FILES ${pnNetCommon_SOURCES})

61
Sources/Plasma/NucleusLib/pnNetCommon/plCreatableUuid.h

@ -0,0 +1,61 @@
/*==LICENSE==*
CyanWorlds.com Engine - MMOG client, server and tools
Copyright (C) 2011 Cyan Worlds, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
Additional permissions under GNU GPL version 3 section 7
If you modify this Program, or any covered work, by linking or
combining it with any of RAD Game Tools Bink SDK, Autodesk 3ds Max SDK,
NVIDIA PhysX SDK, Microsoft DirectX SDK, OpenSSL library, Independent
JPEG Group JPEG library, Microsoft Windows Media SDK, or Apple QuickTime SDK
(or a modified version of those libraries),
containing parts covered by the terms of the Bink SDK EULA, 3ds Max EULA,
PhysX SDK EULA, DirectX SDK EULA, OpenSSL and SSLeay licenses, IJG
JPEG Library README, Windows Media SDK EULA, or QuickTime SDK EULA, the
licensors of this Program grant you additional
permission to convey the resulting work. Corresponding Source for a
non-source form of such a combination shall include the source code for
the parts of OpenSSL and IJG JPEG Library used as well as that of the covered
work.
You can contact Cyan Worlds, Inc. by email legal@cyan.com
or by snail mail at:
Cyan Worlds, Inc.
14617 N Newport Hwy
Mead, WA 99021
*==LICENSE==*/
#ifndef pnCreatableUUID_h_inc
#define pnCreatableUUID_h_inc
#include "pnUUID/pnUUID.h"
#include "pnFactory/plCreatable.h"
class plCreatableUuid : public plUUID, public plCreatable {
public:
CLASSNAME_REGISTER( plCreatableUuid );
GETINTERFACE_ANY( plCreatableUuid, plCreatable );
plCreatableUuid() { }
plCreatableUuid(const plCreatableUuid& other) : plUUID(other) { }
plCreatableUuid(const plUUID& other) : plUUID(other) { }
void Read( hsStream * s, hsResMgr* ) { plUUID::Read(s); }
void Write( hsStream * s, hsResMgr* ) { plUUID::Write(s); }
};
#endif //pnCreatableUUID_h_inc

3
Sources/Plasma/NucleusLib/pnNetCommon/pnNetCommonCreatable.h

@ -57,6 +57,9 @@ REGISTER_CREATABLE( plCreatableGenericValue );
#include "pnNetCommon.h" #include "pnNetCommon.h"
REGISTER_CREATABLE( plCreatableStream ); REGISTER_CREATABLE( plCreatableStream );
#include "plCreatableUuid.h"
REGISTER_CREATABLE( plCreatableUuid );
#endif // pnNetCommonCreatable_inc #endif // pnNetCommonCreatable_inc

2
Sources/Plasma/NucleusLib/pnProduct/CMakeLists.txt

@ -20,5 +20,7 @@ set(pnProduct_PRIVATE
add_library(pnProduct STATIC ${pnProduct_HEADERS} ${pnProduct_PRIVATE}) add_library(pnProduct STATIC ${pnProduct_HEADERS} ${pnProduct_PRIVATE})
target_link_libraries(pnProduct CoreLib pnUUID)
source_group("Header Files" FILES ${pnProduct_HEADERS}) source_group("Header Files" FILES ${pnProduct_HEADERS})
source_group("Private" FILES ${pnProduct_PRIVATE}) source_group("Private" FILES ${pnProduct_PRIVATE})

3
Sources/Plasma/NucleusLib/pnProduct/Pch.h

@ -50,7 +50,4 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#endif #endif
#define PLASMA20_SOURCES_PLASMA_NUCLEUSLIB_PNPRODUCT_PCH_H #define PLASMA20_SOURCES_PLASMA_NUCLEUSLIB_PNPRODUCT_PCH_H
#include "pnUtils/pnUtils.h"
#include "Private/pnPrAllIncludes.h" #include "Private/pnPrAllIncludes.h"

3
Sources/Plasma/NucleusLib/pnProduct/Private/pnPrAllIncludes.h

@ -49,7 +49,8 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#define PLASMA20_SOURCES_PLASMA_NUCLEUSLIB_PNPRODUCT_PRIVATE_PNPRALLINCLUDES_H #define PLASMA20_SOURCES_PLASMA_NUCLEUSLIB_PNPRODUCT_PRIVATE_PNPRALLINCLUDES_H
#include "pnUtils/pnUtils.h" //#include "pnUtils/pnUtils.h"
#include "pnUUID/pnUUID.h"
#include "pnPrBuildId.h" #include "pnPrBuildId.h"
#include "pnPrBranchId.h" #include "pnPrBranchId.h"

6
Sources/Plasma/NucleusLib/pnProduct/Private/pnPrProductId.cpp

@ -61,7 +61,7 @@ namespace Uru {
static const wchar kCoreName[] = L"UruLive"; static const wchar kCoreName[] = L"UruLive";
static const wchar kShortName[] = L"UruLive"; static const wchar kShortName[] = L"UruLive";
static const wchar kLongName[] = L"Uru Live"; static const wchar kLongName[] = L"Uru Live";
static const Uuid kId(L"ea489821-6c35-4bd0-9dae-bb17c585e680"); static const plUUID kId("ea489821-6c35-4bd0-9dae-bb17c585e680");
} }
// @@@: add your product namespace here // @@@: add your product namespace here
@ -96,7 +96,7 @@ namespace Uru {
***/ ***/
//============================================================================ //============================================================================
const Uuid & ProductId () { const plUUID& ProductId () {
return PRODUCT_ID; return PRODUCT_ID;
} }
@ -119,7 +119,7 @@ const wchar * ProductLongName () {
//============================================================================ //============================================================================
void ProductString (wchar * dest, unsigned destChars) { void ProductString (wchar * dest, unsigned destChars) {
// Example: "UruLive.2.214 - External.Release" // Example: "UruLive.2.214 - External.Release"
StrPrintf( swprintf(
dest, dest,
destChars, destChars,
L"%s.%u.%u - %s.%s", L"%s.%u.%u - %s.%s",

2
Sources/Plasma/NucleusLib/pnProduct/Private/pnPrProductId.h

@ -83,7 +83,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
* *
***/ ***/
const Uuid & ProductId (); const plUUID& ProductId ();
const wchar * ProductCoreName (); // e.g: L"Uru" const wchar * ProductCoreName (); // e.g: L"Uru"
const wchar * ProductShortName (); // e.g: L"Uru" (filename/registry friendly) const wchar * ProductShortName (); // e.g: L"Uru" (filename/registry friendly)
const wchar * ProductLongName (); // e.g: L"Uru: Ages Beyond Myst" (human friendly) const wchar * ProductLongName (); // e.g: L"Uru: Ages Beyond Myst" (human friendly)

1
Sources/Plasma/NucleusLib/pnTimer/CMakeLists.txt

@ -18,6 +18,7 @@ set(pnTimer_SOURCES
) )
add_library(pnTimer STATIC ${pnTimer_HEADERS} ${pnTimer_SOURCES}) add_library(pnTimer STATIC ${pnTimer_HEADERS} ${pnTimer_SOURCES})
target_link_libraries(pnTimer CoreLib)
source_group("Header Files" FILES ${pnTimer_HEADERS}) source_group("Header Files" FILES ${pnTimer_HEADERS})
source_group("Source Files" FILES ${pnTimer_SOURCES}) source_group("Source Files" FILES ${pnTimer_SOURCES})

28
Sources/Plasma/NucleusLib/pnUUID/CMakeLists.txt

@ -0,0 +1,28 @@
include_directories("../../CoreLib")
include_directories("../../NucleusLib")
set(pnUUID_SOURCES
pnUUID.cpp
)
if(WIN32)
set(pnUUID_SOURCES ${pnUUID_SOURCES} pnUUID_Win32.cpp)
else(WIN32)
set(pnUUID_SOURCES ${pnUUID_SOURCES} pnUUID_Unix.cpp)
endif(WIN32)
set(pnUUID_HEADERS
pnUUID.h
)
add_library(pnUUID STATIC ${pnUUID_SOURCES} ${pnUUID_HEADERS})
target_link_libraries(pnUUID CoreLib)
if(WIN32)
target_link_libraries(pnUUID pnUtils)
target_link_libraries(pnUUID Rpcrt4)
else(WIN32)
target_link_libraries(pnUUID uuid)
endif(WIN32)
source_group("Source Files" FILES ${pnUUID_SOURCES})
source_group("Header Files" FILES ${pnUUID_HEADERS})

48
Sources/Plasma/PubUtilLib/plUUID/plUUID.cpp → Sources/Plasma/NucleusLib/pnUUID/pnUUID.cpp

@ -39,11 +39,9 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
Mead, WA 99021 Mead, WA 99021
*==LICENSE==*/ *==LICENSE==*/
#include "plUUID.h" #include "pnUUID.h"
#include "hsStream.h" #include "hsStream.h"
COMPILER_ASSERT(msizeof(Uuid, data) == msizeof(plUUID, fData));
plUUID::plUUID() plUUID::plUUID()
{ {
Clear(); Clear();
@ -59,11 +57,6 @@ plUUID::plUUID( const plUUID & other )
CopyFrom( &other ); CopyFrom( &other );
} }
plUUID::plUUID( const Uuid & uuid )
{
MemCopy(fData, uuid.data, sizeof(fData));
}
void plUUID::Read( hsStream * s) void plUUID::Read( hsStream * s)
{ {
s->LogSubStreamPushDesc("plUUID"); s->LogSubStreamPushDesc("plUUID");
@ -75,47 +68,8 @@ void plUUID::Write( hsStream * s)
s->Write( sizeof( fData ), (const void*)fData ); s->Write( sizeof( fData ), (const void*)fData );
} }
plUUID::operator Uuid () const {
Uuid uuid;
MemCopy(uuid.data, fData, sizeof(uuid.data));
return uuid;
}
const char * plUUID::AsString() const { const char * plUUID::AsString() const {
static std::string str; static std::string str;
ToStdString(str); ToStdString(str);
return str.c_str(); return str.c_str();
} }
void plUUID::CopyFrom( const plUUID * v ) {
if (!v)
Clear();
else
CopyFrom(*v);
}
void plUUID::CopyFrom( const plUUID & v ) {
MemCopy(fData, v.fData, sizeof(fData));
}
/*****************************************************************************
*
* plCreatableUuid
*
***/
//============================================================================
plCreatableUuid::plCreatableUuid () {
}
//============================================================================
plCreatableUuid::plCreatableUuid (const plCreatableUuid & other)
: plUUID(other)
{
}
//============================================================================
plCreatableUuid::plCreatableUuid (const plUUID & other)
: plUUID(other)
{
}

27
Sources/Plasma/PubUtilLib/plUUID/plUUID.h → Sources/Plasma/NucleusLib/pnUUID/pnUUID.h

@ -39,13 +39,14 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
Mead, WA 99021 Mead, WA 99021
*==LICENSE==*/ *==LICENSE==*/
#ifndef plUUID_h_inc #ifndef pnUUID_h_inc
#define plUUID_h_inc #define pnUUID_h_inc
#include "hsTypes.h" #include "hsTypes.h"
#include "hsStlUtils.h" #include "hsStlUtils.h"
#ifdef HS_BUILD_FOR_WIN32
#include "pnUtils/pnUtils.h" #include "pnUtils/pnUtils.h"
#include "pnFactory/plCreatable.h" #endif
class hsStream; class hsStream;
@ -64,7 +65,9 @@ public:
plUUID(); plUUID();
plUUID( const char * s ); plUUID( const char * s );
plUUID( const plUUID & other ); plUUID( const plUUID & other );
#ifdef HS_BUILD_FOR_WIN32
plUUID( const Uuid & uuid ); plUUID( const Uuid & uuid );
#endif
void Clear(); void Clear();
bool IsNull() const; bool IsNull() const;
bool IsSet() const { return !IsNull(); } bool IsSet() const { return !IsNull(); }
@ -82,23 +85,11 @@ public:
bool operator==( const plUUID & other ) const { return IsEqualTo( &other ); } bool operator==( const plUUID & other ) const { return IsEqualTo( &other ); }
bool operator!=( const plUUID & other ) const { return !IsEqualTo( &other ); } bool operator!=( const plUUID & other ) const { return !IsEqualTo( &other ); }
int operator <( const plUUID & other ) const { return CompareTo( &other ); } int operator <( const plUUID & other ) const { return CompareTo( &other ); }
#ifdef HS_BUILD_FOR_WIN32
operator Uuid () const; operator Uuid () const;
#endif
static plUUID Generate(); static plUUID Generate();
}; };
class plCreatableUuid : public plUUID, public plCreatable { #endif // pnUUID_h_inc
public:
CLASSNAME_REGISTER( plCreatableUuid );
GETINTERFACE_ANY( plCreatableUuid, plCreatable );
plCreatableUuid ();
plCreatableUuid (const plCreatableUuid & other);
plCreatableUuid (const plUUID & other);
void Read( hsStream * s, hsResMgr* ) { plUUID::Read(s); }
void Write( hsStream * s, hsResMgr* ) { plUUID::Write(s); }
};
#endif // plUUID_h_inc

2
Sources/Plasma/PubUtilLib/plUUID/plUUID_Unix.cpp → Sources/Plasma/NucleusLib/pnUUID/pnUUID_Unix.cpp

@ -39,7 +39,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
Mead, WA 99021 Mead, WA 99021
*==LICENSE==*/ *==LICENSE==*/
#include "plUUID.h" #include "pnUUID.h"
#ifdef HS_BUILD_FOR_UNIX #ifdef HS_BUILD_FOR_UNIX

26
Sources/Plasma/PubUtilLib/plUUID/plUUID_Win32.cpp → Sources/Plasma/NucleusLib/pnUUID/pnUUID_Win32.cpp

@ -39,7 +39,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
Mead, WA 99021 Mead, WA 99021
*==LICENSE==*/ *==LICENSE==*/
#include "plUUID.h" #include "pnUUID.h"
#ifdef HS_BUILD_FOR_WIN32 #ifdef HS_BUILD_FOR_WIN32
@ -47,6 +47,13 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "hsWindows.h" #include "hsWindows.h"
#include <rpc.h> #include <rpc.h>
COMPILER_ASSERT(msizeof(Uuid, data) == msizeof(plUUID, fData));
plUUID::plUUID( const Uuid & uuid )
{
MemCopy(fData, uuid.data, sizeof(fData));
}
void plUUID::Clear() void plUUID::Clear()
{ {
UuidCreateNil( (GUID *)this ); UuidCreateNil( (GUID *)this );
@ -69,6 +76,23 @@ bool plUUID::IsNull() const
return 1 == UuidIsNil( (GUID *)this, &s ); return 1 == UuidIsNil( (GUID *)this, &s );
} }
void plUUID::CopyFrom( const plUUID * v ) {
if (!v)
Clear();
else
CopyFrom(*v);
}
void plUUID::CopyFrom( const plUUID & v ) {
MemCopy(fData, v.fData, sizeof(fData));
}
plUUID::operator Uuid () const {
Uuid uuid;
MemCopy(uuid.data, fData, sizeof(uuid.data));
return uuid;
}
bool plUUID::FromString( const char * str ) bool plUUID::FromString( const char * str )
{ {
Clear(); Clear();

1
Sources/Plasma/PubUtilLib/CMakeLists.txt

@ -48,5 +48,4 @@ add_subdirectory(plStreamLogger)
add_subdirectory(plSurface) add_subdirectory(plSurface)
add_subdirectory(plTransform) add_subdirectory(plTransform)
add_subdirectory(plUnifiedTime) add_subdirectory(plUnifiedTime)
add_subdirectory(plUUID)
add_subdirectory(plVault) add_subdirectory(plVault)

4
Sources/Plasma/PubUtilLib/plAgeLoader/plAgeLoader.cpp

@ -46,7 +46,11 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
//#include "hsTimer.h" //#include "hsTimer.h"
#include "plResPatcher.h" #include "plResPatcher.h"
#include "plBackgroundDownloader.h" #include "plBackgroundDownloader.h"
#if HS_BUILD_FOR_WIN32
# include "process.h" // for getpid() # include "process.h" // for getpid()
#else
# include <unistd.h>
#endif
#include "pnProduct/pnProduct.h" #include "pnProduct/pnProduct.h"

2
Sources/Plasma/PubUtilLib/plAgeLoader/plAgeLoader.h

@ -52,7 +52,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "plAgeDescription/plAgeDescription.h" #include "plAgeDescription/plAgeDescription.h"
#include "plUUID/plUUID.h" #include "pnUUID/pnUUID.h"
// //
// A singleton class which manages loading and unloading ages and operations associated with that // A singleton class which manages loading and unloading ages and operations associated with that

2
Sources/Plasma/PubUtilLib/plAudio/CMakeLists.txt

@ -3,7 +3,9 @@ include_directories("../../NucleusLib/inc")
include_directories("../../NucleusLib") include_directories("../../NucleusLib")
include_directories("../../PubUtilLib") include_directories("../../PubUtilLib")
if(WIN32)
include_directories(${DirectX_INCLUDE_DIR}) include_directories(${DirectX_INCLUDE_DIR})
endif(WIN32)
include_directories(${OPENAL_INCLUDE_DIR}) include_directories(${OPENAL_INCLUDE_DIR})
include_directories(${Speex_INCLUDE_DIR}) include_directories(${Speex_INCLUDE_DIR})

8
Sources/Plasma/PubUtilLib/plAudioCore/CMakeLists.txt

@ -3,9 +3,13 @@ include_directories("../../NucleusLib/inc")
include_directories("../../NucleusLib") include_directories("../../NucleusLib")
include_directories("../../PubUtilLib") include_directories("../../PubUtilLib")
include_directories(${DirectX_INCLUDE_DIR})
include_directories(${Ogg_INCLUDE_DIR}) include_directories(${Ogg_INCLUDE_DIR})
include_directories(${Vorbis_INCLUDE_DIR}) include_directories(${Vorbis_INCLUDE_DIR})
# We only need DirectX if we're building the Max plugin
# TODO: Check if we actually need this at all
if(3dsm_BUILD_PLUGIN)
include_directories(${DirectX_INCLUDE_DIR})
endif(3dsm_BUILD_PLUGIN)
set(plAudioCore_SOURCES set(plAudioCore_SOURCES
plAudioFileReader.cpp plAudioFileReader.cpp
@ -32,6 +36,8 @@ set(plAudioCore_HEADERS
) )
add_library(plAudioCore STATIC ${plAudioCore_SOURCES} ${plAudioCore_HEADERS}) add_library(plAudioCore STATIC ${plAudioCore_SOURCES} ${plAudioCore_HEADERS})
target_link_libraries(plAudioCore ${Ogg_LIBRARIES})
target_link_libraries(plAudioCore ${Vorbis_LIBRARIES})
source_group("Source Files" FILES ${plAudioCore_SOURCES}) source_group("Source Files" FILES ${plAudioCore_SOURCES})
source_group("Header Files" FILES ${plAudioCore_HEADERS}) source_group("Header Files" FILES ${plAudioCore_HEADERS})

6
Sources/Plasma/PubUtilLib/plAvatar/plAGAnimInstance.cpp

@ -458,9 +458,9 @@ hsScalar plAGAnimInstance::ICalcFade(hsBool &fade, hsScalar curVal, hsScalar goa
hsScalar newVal; hsScalar newVal;
hsScalar curStep = rate * elapsed; hsScalar curStep = rate * elapsed;
if(rate > 0) { if(rate > 0) {
newVal = __min(goal, curVal + curStep); newVal = std::min(goal, curVal + curStep);
} else { } else {
newVal = __max(goal, curVal + curStep); newVal = std::max(goal, curVal + curStep);
} }
if(newVal == goal) if(newVal == goal)
@ -593,7 +593,7 @@ void DumpAGAllocs()
agAlloc * al = (*i).second; agAlloc * al = (*i).second;
delete al; delete al;
i = gAGAllocs.erase(i); gAGAllocs.erase(i++);
} }
hsStatusMessage("FINISHED DUMPING AG ALLOCATIONS *********************************************"); hsStatusMessage("FINISHED DUMPING AG ALLOCATIONS *********************************************");
} }

2
Sources/Plasma/PubUtilLib/plAvatar/plAnimStage.cpp

@ -51,7 +51,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "plAGAnimInstance.h" #include "plAGAnimInstance.h"
#include "plMatrixChannel.h" #include "plMatrixChannel.h"
#include "plAvBrainGeneric.h" #include "plAvBrainGeneric.h"
#include "plMultiStageBehMod.h" #include "plMultistageBehMod.h"
// global // global
#include "hsUtils.h" #include "hsUtils.h"

3
Sources/Plasma/PubUtilLib/plContainer/plConfigInfo.cpp

@ -797,7 +797,8 @@ bool plIniSectionConfigSource::ReadSubSource( const char * name )
std::vector<std::string> sections; std::vector<std::string> sections;
for ( int i=0; i<fSections.size(); i++ ) for ( int i=0; i<fSections.size(); i++ )
sections.push_back( fSections[i].c_str() ); sections.push_back( fSections[i].c_str() );
return fConfigInfo->ReadFrom(&plIniSectionConfigSource( name, sections )); plIniSectionConfigSource src(name, sections);
return fConfigInfo->ReadFrom(&src);
} }
///////////////////////////////////////////////// /////////////////////////////////////////////////

6
Sources/Plasma/PubUtilLib/plDrawable/plCluster.cpp

@ -205,8 +205,10 @@ void plCluster::UnPack(UInt8* vDst, UInt16* iDst, int idxOffset, hsBounds3Ext& w
} }
} }
} }
wBnd.Reset(&hsPoint3(minX, minY, minZ)); hsPoint3 min(minX, minY, minZ);
wBnd.Union(&hsPoint3(maxX, maxY, maxZ)); wBnd.Reset(&min);
hsPoint3 max(maxX, maxY, maxZ);
wBnd.Union(&max);
} }

3
Sources/Plasma/PubUtilLib/plDrawable/plDrawableGenerator.cpp

@ -547,7 +547,8 @@ plDrawableSpans *plDrawableGenerator::GenerateConicalDrawable( hsScalar radi
direction.Set( 0, 0, height ); direction.Set( 0, 0, height );
return GenerateConicalDrawable( hsPoint3( 0, 0, 0 ), direction, radius, material, localToWorld, blended, hsPoint3 zero(0, 0, 0);
return GenerateConicalDrawable(zero, direction, radius, material, localToWorld, blended,
multColor, retIndex, toAddTo ); multColor, retIndex, toAddTo );
} }

5
Sources/Plasma/PubUtilLib/plDrawable/plDrawableSpans.cpp

@ -3549,8 +3549,9 @@ plParticleSpan *plDrawableSpans::ICreateParticleIcicle( hsGMaterial *material,
icicle->fLocalBounds.MakeEmpty(); icicle->fLocalBounds.MakeEmpty();
icicle->fWorldBounds.MakeEmpty(); icicle->fWorldBounds.MakeEmpty();
icicle->fLocalBounds.Union( &hsPoint3(0,0,0) ); hsPoint3 zero(0, 0, 0);
icicle->fWorldBounds.Union( &hsPoint3(0,0,0) ); icicle->fLocalBounds.Union( &zero );
icicle->fWorldBounds.Union( &zero );
icicle->fGroupIdx = set->fGroupIdx; icicle->fGroupIdx = set->fGroupIdx;
icicle->fVBufferIdx = set->fVBufferIdx; icicle->fVBufferIdx = set->fVBufferIdx;

2
Sources/Plasma/PubUtilLib/plDrawable/plDynaBulletMgr.cpp

@ -103,7 +103,7 @@ hsBool plDynaBulletMgr::IHandleShot(plBulletMsg* bull)
fCutter->SetLength(hsVector3(bull->Radius() * fScale.fX, bull->Radius() * fScale.fY, bull->Range())); fCutter->SetLength(hsVector3(bull->Radius() * fScale.fX, bull->Radius() * fScale.fY, bull->Range()));
fCutter->Set(pos, up, -bull->Dir()); fCutter->Set(pos, up, -bull->Dir());
plDynaDecalInfo& info = IGetDecalInfo(UInt32(this), GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(this), GetKey());
if( bull->PartyTime() > 0 ) if( bull->PartyTime() > 0 )
fPartyTime = bull->PartyTime(); fPartyTime = bull->PartyTime();

10
Sources/Plasma/PubUtilLib/plDrawable/plDynaDecalMgr.cpp

@ -348,7 +348,7 @@ hsBool plDynaDecalMgr::IWetParts(const plDynaDecalEnableMsg* enaMsg)
const plPrintShape* shape = IGetPrintShape(enaMsg->GetShapeKey()); const plPrintShape* shape = IGetPrintShape(enaMsg->GetShapeKey());
if( shape ) if( shape )
{ {
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
IWetInfo(info, enaMsg); IWetInfo(info, enaMsg);
} }
} }
@ -362,7 +362,7 @@ hsBool plDynaDecalMgr::IWetParts(const plDynaDecalEnableMsg* enaMsg)
const plPrintShape* shape = IGetPrintShape(avMod, fPartIDs[i]); const plPrintShape* shape = IGetPrintShape(avMod, fPartIDs[i]);
if( shape ) if( shape )
{ {
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
IWetInfo(info, enaMsg); IWetInfo(info, enaMsg);
} }
} }
@ -381,7 +381,7 @@ hsBool plDynaDecalMgr::IWetPart(UInt32 id, const plDynaDecalEnableMsg* enaMsg)
const plPrintShape* shape = IGetPrintShape(avMod, id); const plPrintShape* shape = IGetPrintShape(avMod, id);
if( shape ) if( shape )
{ {
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
IWetInfo(info, enaMsg); IWetInfo(info, enaMsg);
} }
return true; return true;
@ -484,7 +484,7 @@ hsBool plDynaDecalMgr::MsgReceive(plMessage* msg)
return true; return true;
case kRefAvatar: case kRefAvatar:
if( refMsg->GetContext() & (plRefMsg::kOnRemove|plRefMsg::kOnDestroy) ) if( refMsg->GetContext() & (plRefMsg::kOnRemove|plRefMsg::kOnDestroy) )
IRemoveDecalInfo(UInt32(refMsg->GetRef())); IRemoveDecalInfo(unsigned_ptr(refMsg->GetRef()));
return true; return true;
} }
} }
@ -537,7 +537,7 @@ plDynaDecalInfo& plDynaDecalInfo::Init(const plKey& key)
return *this; return *this;
} }
plDynaDecalInfo& plDynaDecalMgr::IGetDecalInfo(UInt32 id, const plKey& key) plDynaDecalInfo& plDynaDecalMgr::IGetDecalInfo(unsigned_ptr id, const plKey& key)
{ {
plDynaDecalMap::iterator iter = fDecalMap.find(id); plDynaDecalMap::iterator iter = fDecalMap.find(id);
if( iter == fDecalMap.end() ) if( iter == fDecalMap.end() )

4
Sources/Plasma/PubUtilLib/plDrawable/plDynaDecalMgr.h

@ -104,7 +104,7 @@ public:
plDynaDecalInfo& Init(const plKey& key); plDynaDecalInfo& Init(const plKey& key);
}; };
typedef std::map< UInt32, plDynaDecalInfo, std::less<UInt32> > plDynaDecalMap; typedef std::map< unsigned_ptr, plDynaDecalInfo, std::less<unsigned_ptr> > plDynaDecalMap;
// plDynaDecalMgr // plDynaDecalMgr
// Primary responsibilities: // Primary responsibilities:
@ -189,7 +189,7 @@ protected:
hsBool IWetPart(UInt32 id, const plDynaDecalEnableMsg* enaMsg); hsBool IWetPart(UInt32 id, const plDynaDecalEnableMsg* enaMsg);
void IWetInfo(plDynaDecalInfo& info, const plDynaDecalEnableMsg* enaMsg) const; void IWetInfo(plDynaDecalInfo& info, const plDynaDecalEnableMsg* enaMsg) const;
hsScalar IHowWet(plDynaDecalInfo& info, double t) const; hsScalar IHowWet(plDynaDecalInfo& info, double t) const;
plDynaDecalInfo& IGetDecalInfo(UInt32 id, const plKey& key); plDynaDecalInfo& IGetDecalInfo(unsigned_ptr id, const plKey& key);
void IRemoveDecalInfo(UInt32 id); void IRemoveDecalInfo(UInt32 id);
void IRemoveDecalInfos(const plKey& key); void IRemoveDecalInfos(const plKey& key);

4
Sources/Plasma/PubUtilLib/plDrawable/plDynaFootMgr.cpp

@ -115,7 +115,7 @@ hsBool plDynaFootMgr::MsgReceive(plMessage* msg)
const plPrintShape* shape = IGetPrintShape(armMod, id); const plPrintShape* shape = IGetPrintShape(armMod, id);
if( shape ) if( shape )
{ {
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
if( IPrintFromShape(shape, footMsg->IsLeft()) ) if( IPrintFromShape(shape, footMsg->IsLeft()) )
{ {
INotifyActive(info, armMod->GetKey(), id); INotifyActive(info, armMod->GetKey(), id);
@ -138,7 +138,7 @@ hsBool plDynaFootMgr::IPrintFromShape(const plPrintShape* shape, hsBool flip)
if( shape ) if( shape )
{ {
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
double secs = hsTimer::GetSysSeconds(); double secs = hsTimer::GetSysSeconds();
hsScalar wetness = IHowWet(info, secs); hsScalar wetness = IHowWet(info, secs);

2
Sources/Plasma/PubUtilLib/plDrawable/plDynaPuddleMgr.cpp

@ -94,7 +94,7 @@ hsBool plDynaPuddleMgr::MsgReceive(plMessage* msg)
const plPrintShape* shape = IGetPrintShape(armMod, fPartIDs[i]); const plPrintShape* shape = IGetPrintShape(armMod, fPartIDs[i]);
if( shape ) if( shape )
{ {
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
if( IRippleFromShape(shape, true) ) if( IRippleFromShape(shape, true) )
{ {
INotifyActive(info, armMod->GetKey(), fPartIDs[i]); INotifyActive(info, armMod->GetKey(), fPartIDs[i]);

7
Sources/Plasma/PubUtilLib/plDrawable/plDynaRippleMgr.cpp

@ -146,7 +146,7 @@ hsBool plDynaRippleMgr::MsgReceive(plMessage* msg)
const plPrintShape* shape = IGetPrintShape(armMsg->fArmature, fPartIDs[i]); const plPrintShape* shape = IGetPrintShape(armMsg->fArmature, fPartIDs[i]);
if( shape ) if( shape )
{ {
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
if( IRippleFromShape(shape, false) ) if( IRippleFromShape(shape, false) )
{ {
INotifyActive(info, armMsg->fArmature->GetKey(), fPartIDs[i]); INotifyActive(info, armMsg->fArmature->GetKey(), fPartIDs[i]);
@ -182,7 +182,7 @@ hsBool plDynaRippleMgr::IRippleFromShape(const plPrintShape* shape, hsBool force
hsBool retVal = false; hsBool retVal = false;
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
const hsMatrix44& shapeL2W = shape->GetOwner()->GetLocalToWorld(); const hsMatrix44& shapeL2W = shape->GetOwner()->GetLocalToWorld();
@ -191,7 +191,8 @@ hsBool plDynaRippleMgr::IRippleFromShape(const plPrintShape* shape, hsBool force
double t = hsTimer::GetSysSeconds(); double t = hsTimer::GetSysSeconds();
hsScalar dt = hsScalar(t - info.fLastTime) * sRand.RandZeroToOne(); hsScalar dt = hsScalar(t - info.fLastTime) * sRand.RandZeroToOne();
hsBool longEnough = (dt >= kMinTime); hsBool longEnough = (dt >= kMinTime);
hsBool farEnough = (hsVector3(&info.fLastPos, &shapeL2W.GetTranslate()).Magnitude() > kMinDist); hsPoint3 xlate = shapeL2W.GetTranslate();
hsBool farEnough = (hsVector3(&info.fLastPos, &xlate).Magnitude() > kMinDist);
if( force || longEnough || farEnough ) if( force || longEnough || farEnough )
{ {
hsPoint3 pos = shapeL2W.GetTranslate(); hsPoint3 pos = shapeL2W.GetTranslate();

5
Sources/Plasma/PubUtilLib/plDrawable/plDynaRippleMgrVS.cpp

@ -172,7 +172,7 @@ hsBool plDynaRippleVSMgr::IRippleFromShape(const plPrintShape* shape, hsBool for
hsBool retVal = false; hsBool retVal = false;
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
const hsMatrix44& shapeL2W = shape->GetOwner()->GetLocalToWorld(); const hsMatrix44& shapeL2W = shape->GetOwner()->GetLocalToWorld();
@ -181,7 +181,8 @@ hsBool plDynaRippleVSMgr::IRippleFromShape(const plPrintShape* shape, hsBool for
double t = hsTimer::GetSysSeconds(); double t = hsTimer::GetSysSeconds();
hsScalar dt = hsScalar(t - info.fLastTime) * sRand.RandZeroToOne(); hsScalar dt = hsScalar(t - info.fLastTime) * sRand.RandZeroToOne();
hsBool longEnough = (dt >= kMinTime); hsBool longEnough = (dt >= kMinTime);
hsBool farEnough = (hsVector3(&info.fLastPos, &shapeL2W.GetTranslate()).Magnitude() > kMinDist); hsPoint3 xlate = shapeL2W.GetTranslate();
hsBool farEnough = (hsVector3(&info.fLastPos, &xlate).Magnitude() > kMinDist);
if( force || longEnough || farEnough ) if( force || longEnough || farEnough )
{ {
hsPoint3 pos = shapeL2W.GetTranslate(); hsPoint3 pos = shapeL2W.GetTranslate();

2
Sources/Plasma/PubUtilLib/plDrawable/plDynaTorpedoMgr.cpp

@ -124,7 +124,7 @@ hsBool plDynaTorpedoMgr::IHandleShot(plBulletMsg* bull)
fCutter->SetLength(hsVector3(scaleX, scaleY, bull->Range())); fCutter->SetLength(hsVector3(scaleX, scaleY, bull->Range()));
fCutter->Set(pos, up, -bull->Dir()); fCutter->Set(pos, up, -bull->Dir());
plDynaDecalInfo& info = IGetDecalInfo(UInt32(this), GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(this), GetKey());
if( bull->PartyTime() > 0 ) if( bull->PartyTime() > 0 )
fPartyTime = bull->PartyTime(); fPartyTime = bull->PartyTime();

5
Sources/Plasma/PubUtilLib/plDrawable/plDynaWakeMgr.cpp

@ -173,7 +173,7 @@ hsBool plDynaWakeMgr::IRippleFromShape(const plPrintShape* shape, hsBool force)
hsBool retVal = false; hsBool retVal = false;
plDynaDecalInfo& info = IGetDecalInfo(UInt32(shape), shape->GetKey()); plDynaDecalInfo& info = IGetDecalInfo(unsigned_ptr(shape), shape->GetKey());
const hsMatrix44& shapeL2W = shape->GetOwner()->GetLocalToWorld(); const hsMatrix44& shapeL2W = shape->GetOwner()->GetLocalToWorld();
@ -182,7 +182,8 @@ hsBool plDynaWakeMgr::IRippleFromShape(const plPrintShape* shape, hsBool force)
double t = hsTimer::GetSysSeconds(); double t = hsTimer::GetSysSeconds();
hsScalar dt = hsScalar(t - info.fLastTime) * sRand.RandZeroToOne(); hsScalar dt = hsScalar(t - info.fLastTime) * sRand.RandZeroToOne();
hsBool longEnough = (dt >= kMinTime); hsBool longEnough = (dt >= kMinTime);
hsBool farEnough = (hsVector3(&info.fLastPos, &shapeL2W.GetTranslate()).Magnitude() > kMinDist); hsPoint3 xlate = shapeL2W.GetTranslate();
hsBool farEnough = (hsVector3(&info.fLastPos, &xlate).Magnitude() > kMinDist);
if( force || longEnough || farEnough ) if( force || longEnough || farEnough )
{ {
hsPoint3 pos = shapeL2W.GetTranslate(); hsPoint3 pos = shapeL2W.GetTranslate();

18
Sources/Plasma/PubUtilLib/plDrawable/plParticleFiller.cpp

@ -104,7 +104,8 @@ void inline IInlSetParticlePathFollow( const plParticleCore &particle, const hsM
/// Follow path specified by interpreting orientation as a velocity vector. /// Follow path specified by interpreting orientation as a velocity vector.
hsVector3 viewDir(&particle.fPos, &viewToWorld.GetTranslate()); hsPoint3 xlate = viewToWorld.GetTranslate();
hsVector3 viewDir(&particle.fPos, &xlate);
hsFastMath::NormalizeAppr(viewDir); hsFastMath::NormalizeAppr(viewDir);
zVec = viewDir; zVec = viewDir;
@ -152,7 +153,8 @@ void inline IInlSetParticlePathStretch( const plParticleCore &particle, const hs
// Note that we could probably slim away a normalize or two, but the actual number // Note that we could probably slim away a normalize or two, but the actual number
// of normalizes we're doing hasn't gone up, I've just moved them up from IInlSetParticlePoints(). // of normalizes we're doing hasn't gone up, I've just moved them up from IInlSetParticlePoints().
hsVector3 viewDir(&particle.fPos, &viewToWorld.GetTranslate()); hsPoint3 xlate = viewToWorld.GetTranslate();
hsVector3 viewDir(&particle.fPos, &xlate);
hsScalar invD = hsFastMath::InvSqrtAppr(viewDir.MagnitudeSquared()); hsScalar invD = hsFastMath::InvSqrtAppr(viewDir.MagnitudeSquared());
viewDir *= invD; viewDir *= invD;
@ -191,7 +193,8 @@ void inline IInlSetParticlePathFlow( const plParticleCore &particle, const hsMat
// difference is that we're going to keep the area of the particle constant, // difference is that we're going to keep the area of the particle constant,
// so the longer it stretches, the narrower it gets orthogonal to the velocity. // so the longer it stretches, the narrower it gets orthogonal to the velocity.
hsVector3 viewDir(&particle.fPos, &viewToWorld.GetTranslate()); hsPoint3 xlate = viewToWorld.GetTranslate();
hsVector3 viewDir(&particle.fPos, &xlate);
hsScalar invD = hsFastMath::InvSqrtAppr(viewDir.MagnitudeSquared()); hsScalar invD = hsFastMath::InvSqrtAppr(viewDir.MagnitudeSquared());
viewDir *= invD; viewDir *= invD;
@ -242,10 +245,12 @@ void inline IInlSetParticleExplicit( const hsMatrix44 &viewToWorld, const plPart
// to calculate the vector from camera to particle and normalize it than // to calculate the vector from camera to particle and normalize it than
// to transform the vector (0,0,-1) (though not as fast as pulling the // to transform the vector (0,0,-1) (though not as fast as pulling the
// camera direction directly from the viewToWorld). // camera direction directly from the viewToWorld).
hsVector3 del(&particle.fPos, &viewToWorld.GetTranslate()); hsPoint3 xlate = viewToWorld.GetTranslate();
hsVector3 del(&particle.fPos, &xlate);
hsFastMath::NormalizeAppr(del); hsFastMath::NormalizeAppr(del);
zVec = del; zVec = del;
yVec.Set(&(viewToWorld * orientation)); hsVector3 tmp = viewToWorld * orientation;
yVec.Set(&tmp);
xVec = yVec % zVec; xVec = yVec % zVec;
#endif // See notes below - mf #endif // See notes below - mf
@ -320,7 +325,8 @@ void inline IInlSetNormalStrongestLight( hsVector3 &partNorm, const plParticleCo
{ {
if( omniLight != nil ) if( omniLight != nil )
{ {
partNorm.Set( &particle.fPos, &omniLight->GetWorldPosition() ); hsPoint3 pos = omniLight->GetWorldPosition();
partNorm.Set( &particle.fPos, &pos );
partNorm = -partNorm; partNorm = -partNorm;
} }
else if( directionLight != nil ) else if( directionLight != nil )

3
Sources/Plasma/PubUtilLib/plDrawable/plSpaceTreeMaker.cpp

@ -551,7 +551,8 @@ plSpaceTree* plSpaceTreeMaker::IMakeEmptyTree()
plSpaceTree* tree = TRACKED_NEW plSpaceTree; plSpaceTree* tree = TRACKED_NEW plSpaceTree;
tree->fTree.SetCount(1); tree->fTree.SetCount(1);
tree->fTree[0].fWorldBounds.Reset(&hsPoint3(0,0,0)); hsPoint3 zero(0, 0, 0);
tree->fTree[0].fWorldBounds.Reset(&zero);
tree->fTree[0].fFlags = plSpaceTreeNode::kEmpty; tree->fTree[0].fFlags = plSpaceTreeNode::kEmpty;
tree->fRoot = 0; tree->fRoot = 0;
tree->fNumLeaves = 0; tree->fNumLeaves = 0;

2
Sources/Plasma/PubUtilLib/plFile/CMakeLists.txt

@ -31,7 +31,7 @@ set(plFile_HEADERS
) )
add_library(plFile STATIC ${plFile_SOURCES} ${plFile_HEADERS}) add_library(plFile STATIC ${plFile_SOURCES} ${plFile_HEADERS})
target_link_libraries(plFile ${ZLIB_LIBRARIES}) target_link_libraries(plFile CoreLib plUnifiedTime ${ZLIB_LIBRARIES})
source_group("Source Files" FILES ${plFile_SOURCES}) source_group("Source Files" FILES ${plFile_SOURCES})
source_group("Header Files" FILES ${plFile_HEADERS}) source_group("Header Files" FILES ${plFile_HEADERS})

1
Sources/Plasma/PubUtilLib/plFile/hsFiles.h

@ -48,7 +48,6 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#if HS_BUILD_FOR_UNIX #if HS_BUILD_FOR_UNIX
#include <limits.h> #include <limits.h>
#define kFolderIterator_MaxPath PATH_MAX #define kFolderIterator_MaxPath PATH_MAX
#include <unistd.h>
#define SetCurrentDirectory chdir #define SetCurrentDirectory chdir
#else #else
#define kFolderIterator_MaxPath _MAX_PATH #define kFolderIterator_MaxPath _MAX_PATH

39
Sources/Plasma/PubUtilLib/plFile/plFileUtils.cpp

@ -103,7 +103,9 @@ hsBool plFileUtils::CreateDir( const wchar *path )
#if HS_BUILD_FOR_WIN32 #if HS_BUILD_FOR_WIN32
return ( _wmkdir( path ) == 0 ) ? true : ( errno==EEXIST ); return ( _wmkdir( path ) == 0 ) ? true : ( errno==EEXIST );
#elif HS_BUILD_FOR_UNIX #elif HS_BUILD_FOR_UNIX
return ( mkdir( path, 0777 ) == 0 ) ? true : ( errno==EEXIST ); const char* cpath = hsWStringToString(path);
CreateDir(cpath);
delete[] cpath; /* Free the string */
#endif #endif
} }
@ -148,9 +150,15 @@ bool plFileUtils::RemoveFile(const char* filename, bool delReadOnly)
bool plFileUtils::RemoveFile(const wchar* filename, bool delReadOnly) bool plFileUtils::RemoveFile(const wchar* filename, bool delReadOnly)
{ {
#ifdef HS_BUILD_FOR_WIN32
if (delReadOnly) if (delReadOnly)
_wchmod(filename, S_IWRITE); _wchmod(filename, S_IWRITE);
return (_wunlink(filename) == 0); return (_wunlink(filename) == 0);
#elif HS_BUILD_FOR_UNIX
const char* cfilename = hsWStringToString(filename);
RemoveFile(cfilename, delReadOnly);
delete[] cfilename; /* Free the string */
#endif
} }
bool plFileUtils::FileCopy(const char* existingFile, const char* newFile) bool plFileUtils::FileCopy(const char* existingFile, const char* newFile)
@ -169,8 +177,12 @@ bool plFileUtils::FileCopy(const wchar* existingFile, const wchar* newFile)
return (::CopyFileW(existingFile, newFile, FALSE) != 0); return (::CopyFileW(existingFile, newFile, FALSE) != 0);
#elif HS_BUILD_FOR_UNIX #elif HS_BUILD_FOR_UNIX
char data[1500]; char data[1500];
FILE* fp = fopen(existingFile, "rb"); const char* cexisting = hsWStringToString(existingFile);
FILE* fw = fopen(newFile, "w"); const char* cnew = hsWStringToString(newFile);
FILE* fp = fopen(cexisting, "rb");
FILE* fw = fopen(cnew, "w");
delete[] cexisting;
delete[] cnew;
int num = 0; int num = 0;
bool retVal = true; bool retVal = true;
if (fp && fw){ if (fp && fw){
@ -427,7 +439,22 @@ void plFileUtils::AddSlash(char* path)
{ {
char lastChar = path[strlen(path)-1]; char lastChar = path[strlen(path)-1];
if (lastChar != '\\' && lastChar != '/') if (lastChar != '\\' && lastChar != '/')
#if HS_BUILD_FOR_WIN32
strcat(path, "\\"); strcat(path, "\\");
#else
strcat(path, "/");
#endif
}
void plFileUtils::AddSlash(wchar* path)
{
wchar lastChar = path[wcslen(path)-1];
if (lastChar != L'\\' && lastChar != L'/')
#if HS_BUILD_FOR_WIN32
wcscat(path, L"\\");
#else
wcscat(path, L"/");
#endif
} }
void plFileUtils::ConcatFileName(char* path, const char* fileName) void plFileUtils::ConcatFileName(char* path, const char* fileName)
@ -436,6 +463,12 @@ void plFileUtils::ConcatFileName(char* path, const char* fileName)
strcat(path, fileName); strcat(path, fileName);
} }
void plFileUtils::ConcatFileName(wchar* path, const wchar* fileName)
{
AddSlash(path);
wcscat(path, fileName);
}
//// GetFileSize ///////////////////////////////////////////////////////////// //// GetFileSize /////////////////////////////////////////////////////////////
UInt32 plFileUtils::GetFileSize( const char *path ) UInt32 plFileUtils::GetFileSize( const char *path )

2
Sources/Plasma/PubUtilLib/plFile/plFileUtils.h

@ -107,9 +107,11 @@ namespace plFileUtils
// Adds a slash to the end of a filename (or does nothing if it's already there) // Adds a slash to the end of a filename (or does nothing if it's already there)
void AddSlash(char* path); void AddSlash(char* path);
void AddSlash(wchar* path);
// Concatenates fileName onto path, making sure to add a slash if necessary // Concatenates fileName onto path, making sure to add a slash if necessary
void ConcatFileName(char* path, const char* fileName); void ConcatFileName(char* path, const char* fileName);
void ConcatFileName(wchar* path, const wchar* fileName);
// searches the parent directory of filename for the encryption key file, and reads it // searches the parent directory of filename for the encryption key file, and reads it
// into the key passed in. Returns false if the key file didn't exist (and sets key to // into the key passed in. Returns false if the key file didn't exist (and sets key to

74
Sources/Plasma/PubUtilLib/plFile/plSecureStream.cpp

@ -46,6 +46,10 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include <time.h> #include <time.h>
#if !HS_BUILD_FOR_WIN32
#define INVALID_HANDLE_VALUE 0
#endif
// our default encryption key // our default encryption key
const UInt32 plSecureStream::kDefaultKey[4] = { 0x6c0a5452, 0x3827d0f, 0x3a170b92, 0x16db7fc2 }; const UInt32 plSecureStream::kDefaultKey[4] = { 0x6c0a5452, 0x3827d0f, 0x3a170b92, 0x16db7fc2 };
@ -143,6 +147,7 @@ hsBool plSecureStream::Open(const wchar* name, const wchar* mode)
{ {
if (wcscmp(mode, L"rb") == 0) if (wcscmp(mode, L"rb") == 0)
{ {
#if HS_BUILD_FOR_WIN32
if (fDeleteOnExit) if (fDeleteOnExit)
{ {
fRef = CreateFileW(name, fRef = CreateFileW(name,
@ -179,6 +184,23 @@ hsBool plSecureStream::Open(const wchar* name, const wchar* mode)
DWORD numBytesRead; DWORD numBytesRead;
ReadFile(fRef, &fActualFileSize, sizeof(UInt32), &numBytesRead, NULL); ReadFile(fRef, &fActualFileSize, sizeof(UInt32), &numBytesRead, NULL);
#elif HS_BUILD_FOR_UNIX
const char* cname = hsWStringToString(name);
fRef = fopen(cname, "rb");
delete[] cname;
fPosition = 0;
if (fRef == INVALID_HANDLE_VALUE)
return false;
if (!ICheckMagicString(fRef))
{
fclose(fRef);
fRef = INVALID_HANDLE_VALUE;
return false;
}
#endif
// The encrypted stream is inefficient if you do reads smaller than // The encrypted stream is inefficient if you do reads smaller than
// 8 bytes. Since we do a lot of those, any file under a size threshold // 8 bytes. Since we do a lot of those, any file under a size threshold
@ -221,7 +243,11 @@ hsBool plSecureStream::Close()
} }
if (fRef != INVALID_HANDLE_VALUE) if (fRef != INVALID_HANDLE_VALUE)
{ {
#if HS_BUILD_FOR_WIN32
rtn = CloseHandle(fRef); rtn = CloseHandle(fRef);
#elif HS_BUILD_FOR_UNIX
rtn = fclose(fRef);
#endif
fRef = INVALID_HANDLE_VALUE; fRef = INVALID_HANDLE_VALUE;
} }
@ -248,8 +274,13 @@ UInt32 plSecureStream::IRead(UInt32 bytes, void* buffer)
{ {
if (fRef == INVALID_HANDLE_VALUE) if (fRef == INVALID_HANDLE_VALUE)
return 0; return 0;
DWORD numItems; UInt32 numItems;
bool success = (ReadFile(fRef, buffer, bytes, &numItems, NULL) != 0); #if HS_BUILD_FOR_WIN32
bool success = (ReadFile(fRef, buffer, bytes, (LPDWORD)&numItems, NULL) != 0);
#elif HS_BUILD_FOR_UNIX
numItems = fread(buffer, bytes, 1, fRef);
bool success = numItems != 0;
#endif
fBytesRead += numItems; fBytesRead += numItems;
fPosition += numItems; fPosition += numItems;
if ((unsigned)numItems < bytes) if ((unsigned)numItems < bytes)
@ -281,7 +312,11 @@ void plSecureStream::IBufferFile()
fRAMStream->Rewind(); fRAMStream->Rewind();
fBufferedStream = true; fBufferedStream = true;
#if HS_BUILD_FOR_WIN32
CloseHandle(fRef); CloseHandle(fRef);
#elif HS_BUILD_FOR_UNIX
fclose(fRef);
#endif
fRef = INVALID_HANDLE_VALUE; fRef = INVALID_HANDLE_VALUE;
fPosition = 0; fPosition = 0;
} }
@ -305,7 +340,11 @@ void plSecureStream::Skip(UInt32 delta)
{ {
fBytesRead += delta; fBytesRead += delta;
fPosition += delta; fPosition += delta;
#if HS_BUILD_FOR_WIN32
SetFilePointer(fRef, delta, 0, FILE_CURRENT); SetFilePointer(fRef, delta, 0, FILE_CURRENT);
#elif HS_BUILD_FOR_UNIX
fseek(fRef, delta, SEEK_CUR);
#endif
} }
} }
@ -320,7 +359,11 @@ void plSecureStream::Rewind()
{ {
fBytesRead = 0; fBytesRead = 0;
fPosition = 0; fPosition = 0;
#if HS_BUILD_FOR_WIN32
SetFilePointer(fRef, kFileStartOffset, 0, FILE_BEGIN); SetFilePointer(fRef, kFileStartOffset, 0, FILE_BEGIN);
#elif HS_BUILD_FOR_UNIX
fseek(fRef, kFileStartOffset, SEEK_SET);
#endif
} }
} }
@ -333,7 +376,11 @@ void plSecureStream::FastFwd()
} }
else if (fRef != INVALID_HANDLE_VALUE) else if (fRef != INVALID_HANDLE_VALUE)
{ {
#if HS_BUILD_FOR_WIN32
fBytesRead = fPosition = SetFilePointer(fRef, kFileStartOffset + fActualFileSize, 0, FILE_BEGIN); fBytesRead = fPosition = SetFilePointer(fRef, kFileStartOffset + fActualFileSize, 0, FILE_BEGIN);
#elif HS_BUILD_FOR_UNIX
fBytesRead = fPosition = fseek(fRef, 0, SEEK_END);
#endif
} }
} }
@ -551,11 +598,15 @@ bool plSecureStream::FileDecrypt(const wchar* fileName, UInt32* key /* = nil */)
return true; return true;
} }
bool plSecureStream::ICheckMagicString(HANDLE fp) bool plSecureStream::ICheckMagicString(hsFD fp)
{ {
char magicString[kMagicStringLen+1]; char magicString[kMagicStringLen+1];
DWORD numBytesRead; #ifdef HS_BUILD_FOR_WIN32
ReadFile(fp, &magicString, kMagicStringLen, &numBytesRead, NULL); DWORD numread;
ReadFile(fp, &magicString, kMagicStringLen, &numread, NULL);
#elif HS_BUILD_FOR_UNIX
fread(&magicString, kMagicStringLen, 1, fp);
#endif
magicString[kMagicStringLen] = '\0'; magicString[kMagicStringLen] = '\0';
return (hsStrEQ(magicString, kMagicString) != 0); return (hsStrEQ(magicString, kMagicString) != 0);
} }
@ -570,7 +621,9 @@ bool plSecureStream::IsSecureFile(const char* fileName)
bool plSecureStream::IsSecureFile(const wchar* fileName) bool plSecureStream::IsSecureFile(const wchar* fileName)
{ {
HANDLE fp = INVALID_HANDLE_VALUE; hsFD fp = INVALID_HANDLE_VALUE;
#if HS_BUILD_FOR_WIN32
fp = CreateFileW(fileName, fp = CreateFileW(fileName,
GENERIC_READ, // open for reading GENERIC_READ, // open for reading
0, // no one can open the file until we're done 0, // no one can open the file until we're done
@ -578,13 +631,22 @@ bool plSecureStream::IsSecureFile(const wchar* fileName)
OPEN_EXISTING, // only open existing files (no creation) OPEN_EXISTING, // only open existing files (no creation)
FILE_ATTRIBUTE_NORMAL, // normal file attributes FILE_ATTRIBUTE_NORMAL, // normal file attributes
NULL); // no template NULL); // no template
#elif HS_BUILD_FOR_UNIX
const char* cfile = hsWStringToString(fileName);
fp = fopen(cfile, "rb");
delete[] cfile;
#endif
if (fp == INVALID_HANDLE_VALUE) if (fp == INVALID_HANDLE_VALUE)
return false; return false;
bool isEncrypted = ICheckMagicString(fp); bool isEncrypted = ICheckMagicString(fp);
#if HS_BUILD_FOR_WIN32
CloseHandle(fp); CloseHandle(fp);
#elif HS_BUILD_FOR_UNIX
fclose(fp);
#endif
return isEncrypted; return isEncrypted;
} }

10
Sources/Plasma/PubUtilLib/plFile/plSecureStream.h

@ -43,7 +43,13 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#define plSecureStream_h_inc #define plSecureStream_h_inc
#include "hsStream.h" #include "hsStream.h"
#if HS_BUILD_FOR_WIN32
# include <windows.h> # include <windows.h>
# define hsFD HANDLE
#else
# define hsFD FILE*
#endif
// A slightly more secure stream then plEncryptedStream in that it uses windows file functions // A slightly more secure stream then plEncryptedStream in that it uses windows file functions
// to prevent other processes from accessing the file it is working with. It also can be set // to prevent other processes from accessing the file it is working with. It also can be set
@ -53,7 +59,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
class plSecureStream: public hsStream class plSecureStream: public hsStream
{ {
protected: protected:
HANDLE fRef; hsFD fRef;
UInt32 fKey[4]; UInt32 fKey[4];
UInt32 fActualFileSize; UInt32 fActualFileSize;
@ -78,7 +84,7 @@ protected:
bool IWriteEncrypted(hsStream* sourceStream, const wchar* outputFile); bool IWriteEncrypted(hsStream* sourceStream, const wchar* outputFile);
static bool ICheckMagicString(HANDLE fp); static bool ICheckMagicString(hsFD fp);
public: public:
plSecureStream(hsBool deleteOnExit = false, UInt32* key = nil); // uses default key if you don't pass one in plSecureStream(hsBool deleteOnExit = false, UInt32* key = nil); // uses default key if you don't pass one in

4
Sources/Plasma/PubUtilLib/plFile/plStreamSource.cpp

@ -46,6 +46,10 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "plEncryptedStream.h" #include "plEncryptedStream.h"
#include "plFileUtils.h" #include "plFileUtils.h"
#if HS_BUILD_FOR_UNIX
# include <wctype.h>
#endif
void ToLower(std::wstring& str) void ToLower(std::wstring& str)
{ {
for (unsigned i = 0; i < str.length(); i++) for (unsigned i = 0; i < str.length(); i++)

2
Sources/Plasma/PubUtilLib/plInputCore/CMakeLists.txt

@ -3,7 +3,9 @@ include_directories("../../NucleusLib/inc")
include_directories("../../NucleusLib") include_directories("../../NucleusLib")
include_directories("../../PubUtilLib") include_directories("../../PubUtilLib")
if(WIN32)
include_directories(${DirectX_INCLUDE_DIR}) include_directories(${DirectX_INCLUDE_DIR})
endif(WIN32)
include_directories(${OPENAL_INCLUDE_DIR}) include_directories(${OPENAL_INCLUDE_DIR})
set(plInputCore_SOURCES set(plInputCore_SOURCES

2
Sources/Plasma/PubUtilLib/plInputCore/plInputManager.h

@ -44,7 +44,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#ifndef PL_INPUT_MANAGER_H #ifndef PL_INPUT_MANAGER_H
#define PL_INPUT_MANAGER_H #define PL_INPUT_MANAGER_H
#include <windows.h> #include "hsWindows.h"
#include "hsTypes.h" #include "hsTypes.h"
#include "hsTemplates.h" #include "hsTemplates.h"
#include "pnKeyedObject/hsKeyedObject.h" #include "pnKeyedObject/hsKeyedObject.h"

5
Sources/Plasma/PubUtilLib/plInterp/plAnimPath.cpp

@ -120,7 +120,10 @@ void plAnimPath::SetCurTime(hsScalar t, UInt32 calcFlags)
fVel.Set(pos+1, pos+0); fVel.Set(pos+1, pos+0);
fVel *= kInvSmallDelTime; fVel *= kInvSmallDelTime;
fVel = fLocalToWorld * fVel; fVel = fLocalToWorld * fVel;
fAccel.Set(&(pos[2] - pos[1]), &(pos[1] - pos[0]));
hsPoint3 first = pos[2] - pos[1];
hsPoint3 second = pos[1] - pos[0];
fAccel.Set(&first, &second);
fAccel *= kInvSmallDelTime * kInvSmallDelTime; fAccel *= kInvSmallDelTime * kInvSmallDelTime;
fAccel = fLocalToWorld * fAccel; fAccel = fLocalToWorld * fAccel;
} }

1
Sources/Plasma/PubUtilLib/plMessage/plAgeLoadedMsg.h

@ -42,7 +42,6 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#ifndef plAgeLoadedMsg_INC #ifndef plAgeLoadedMsg_INC
#define plAgeLoadedMsg_INC #define plAgeLoadedMsg_INC
#include "pnUtils/pnUtils.h"
#include "pnMessage/plMessage.h" #include "pnMessage/plMessage.h"
// //

8
Sources/Plasma/PubUtilLib/plMessage/plInputIfaceMgrMsg.h

@ -52,7 +52,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "hsStream.h" #include "hsStream.h"
#include "hsResMgr.h" #include "hsResMgr.h"
#include "pnMessage/plMessage.h" #include "pnMessage/plMessage.h"
#include "pnUtils/pnUtils.h" #include "pnUUID/pnUUID.h"
class plInputInterface; class plInputInterface;
class plInputIfaceMgrMsg : public plMessage class plInputIfaceMgrMsg : public plMessage
@ -65,7 +65,7 @@ class plInputIfaceMgrMsg : public plMessage
const char* ageName; const char* ageName;
const char* ageFileName; const char* ageFileName;
const char* spawnPoint; const char* spawnPoint;
Uuid ageInstanceGuid; plUUID ageInstanceGuid;
plKey fAvKey; plKey fAvKey;
public: public:
@ -125,8 +125,8 @@ class plInputIfaceMgrMsg : public plMessage
const char* GetAgeFileName() { return ageFileName; } const char* GetAgeFileName() { return ageFileName; }
void SetSpawnPoint(const char* s) { spawnPoint = s; } void SetSpawnPoint(const char* s) { spawnPoint = s; }
const char* GetSpawnPoint() { return spawnPoint; } const char* GetSpawnPoint() { return spawnPoint; }
void SetAgeInstanceGuid(const Uuid& guid) { ageInstanceGuid = guid; } void SetAgeInstanceGuid(const plUUID& guid) { ageInstanceGuid = guid; }
const Uuid& GetAgeInstanceGuid() { return ageInstanceGuid; } const plUUID& GetAgeInstanceGuid() { return ageInstanceGuid; }
UInt8 GetCommand( void ) { return fCommand; } UInt8 GetCommand( void ) { return fCommand; }
UInt32 GetPageID( void ) { return fPageID; } UInt32 GetPageID( void ) { return fPageID; }
void SetIFace( plInputInterface *iface ); void SetIFace( plInputInterface *iface );

2
Sources/Plasma/PubUtilLib/plMessage/plLoadAgeMsg.h

@ -43,7 +43,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#define plLoadAgeMsg_INC #define plLoadAgeMsg_INC
#include "pnMessage/plMessage.h" #include "pnMessage/plMessage.h"
#include "plUUID/plUUID.h" #include "pnUUID/pnUUID.h"
#include "hsUtils.h" #include "hsUtils.h"
// //

2
Sources/Plasma/PubUtilLib/plNetCommon/plClientGuid.h

@ -45,7 +45,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "hsConfig.h" #include "hsConfig.h"
#include "hsStlUtils.h" #include "hsStlUtils.h"
#include "pnFactory/plCreatable.h" #include "pnFactory/plCreatable.h"
#include "plUUID/plUUID.h" #include "pnUUID/pnUUID.h"
class plClientGuid : public plCreatable class plClientGuid : public plCreatable
{ {

2
Sources/Plasma/PubUtilLib/plNetCommon/plNetCommon.cpp

@ -41,7 +41,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
*==LICENSE==*/ *==LICENSE==*/
#include "plNetCommon.h" #include "plNetCommon.h"
#include "hsStlUtils.h" #include "hsStlUtils.h"
#include "plUUID/plUUID.h" #include "pnUUID/pnUUID.h"
#include <algorithm> #include <algorithm>
namespace plNetCommon namespace plNetCommon

4
Sources/Plasma/PubUtilLib/plNetCommon/plNetCommonCreatable.h

@ -55,10 +55,6 @@ REGISTER_CREATABLE( plNetCoreStatsSummary );
#endif // SERVER #endif // SERVER
REGISTER_CREATABLE( plCreatableListHelper ); REGISTER_CREATABLE( plCreatableListHelper );
// HACK: plUUID should have it's own creatable include
#include "../plUUID/plUUID.h"
REGISTER_CREATABLE( plCreatableUuid );
#include "plClientGuid.h" #include "plClientGuid.h"
REGISTER_CREATABLE( plClientGuid ); REGISTER_CREATABLE( plClientGuid );
#include "plNetServerSessionInfo.h" #include "plNetServerSessionInfo.h"

2
Sources/Plasma/PubUtilLib/plNetCommon/plNetServerSessionInfo.h

@ -47,7 +47,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
#include "pnFactory/plCreatable.h" #include "pnFactory/plCreatable.h"
#include "pnNetCommon/plNetServers.h" #include "pnNetCommon/plNetServers.h"
#include "plNetCommon/plSpawnPointInfo.h" #include "plNetCommon/plSpawnPointInfo.h"
#include "plUUID/plUUID.h" #include "pnUUID/pnUUID.h"
class hsStream; class hsStream;

3
Sources/Plasma/PubUtilLib/plParticleSystem/plConvexVolume.cpp

@ -104,7 +104,8 @@ void plConvexVolume::Update(const hsMatrix44 &l2w)
{ {
// Since fN is an hsVector3, it will only apply the rotational aspect of the transform... // Since fN is an hsVector3, it will only apply the rotational aspect of the transform...
fWorldPlanes[i].fN = l2w * fLocalPlanes[i].fN; fWorldPlanes[i].fN = l2w * fLocalPlanes[i].fN;
planePt.Set(&(fLocalPlanes[i].fN * fLocalPlanes[i].fD)); hsVector3 tmp = fLocalPlanes[i].fN * fLocalPlanes[i].fD;
planePt.Set(&tmp);
fWorldPlanes[i].fD = -(l2w * planePt).InnerProduct(fWorldPlanes[i].fN); fWorldPlanes[i].fD = -(l2w * planePt).InnerProduct(fWorldPlanes[i].fN);
} }
} }

3
Sources/Plasma/PubUtilLib/plParticleSystem/plParticleEffect.cpp

@ -759,7 +759,8 @@ hsBool plParticleFlockEffect::ApplyEffect(const plEffectTargetInfo& target, Int3
goal = fDissenterTarget; goal = fDissenterTarget;
hsVector3 goalDir; hsVector3 goalDir;
goalDir.Set(&(goal - pos)); hsPoint3 tmp = goal - pos;
goalDir.Set(&tmp);
hsScalar distSq = goalDir.MagnitudeSquared(); hsScalar distSq = goalDir.MagnitudeSquared();
goalDir.Normalize(); goalDir.Normalize();

6
Sources/Plasma/PubUtilLib/plParticleSystem/plParticleEmitter.cpp

@ -410,7 +410,11 @@ void plParticleEmitter::IUpdateParticles(hsScalar delta)
// This is the only orientation option (so far) that requires an update here // This is the only orientation option (so far) that requires an update here
if (fMiscFlags & (kOrientationVelocityBased | kOrientationVelocityStretch | kOrientationVelocityFlow)) if (fMiscFlags & (kOrientationVelocityBased | kOrientationVelocityStretch | kOrientationVelocityFlow))
fParticleCores[i].fOrientation.Set(&(*currVelocity * delta)); // mf - want the orientation to be a delposition {
// mf - want the orientation to be a delposition
hsVector3 tmp = *currVelocity * delta;
fParticleCores[i].fOrientation.Set(&tmp);
}
else if( fParticleExts[i].fRadsPerSec != 0 ) else if( fParticleExts[i].fRadsPerSec != 0 )
{ {
hsScalar sinX, cosX; hsScalar sinX, cosX;

3
Sources/Plasma/PubUtilLib/plParticleSystem/plParticleGenerator.cpp

@ -216,7 +216,8 @@ hsBool plSimpleParticleGenerator::AddAutoParticles(plParticleEmitter *emitter, f
if( fPartRadsPerSecRange > 0 ) if( fPartRadsPerSecRange > 0 )
radsPerSec = fPartRadsPerSecRange * sRandom.RandMinusOneToOne(); radsPerSec = fPartRadsPerSecRange * sRandom.RandMinusOneToOne();
emitter->AddParticle(currStart, initDirection * initVelocity, tile, fXSize, fYSize, currSizeVar, hsVector3 tmp = initDirection * initVelocity;
emitter->AddParticle(currStart, tmp, tile, fXSize, fYSize, currSizeVar,
invMass, initLife, orientation, miscFlags, radsPerSec); invMass, initLife, orientation, miscFlags, radsPerSec);
} }

2
Sources/Plasma/PubUtilLib/plPhysical/plCollisionDetector.h

@ -93,7 +93,7 @@ class plObjectInVolumeDetector : public plCollisionDetector
public: public:
class plCollisionBookKeepingInfo class plCollisionBookKeepingInfo
{ {
friend plObjectInVolumeDetector; friend class plObjectInVolumeDetector;
public: public:
plCollisionBookKeepingInfo(plKey& hit) plCollisionBookKeepingInfo(plKey& hit)
{ {

2
Sources/Plasma/PubUtilLib/plPipeline/CMakeLists.txt

@ -7,7 +7,9 @@ include_directories("../../PubUtilLib")
if(Bink_SDK_AVAILABLE) if(Bink_SDK_AVAILABLE)
include_directories(${Bink_INCLUDE_DIR}) include_directories(${Bink_INCLUDE_DIR})
endif() endif()
if(WIN32)
include_directories(${DirectX_INCLUDE_DIR}) include_directories(${DirectX_INCLUDE_DIR})
endif(WIN32)
set(plPipeline_SOURCES set(plPipeline_SOURCES
hsG3DDeviceSelector.cpp hsG3DDeviceSelector.cpp

2
Sources/Plasma/PubUtilLib/plPipeline/hsG3DDeviceSelector.h

@ -448,7 +448,7 @@ public:
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
#include <stdio.h> #include <stdio.h>
#include "headspin.h" #include "HeadSpin.h"
class plDemoDebugFile class plDemoDebugFile
{ {

4
Sources/Plasma/PubUtilLib/plProgressMgr/plProgressMgr.cpp

@ -70,7 +70,7 @@ plProgressMgr *plProgressMgr::fManager = nil;
char* plProgressMgr::fImageRotation[LOADING_RES_COUNT]; char* plProgressMgr::fImageRotation[LOADING_RES_COUNT];
char* plProgressMgr::fStaticTextIDs[] = { const char* plProgressMgr::fStaticTextIDs[] = {
"xLoading_Linking_Text.png", "xLoading_Linking_Text.png",
"xLoading_Updating_Text.png" "xLoading_Updating_Text.png"
}; };
@ -249,7 +249,7 @@ char* plProgressMgr::GetLoadingFrameID(int index)
return fImageRotation[0]; return fImageRotation[0];
} }
char* plProgressMgr::GetStaticTextID(StaticText staticTextType) const char* plProgressMgr::GetStaticTextID(StaticText staticTextType)
{ {
return fStaticTextIDs[staticTextType]; return fStaticTextIDs[staticTextType];
} }

4
Sources/Plasma/PubUtilLib/plProgressMgr/plProgressMgr.h

@ -197,7 +197,7 @@ class plProgressMgr
static plProgressMgr *fManager; static plProgressMgr *fManager;
static char* fImageRotation[]; static char* fImageRotation[];
static char* fStaticTextIDs[]; static const char* fStaticTextIDs[];
protected: protected:
@ -230,7 +230,7 @@ class plProgressMgr
static plProgressMgr* GetInstance() { return fManager; } static plProgressMgr* GetInstance() { return fManager; }
static char* GetLoadingFrameID(int index); static char* GetLoadingFrameID(int index);
static char* GetStaticTextID(StaticText staticTextType); static const char* GetStaticTextID(StaticText staticTextType);
virtual void Draw( plPipeline *p ) { } virtual void Draw( plPipeline *p ) { }

1
Sources/Plasma/PubUtilLib/plResMgr/CMakeLists.txt

@ -34,6 +34,7 @@ set(plResMgr_HEADERS
) )
add_library(plResMgr STATIC ${plResMgr_SOURCES} ${plResMgr_HEADERS}) add_library(plResMgr STATIC ${plResMgr_SOURCES} ${plResMgr_HEADERS})
target_link_libraries(plResMgr CoreLib pnDispatch pnFactory pnKeyedObject pnMessage pnTimer plFile plStatusLog)
source_group("Source Files" FILES ${plResMgr_SOURCES}) source_group("Source Files" FILES ${plResMgr_SOURCES})
source_group("Header Files" FILES ${plResMgr_HEADERS}) source_group("Header Files" FILES ${plResMgr_HEADERS})

4
Sources/Plasma/PubUtilLib/plSDL/plSDL.h

@ -516,8 +516,8 @@ private:
plVarDescriptor*& curVar) const; plVarDescriptor*& curVar) const;
bool IParseStateDesc(const char* fileName, hsStream* stream, char token[], plStateDescriptor*& curDesc) const; bool IParseStateDesc(const char* fileName, hsStream* stream, char token[], plStateDescriptor*& curDesc) const;
void DebugMsg(char* fmt, ...) const; void DebugMsg(const char* fmt, ...) const;
void DebugMsgV(char* fmt, va_list args) const; void DebugMsgV(const char* fmt, va_list args) const;
public: public:

4
Sources/Plasma/PubUtilLib/plSDL/plSDLParser.cpp

@ -49,7 +49,7 @@ You can contact Cyan Worlds, Inc. by email legal@cyan.com
static const int kTokenLen=256; static const int kTokenLen=256;
void plSDLParser::DebugMsg(char* fmt, ...) const void plSDLParser::DebugMsg(const char* fmt, ...) const
{ {
return; return;
plNetApp* netApp = plSDLMgr::GetInstance()->GetNetApp(); plNetApp* netApp = plSDLMgr::GetInstance()->GetNetApp();
@ -66,7 +66,7 @@ void plSDLParser::DebugMsg(char* fmt, ...) const
va_end(args); va_end(args);
} }
void plSDLParser::DebugMsgV(char* fmt, va_list args) const void plSDLParser::DebugMsgV(const char* fmt, va_list args) const
{ {
if (strlen(fmt)==nil) if (strlen(fmt)==nil)
return; return;

3
Sources/Plasma/PubUtilLib/plScene/plSceneNode.cpp

@ -185,7 +185,8 @@ plSpaceTree* plSceneNode::IBuildSpaceTree()
maker.Reset(); maker.Reset();
hsBounds3Ext bnd; hsBounds3Ext bnd;
bnd.Reset(&hsPoint3(0,0,0)); hsPoint3 zero(0, 0, 0);
bnd.Reset(&zero);
int i; int i;
for( i = 0; i < fDrawPool.GetCount(); i++ ) for( i = 0; i < fDrawPool.GetCount(); i++ )

1
Sources/Plasma/PubUtilLib/plStatusLog/CMakeLists.txt

@ -16,6 +16,7 @@ set(plStatusLog_HEADERS
) )
add_library(plStatusLog STATIC ${plStatusLog_SOURCES} ${plStatusLog_HEADERS}) add_library(plStatusLog STATIC ${plStatusLog_SOURCES} ${plStatusLog_HEADERS})
target_link_libraries(plStatusLog CoreLib plFile plUnifiedTime)
source_group("Source Files" FILES ${plStatusLog_SOURCES}) source_group("Source Files" FILES ${plStatusLog_SOURCES})
source_group("Header Files" FILES ${plStatusLog_HEADERS}) source_group("Header Files" FILES ${plStatusLog_HEADERS})

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save