/* Arduino SdFat Library * Copyright (C) 2012 by William Greiman * * This file is part of the Arduino SdFat Library * * This Library is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This Library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with the Arduino SdFat Library. If not, see * . */ #ifndef SdFatUtil_h #define SdFatUtil_h /** * \file * \brief Useful utility functions. */ #include "SdFat.h" /** Store and print a string in flash memory.*/ #define PgmPrint(x) SerialPrint_P(PSTR(x)) /** Store and print a string in flash memory followed by a CR/LF.*/ #define PgmPrintln(x) SerialPrintln_P(PSTR(x)) namespace SdFatUtil { /** Amount of free RAM * \return The number of free bytes. */ int FreeRam(); /** %Print a string in flash memory. * * \param[in] pr Print object for output. * \param[in] str Pointer to string stored in flash memory. */ void print_P(Print* pr, PGM_P str); /** %Print a string in flash memory followed by a CR/LF. * * \param[in] pr Print object for output. * \param[in] str Pointer to string stored in flash memory. */ void println_P(Print* pr, PGM_P str); //---------------------------------------------------------------------------- /** %Print a string in flash memory to Serial. * * \param[in] str Pointer to string stored in flash memory. */ inline void SerialPrint_P(PGM_P str) { print_P(&Serial, str); } //---------------------------------------------------------------------------- /** %Print a string in flash memory to Serial followed by a CR/LF. * * \param[in] str Pointer to string stored in flash memory. */ inline void SerialPrintln_P(PGM_P str) { println_P(&Serial, str); } } // namespace SdFatUtil using namespace SdFatUtil; // NOLINT #endif // #define SdFatUtil_h