mirror of
https://github.com/yuzu-emu/FasTC.git
synced 2025-01-23 19:51:19 +00:00
Fix a bunch of MSVC compiler warnings and errors.
Most notably, we need to actually fix a bug in MSVC that doesn't know how to properly instantiate enums in partial template specialization. There are more details outlined here: http://stackoverflow.com/questions/15466594/why-does-msvc-fail-to-compile-this-template-function The fix in this commit closes #10 Also in this commit is a hacky way to allow GL defines. Apparently "LoadImage" is defined as a macro even with WIN32_LEAN_AND_MEAN. This means that we have to #undef the code that includes it, meaning that we also need to make sure not to actually mix GLDefines.h with any file that needs to use the functions from Windows.h
This commit is contained in:
parent
0eae5548a3
commit
479ba8e76d
|
@ -73,7 +73,7 @@ namespace FasTC {
|
||||||
// principal eigenvector. However, that may be due to
|
// principal eigenvector. However, that may be due to
|
||||||
// poor initialization of the random vector, so rerandomize
|
// poor initialization of the random vector, so rerandomize
|
||||||
// and try again.
|
// and try again.
|
||||||
const float newBlen = newB.Length();
|
const T newBlen = newB.Length();
|
||||||
if(newBlen < 1e-10) {
|
if(newBlen < 1e-10) {
|
||||||
if(badEigenValue) {
|
if(badEigenValue) {
|
||||||
eigVec = b;
|
eigVec = b;
|
||||||
|
|
|
@ -183,9 +183,10 @@ namespace FasTC {
|
||||||
return a;
|
return a;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// !WTF! MSVC bug with enums in template parameters =(
|
||||||
template<
|
template<
|
||||||
EVectorType kVectorTypeOne,
|
/* EVectorType */unsigned kVectorTypeOne,
|
||||||
EVectorType kVectorTypeTwo,
|
/* EVectorType */unsigned kVectorTypeTwo,
|
||||||
typename TypeOne,
|
typename TypeOne,
|
||||||
typename TypeTwo>
|
typename TypeTwo>
|
||||||
class MultSwitch {
|
class MultSwitch {
|
||||||
|
|
|
@ -53,7 +53,7 @@
|
||||||
#include "gtest/gtest.h"
|
#include "gtest/gtest.h"
|
||||||
#include "MatrixBase.h"
|
#include "MatrixBase.h"
|
||||||
|
|
||||||
static const float kEpsilon = 1e-6;
|
static const float kEpsilon = 1e-6f;
|
||||||
|
|
||||||
TEST(MatrixBase, Constructors) {
|
TEST(MatrixBase, Constructors) {
|
||||||
FasTC::MatrixBase<float, 3, 4> m3f;
|
FasTC::MatrixBase<float, 3, 4> m3f;
|
||||||
|
@ -123,7 +123,7 @@ TEST(MatrixBase, PointerConversion) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(MatrixBase, CastVector) {
|
TEST(MatrixBase, CastVector) {
|
||||||
srand(time(NULL));
|
srand(static_cast<unsigned>(time(NULL)));
|
||||||
|
|
||||||
FasTC::MatrixBase<float, 3, 2> v3f;
|
FasTC::MatrixBase<float, 3, 2> v3f;
|
||||||
for(int i = 0; i < 6; i++) {
|
for(int i = 0; i < 6; i++) {
|
||||||
|
|
|
@ -53,7 +53,7 @@
|
||||||
#include "gtest/gtest.h"
|
#include "gtest/gtest.h"
|
||||||
#include "VectorBase.h"
|
#include "VectorBase.h"
|
||||||
|
|
||||||
static const float kEpsilon = 1e-6;
|
static const float kEpsilon = 1e-6f;
|
||||||
|
|
||||||
TEST(VectorBase, Constructors) {
|
TEST(VectorBase, Constructors) {
|
||||||
FasTC::VectorBase<float, 3> v3f;
|
FasTC::VectorBase<float, 3> v3f;
|
||||||
|
@ -173,7 +173,7 @@ TEST(VectorBase, Normalization) {
|
||||||
EXPECT_EQ(v2u[0], 1);
|
EXPECT_EQ(v2u[0], 1);
|
||||||
EXPECT_EQ(v2u[1], 1);
|
EXPECT_EQ(v2u[1], 1);
|
||||||
|
|
||||||
const float sqrt2 = sqrt(2)/2.0f;
|
const double sqrt2 = sqrt(2)/2.0f;
|
||||||
for(int i = 2; i < 10; i++) {
|
for(int i = 2; i < 10; i++) {
|
||||||
v2f[0] = static_cast<float>(i);
|
v2f[0] = static_cast<float>(i);
|
||||||
v2f[1] = static_cast<float>(i);
|
v2f[1] = static_cast<float>(i);
|
||||||
|
|
|
@ -59,12 +59,7 @@
|
||||||
#include "TexComp.h"
|
#include "TexComp.h"
|
||||||
#include "ThreadSafeStreambuf.h"
|
#include "ThreadSafeStreambuf.h"
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
int _tmain(int argc, _TCHAR* argv[]) {
|
|
||||||
#else
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
#endif
|
|
||||||
|
|
||||||
if(argc != 3) {
|
if(argc != 3) {
|
||||||
fprintf(stderr, "Usage: compare <img1> <img2>\n");
|
fprintf(stderr, "Usage: compare <img1> <img2>\n");
|
||||||
return 1;
|
return 1;
|
||||||
|
|
|
@ -57,6 +57,11 @@
|
||||||
# ifdef __APPLE__
|
# ifdef __APPLE__
|
||||||
# include <OpenGL/gl.h>
|
# include <OpenGL/gl.h>
|
||||||
# else
|
# else
|
||||||
|
# ifdef _MSC_VER
|
||||||
|
# define WIN32_LEAN_AND_MEAN
|
||||||
|
# include "Windows.h"
|
||||||
|
# undef LoadImage
|
||||||
|
# endif
|
||||||
# include <GL/gl.h>
|
# include <GL/gl.h>
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue