grbl-LPC-CoreXY/print.c

92 lines
2.0 KiB
C
Raw Normal View History

/*
print.c - Functions for formatting output strings
Part of Grbl
Copyright (c) 2009-2011 Simen Svale Skogsrud
Grbl 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.
Grbl 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 Grbl. If not, see <http://www.gnu.org/licenses/>.
*/
/* This code was initially inspired by the wiring_serial module by David A. Mellis which
used to be a part of the Arduino project. */
#include <math.h>
#include <avr/pgmspace.h>
#include "serial.h"
2011-06-03 21:56:18 +02:00
#define DECIMAL_PLACES 4
void printString(const char *s)
{
while (*s)
serial_write(*s++);
}
// Print a string stored in PGM-memory
void printPgmString(const char *s)
{
char c;
while ((c = pgm_read_byte_near(s++)))
serial_write(c);
}
// Prints a single digit of any base up to 36. 0..9 prints as
// '0'..'9' while 10..35 prints as 'a'..'z'
void printDigit(uint8_t value) {
serial_write(value < 10 ?
'0' + value :
'a' + value - 10);
}
void printIntegerInBase(unsigned long n, unsigned long base)
{
if (n == 0) {
printDigit(0);
return;
}
while (n > 0) {
printDigit(n % base);
n /= base;
}
}
void printInteger(long n)
{
if (n < 0) {
serial_write('-');
n = -n;
}
printIntegerInBase(n, 10);
}
2011-06-03 21:56:18 +02:00
// A very simple
void printFloat(double n)
{
2011-06-03 21:56:18 +02:00
double integer_part, fractional_part, decimal_part;
fractional_part = modf(n, &integer_part);
printInteger(integer_part);
serial_write('.');
2011-06-03 21:56:18 +02:00
fractional_part *= 10;
int decimals = DECIMAL_PLACES;
2011-06-03 21:56:55 +02:00
while(decimals-- > 0) {
2011-06-03 21:56:18 +02:00
decimal_part = floor(fractional_part);
printDigit(decimal_part);
fractional_part -= decimal_part;
fractional_part *= 10;
}
}