If you develop on windows and need cr/lf files, see this:
    https://git-scm.com/book/en/v2/Customizing-Git-Git-Configuration#_formatting_and_whitespace
    Git can handle this by auto-converting CRLF line endings into LF
    when you add a file to the index, and vice versa when it checks out
    code onto your filesystem. You can turn on this functionality with
    the core.autocrlf setting. If you're on a Windows machine, set it
    to true - this converts LF endings into CRLF when you check out code:
    $ git config --global core.autocrlf true
		
	
			
		
			
				
	
	
		
			111 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <stdlib.h>
 | |
| #include <stdio.h>
 | |
| #include <string.h>
 | |
| #include <inttypes.h>
 | |
| 
 | |
| #include "HardwareSerial.h"
 | |
| 
 | |
| #if !defined(NO_GLOBAL_INSTANCES) && !defined(NO_GLOBAL_SERIAL)
 | |
| HardwareSerial Serial(0);
 | |
| #endif
 | |
| 
 | |
| HardwareSerial::HardwareSerial(int uart_nr) : _uart_nr(uart_nr), _uart(NULL) {}
 | |
| 
 | |
| void HardwareSerial::begin(unsigned long baud, uint32_t config, int8_t rxPin, int8_t txPin, bool invert)
 | |
| {
 | |
|     if(0 > _uart_nr || _uart_nr > 2) {
 | |
|         log_e("Serial number is invalid, please use 0, 1 or 2");
 | |
|         return;
 | |
|     }
 | |
|     if(_uart) {
 | |
|         end();
 | |
|     }
 | |
|     if(_uart_nr == 0 && rxPin < 0 && txPin < 0) {
 | |
|         rxPin = 3;
 | |
|         txPin = 1;
 | |
|     }
 | |
|     if(_uart_nr == 1 && rxPin < 0 && txPin < 0) {
 | |
|         rxPin = 9;
 | |
|         txPin = 10;
 | |
|     }
 | |
|     if(_uart_nr == 2 && rxPin < 0 && txPin < 0) {
 | |
|         rxPin = 16;
 | |
|         txPin = 17;
 | |
|     }
 | |
|     _uart = uartBegin(_uart_nr, baud, config, rxPin, txPin, 256, invert);
 | |
| }
 | |
| 
 | |
| void HardwareSerial::end()
 | |
| {
 | |
|     if(uartGetDebug() == _uart_nr) {
 | |
|         uartSetDebug(0);
 | |
|     }
 | |
|     uartEnd(_uart);
 | |
|     _uart = 0;
 | |
| }
 | |
| 
 | |
| void HardwareSerial::setDebugOutput(bool en)
 | |
| {
 | |
|     if(_uart == 0) {
 | |
|         return;
 | |
|     }
 | |
|     if(en) {
 | |
|         uartSetDebug(_uart);
 | |
|     } else {
 | |
|         if(uartGetDebug() == _uart_nr) {
 | |
|             uartSetDebug(0);
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| int HardwareSerial::available(void)
 | |
| {
 | |
|     return uartAvailable(_uart);
 | |
| }
 | |
| int HardwareSerial::availableForWrite(void)
 | |
| {
 | |
|     return uartAvailableForWrite(_uart);
 | |
| }
 | |
| 
 | |
| int HardwareSerial::peek(void)
 | |
| {
 | |
|     if (available()) {
 | |
|         return uartPeek(_uart);
 | |
|     }
 | |
|     return -1;
 | |
| }
 | |
| 
 | |
| int HardwareSerial::read(void)
 | |
| {
 | |
|     if(available()) {
 | |
|         return uartRead(_uart);
 | |
|     }
 | |
|     return -1;
 | |
| }
 | |
| 
 | |
| void HardwareSerial::flush()
 | |
| {
 | |
|     uartFlush(_uart);
 | |
| }
 | |
| 
 | |
| size_t HardwareSerial::write(uint8_t c)
 | |
| {
 | |
|     uartWrite(_uart, c);
 | |
|     return 1;
 | |
| }
 | |
| 
 | |
| size_t HardwareSerial::write(const uint8_t *buffer, size_t size)
 | |
| {
 | |
|     uartWriteBuf(_uart, buffer, size);
 | |
|     return size;
 | |
| }
 | |
| uint32_t  HardwareSerial::baudRate()
 | |
| 
 | |
| {
 | |
| 	return uartGetBaudRate(_uart);
 | |
| }
 | |
| HardwareSerial::operator bool() const
 | |
| {
 | |
|     return true;
 | |
| }
 |