Smart-Home am Beispiel der Präsenzerkennung im Raum Projektarbeit Lennart Heimbs, Johannes Krug, Sebastian Dohle und Kevin Holzschuh bei Prof. Oliver Hofmann SS2019
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Print.cpp 5.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /*
  2. Print.cpp - Base class that provides print() and println()
  3. Copyright (c) 2008 David A. Mellis. All right reserved.
  4. This library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. This library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with this library; if not, write to the Free Software
  14. Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  15. Modified 23 November 2006 by David A. Mellis
  16. Modified December 2014 by Ivan Grokhotkov
  17. Modified May 2015 by Michael C. Miller - esp8266 progmem support
  18. Modified August 2016 by Marcelo Aquino <marceloaqno@gmail.org> for MySensors use
  19. */
  20. #include <cstdlib>
  21. #include <cstdio>
  22. #include <cstdarg>
  23. #include <cmath>
  24. #include "Print.h"
  25. // Public Methods //////////////////////////////////////////////////////////////
  26. size_t Print::write(const uint8_t *buffer, size_t size)
  27. {
  28. size_t n = 0;
  29. while(size--) {
  30. n += write(*buffer++);
  31. }
  32. return n;
  33. }
  34. size_t
  35. #ifdef __GNUC__
  36. __attribute__((format(printf, 2, 3)))
  37. #endif
  38. Print::printf(const char *format, ...)
  39. {
  40. va_list arg;
  41. va_start(arg, format);
  42. char temp[64];
  43. char* buffer = temp;
  44. size_t len = vsnprintf(temp, sizeof(temp), format, arg);
  45. va_end(arg);
  46. if (len > sizeof(temp) - 1) {
  47. buffer = new char[len + 1];
  48. if (!buffer) {
  49. return 0;
  50. }
  51. va_start(arg, format);
  52. vsnprintf(buffer, len + 1, format, arg);
  53. va_end(arg);
  54. }
  55. len = write((const uint8_t*) buffer, len);
  56. if (buffer != temp) {
  57. delete[] buffer;
  58. }
  59. return len;
  60. }
  61. size_t Print::print(const std::string &s)
  62. {
  63. return write(s.c_str(), s.length());
  64. }
  65. size_t Print::print(const char str[])
  66. {
  67. return write(str);
  68. }
  69. size_t Print::print(char c)
  70. {
  71. return write(c);
  72. }
  73. size_t Print::print(unsigned char b, int base)
  74. {
  75. return print((unsigned long) b, base);
  76. }
  77. size_t Print::print(int n, int base)
  78. {
  79. return print((long) n, base);
  80. }
  81. size_t Print::print(unsigned int n, int base)
  82. {
  83. return print((unsigned long) n, base);
  84. }
  85. size_t Print::print(long n, int base)
  86. {
  87. if(base == 0) {
  88. return write(n);
  89. } else if(base == 10) {
  90. if(n < 0) {
  91. int t = print('-');
  92. n = -n;
  93. return printNumber(n, 10) + t;
  94. }
  95. return printNumber(n, 10);
  96. } else {
  97. return printNumber(n, base);
  98. }
  99. }
  100. size_t Print::print(unsigned long n, int base)
  101. {
  102. if(base == 0) {
  103. return write(n);
  104. } else {
  105. return printNumber(n, base);
  106. }
  107. }
  108. size_t Print::print(double n, int digits)
  109. {
  110. return printFloat(n, digits);
  111. }
  112. size_t Print::println(void)
  113. {
  114. return print("\r\n");
  115. }
  116. size_t Print::println(const std::string &s)
  117. {
  118. size_t n = print(s);
  119. n += println();
  120. return n;
  121. }
  122. size_t Print::println(const char c[])
  123. {
  124. size_t n = print(c);
  125. n += println();
  126. return n;
  127. }
  128. size_t Print::println(char c)
  129. {
  130. size_t n = print(c);
  131. n += println();
  132. return n;
  133. }
  134. size_t Print::println(unsigned char b, int base)
  135. {
  136. size_t n = print(b, base);
  137. n += println();
  138. return n;
  139. }
  140. size_t Print::println(int num, int base)
  141. {
  142. size_t n = print(num, base);
  143. n += println();
  144. return n;
  145. }
  146. size_t Print::println(unsigned int num, int base)
  147. {
  148. size_t n = print(num, base);
  149. n += println();
  150. return n;
  151. }
  152. size_t Print::println(long num, int base)
  153. {
  154. size_t n = print(num, base);
  155. n += println();
  156. return n;
  157. }
  158. size_t Print::println(unsigned long num, int base)
  159. {
  160. size_t n = print(num, base);
  161. n += println();
  162. return n;
  163. }
  164. size_t Print::println(double num, int digits)
  165. {
  166. size_t n = print(num, digits);
  167. n += println();
  168. return n;
  169. }
  170. // Private Methods /////////////////////////////////////////////////////////////
  171. size_t Print::printNumber(unsigned long n, uint8_t base)
  172. {
  173. char buf[8 * sizeof(long) + 1]; // Assumes 8-bit chars plus zero byte.
  174. char *str = &buf[sizeof(buf) - 1];
  175. *str = '\0';
  176. // prevent crash if called with base == 1
  177. if(base < 2) {
  178. base = 10;
  179. }
  180. do {
  181. char c = n % base;
  182. n /= base;
  183. *--str = c < 10 ? c + '0' : c + 'A' - 10;
  184. } while(n);
  185. return write(str);
  186. }
  187. size_t Print::printFloat(double number, uint8_t digits)
  188. {
  189. size_t n = 0;
  190. if(std::isnan(number)) {
  191. return print("nan");
  192. }
  193. if(std::isinf(number)) {
  194. return print("inf");
  195. }
  196. if(number > 4294967040.0) {
  197. return print("ovf"); // constant determined empirically
  198. }
  199. if(number < -4294967040.0) {
  200. return print("ovf"); // constant determined empirically
  201. }
  202. // Handle negative numbers
  203. if(number < 0.0) {
  204. n += print('-');
  205. number = -number;
  206. }
  207. // Round correctly so that print(1.999, 2) prints as "2.00"
  208. double rounding = 0.5;
  209. for(uint8_t i = 0; i < digits; ++i) {
  210. rounding /= 10.0;
  211. }
  212. number += rounding;
  213. // Extract the integer part of the number and print it
  214. unsigned long int_part = (unsigned long) number;
  215. double remainder = number - (double) int_part;
  216. n += print(int_part);
  217. // Print the decimal point, but only if there are digits beyond
  218. if(digits > 0) {
  219. n += print(".");
  220. }
  221. // Extract digits from the remainder one at a time
  222. while(digits-- > 0) {
  223. remainder *= 10.0;
  224. int toPrint = int(remainder);
  225. n += print(toPrint);
  226. remainder -= toPrint;
  227. }
  228. return n;
  229. }