aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohan Jansen <jnsn.johan@gmail.com>2015-03-17 13:58:03 +0100
committerJohan Jansen <jnsn.johan@gmail.com>2015-03-17 13:58:03 +0100
commit008a36003f4bf3ca031bd4473597a4892727dba2 (patch)
tree44983d80c87833d1cdde96f9663a1534da8fa947
parent0be253003725b86a559795be78011aae6f2e41c7 (diff)
downloadpx4-firmware-008a36003f4bf3ca031bd4473597a4892727dba2.tar.gz
px4-firmware-008a36003f4bf3ca031bd4473597a4892727dba2.tar.bz2
px4-firmware-008a36003f4bf3ca031bd4473597a4892727dba2.zip
Eigen: Add general purpose Eigen compatability header for PX4
-rw-r--r--src/lib/px4_eigen.h51
-rw-r--r--src/systemcmds/tests/test_eigen.cpp12
2 files changed, 52 insertions, 11 deletions
diff --git a/src/lib/px4_eigen.h b/src/lib/px4_eigen.h
new file mode 100644
index 000000000..2cd98e59a
--- /dev/null
+++ b/src/lib/px4_eigen.h
@@ -0,0 +1,51 @@
+/****************************************************************************
+ *
+ * Copyright (c) 2013-2015 PX4 Development Team. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in
+ * the documentation and/or other materials provided with the
+ * distribution.
+ * 3. Neither the name PX4 nor the names of its contributors may be
+ * used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ *
+ ****************************************************************************/
+
+/**
+ * @file px4_eigen.h
+ *
+ * Compatability header to make Eigen compile on the PX4 stack
+ * @author Johan Jansen <jnsn.johan@gmail.com>
+ */
+
+#pragma once
+
+#pragma GCC diagnostic push
+#define RAND_MAX __RAND_MAX
+#pragma GCC diagnostic ignored "-Wshadow"
+#pragma GCC diagnostic ignored "-Wfloat-equal"
+#define _GLIBCXX_USE_C99_FP_MACROS_DYNAMIC 1
+
+#include <eigen/Eigen/Core>
+#include <eigen/Eigen/Geometry>
+#pragma GCC diagnostic pop
diff --git a/src/systemcmds/tests/test_eigen.cpp b/src/systemcmds/tests/test_eigen.cpp
index 0c9ee810a..ed04d39a1 100644
--- a/src/systemcmds/tests/test_eigen.cpp
+++ b/src/systemcmds/tests/test_eigen.cpp
@@ -38,17 +38,7 @@
* @author Johan Jansen <jnsn.johan@gmail.com>
*/
-//Hacks to make Eigen compile on NuttX
-#pragma GCC diagnostic push
-#define RAND_MAX __RAND_MAX
-#pragma GCC diagnostic ignored "-Wshadow"
-#pragma GCC diagnostic ignored "-Wfloat-equal"
-#define _GLIBCXX_USE_C99_FP_MACROS_DYNAMIC 1
-
-#include <eigen/Eigen/Core>
-#include <eigen/Eigen/Geometry>
-#pragma GCC diagnostic pop
-
+#include <px4_eigen.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>