/**************************************************************************************************** RepRapFirmware - Main Include This includes all the other include files in the right order and defines some globals. No other definitions or information should be in here. ----------------------------------------------------------------------------------------------------- Version 0.1 18 November 2012 Adrian Bowyer RepRap Professional Ltd http://reprappro.com Licence: GPL ****************************************************************************************************/ #ifndef REPRAPFIRMWARE_H #define REPRAPFIRMWARE_H #include // for size_t #include #include // Module numbers, used for diagnostics and debug enum Module { modulePlatform = 0, moduleNetwork = 1, moduleWebserver = 2, moduleGcodes = 3, moduleMove = 4, moduleHeat = 5, moduleDda = 6, noModule = 15 }; extern const char *moduleName[]; // Warn of what's to come, so we can use pointers to classes... class Network; class Platform; class Webserver; class GCodes; class Move; class Heat; class Tool; class RepRap; class FileStore; // A single instance of the RepRap class contains all the others extern RepRap reprap; // Functions and globals not part of any class const size_t MaxFilenameLength = 100; // maximum length of a path + filename on the SD card extern "C" void debugPrintf(const char* fmt, ...); bool StringEndsWith(const char* string, const char* ending); bool StringStartsWith(const char* string, const char* starting); bool StringEquals(const char* s1, const char* s2); int StringContains(const char* string, const char* match); // Macro to give us the number of elements in an array #define ARRAY_SIZE(_x) (sizeof(_x)/sizeof(_x[0])) // Macro to give us the highest valid index into an array i.e. one less than the size #define ARRAY_UPB(_x) (ARRAY_SIZE(_x) - 1) // Macro to assign an array from an initializer list #if __cplusplus >= 201103L // This version relies on C++'11 features #define ARRAY_INIT(_dest, _init) {static const decltype(_dest) _temp = _init; memcpy(_dest, _temp, sizeof(_dest)); } #else // This version relies on a gcc extension that is available only in older compilers #define ARRAY_INIT(_dest, _init) _dest = _init #define nullptr (0) #endif // Class to describe a string buffer, including its length. This saves passing buffer lengths around everywhere. class StringRef { char *p; // pointer to the storage size_t len; // number of characters in the storage public: StringRef(char *pp, size_t pl) : p(pp), len(pl) { } size_t Length() const { return len; } size_t strlen() const; char *Pointer() { return p; } const char *Pointer() const { return p; } char& operator[](size_t index) { return p[index]; } char operator[](size_t index) const { return p[index]; } void Clear() { p[0] = 0; } int printf(const char *fmt, ...); int vprintf(const char *fmt, va_list vargs); int catf(const char *fmt, ...); size_t copy(const char* src); size_t cat(const char *src); }; extern StringRef scratchString; #include "Arduino.h" #include "Configuration.h" #include "Network.h" #include "Platform.h" #include "Webserver.h" #include "GCodes.h" #include "Move.h" #include "Heat.h" #include "Tool.h" #include "Reprap.h" // std::min and std::max don't seem to work with this variant of gcc, so define our own ones here // We use these only with primitive types, so pass them directly instead of by const reference #undef min #undef max template inline X min(X _a, X _b) { return (_a < _b) ? _a : _b; } template inline X max(X _a, X _b) { return (_a > _b) ? _a : _b; } // Specialisations for float and double to handle NANs properly template<> inline float min(float _a, float _b) { return (isnan(_a) || _a < _b) ? _a : _b; } template<> inline float max(float _a, float _b) { return (isnan(_a) || _a > _b) ? _a : _b; } template<> inline double min(double _a, double _b) { return (isnan(_a) || _a < _b) ? _a : _b; } template<> inline double max(double _a, double _b) { return (isnan(_a) || _a > _b) ? _a : _b; } inline float fsquare(float arg) { return arg * arg; } inline uint64_t isquare64(int32_t arg) { return (uint64_t)((int64_t)arg * arg); } inline uint64_t isquare64(uint32_t arg) { return (uint64_t)arg * arg; } #endif