mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
e22080db3a
Animations accessible. Pass map of animation names and phases and pass a vector of the lods you want to animate. Dynamic loading humbuggery. Added: A3->Extension animation state sync framework done. Test cases for animations created. Apply animation phases from game to test case render. Continuing finalization. rotation_offset was reversed for zero_distance, thats fixed but still off. Rendering test hard-coded for container LOD temporarily. Rotation translation corrected. Removed: Scale flipping, these should work now but they dont. Debug logging, debug model. Correct parameters to extension. Stability fixes. Animations nearly aligning correctly. scale, rotation and translation work; still not working. Back compat for v60 p3d's fully implemented. Add vehicle ID to animation state send. cmake bullet integration from submodule. WINVER forced for all builds. More bullet + windows + cmake fun. Remove LinaerMath. Testing for nou. typo Fixed: Pathing bug. Vehicle damage working set for Nou.
77 lines
2.0 KiB
C++
77 lines
2.0 KiB
C++
#pragma once
|
|
|
|
#include "targetver.h"
|
|
#include <assert.h>
|
|
#include <stdio.h>
|
|
#include <string>
|
|
#include <vector>
|
|
#include <list>
|
|
#include <map>
|
|
#include <unordered_map>
|
|
#include <memory>
|
|
#include <cmath>
|
|
#include <cstdint>
|
|
#include <streambuf>
|
|
#include "ace_version.hpp"
|
|
#include "logging.hpp"
|
|
|
|
#ifdef _DEBUG
|
|
#define ZERO_OUTPUT() { memset(output, 0x00, outputSize); }
|
|
#define EXTENSION_RETURN() {output[outputSize-1] = 0x00; } return;
|
|
#else
|
|
#define ZERO_OUTPUT()
|
|
#define EXTENSION_RETURN() return;
|
|
#endif
|
|
|
|
#ifdef _WINDOWS
|
|
#define sleep(x) Sleep(x)
|
|
#endif
|
|
|
|
namespace ace {
|
|
template< typename T >
|
|
struct array_deleter
|
|
{
|
|
void operator ()(T const * p)
|
|
{
|
|
delete[] p;
|
|
}
|
|
};
|
|
|
|
std::vector<std::string> &split(const std::string &s, char delim, std::vector<std::string> &elems);
|
|
std::vector<std::string> split(const std::string &s, char delim);
|
|
|
|
// trim from start
|
|
static inline std::string <rim(std::string &s) {
|
|
s.erase(s.begin(), std::find_if(s.begin(), s.end(), std::not1(std::ptr_fun<int, int>(std::isspace))));
|
|
return s;
|
|
}
|
|
|
|
// trim from end
|
|
static inline std::string &rtrim(std::string &s) {
|
|
s.erase(std::find_if(s.rbegin(), s.rend(), std::not1(std::ptr_fun<int, int>(std::isspace))).base(), s.end());
|
|
return s;
|
|
}
|
|
|
|
// trim from both ends
|
|
static inline std::string &trim(std::string &s) {
|
|
return ltrim(rtrim(s));
|
|
}
|
|
|
|
inline void runtime_assert(bool result);
|
|
|
|
struct exception {
|
|
exception(const uint32_t code_, const std::string & text_) : code(code_), text(text_) {}
|
|
|
|
exception & operator= (const exception& other) { code = other.code; text = other.text; return *this; }
|
|
bool operator == (const exception &r) const { return ( code == r.code ); }
|
|
|
|
uint32_t code;
|
|
std::string text;
|
|
};
|
|
}
|
|
|
|
#ifdef _DEBUG
|
|
#define ACE_ASSERT assert()
|
|
#else
|
|
#define ACE_ASSERT ace::runtime_assert()
|
|
#endif |