Device interface library for multiple platforms including Mbed.
Dependents: DeepCover Embedded Security in IoT MaximInterface MAXREFDES155#
Maxim Interface is a library framework focused on providing flexible and expressive hardware interfaces. Both communication interfaces such as I2C and 1-Wire and device interfaces such as DS18B20 are supported. Modern C++ concepts are used extensively while keeping compatibility with C++98/C++03 and requiring no external dependencies. The embedded-friendly design does not depend on exceptions or RTTI.
The full version of the project is hosted on GitLab: https://gitlab.com/iabenz/MaximInterface
Diff: MaximInterfaceCore/Uart.cpp
- Revision:
- 8:5ea891c7d1a1
- Parent:
- 7:9cd16581b578
- Child:
- 11:3f3bf6bf5e6c
--- a/MaximInterfaceCore/Uart.cpp Mon Jul 22 11:44:07 2019 -0500 +++ b/MaximInterfaceCore/Uart.cpp Mon Sep 16 11:13:37 2019 -0500 @@ -1,5 +1,5 @@ /******************************************************************************* -* Copyright (C) 2017 Maxim Integrated Products, Inc., All Rights Reserved. +* Copyright (C) Maxim Integrated Products, Inc., All Rights Reserved. * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), @@ -35,21 +35,18 @@ namespace MaximInterfaceCore { -error_code Uart::writeBlock(span<const uint_least8_t> data) { - error_code result; - for (span<const uint_least8_t>::index_type i = 0; - i < data.size() && !result; ++i) { - result = writeByte(data[i]); +Result<void> Uart::writeBlock(span<const uint_least8_t> data) { + for (span<const uint_least8_t>::index_type i = 0; i < data.size(); ++i) { + MaximInterfaceCore_TRY(writeByte(data[i])); } - return result; + return none; } -error_code Uart::readBlock(span<uint_least8_t> data) { - error_code result; - for (span<uint_least8_t>::index_type i = 0; i < data.size() && !result; ++i) { - result = readByte(data[i]); +Result<void> Uart::readBlock(span<uint_least8_t> data) { + for (span<uint_least8_t>::index_type i = 0; i < data.size(); ++i) { + MaximInterfaceCore_TRY_VALUE(data[i], readByte()); } - return result; + return none; } const error_category & Uart::errorCategory() { @@ -64,10 +61,8 @@ case OverrunError: return "Overrun Error"; - - default: - return defaultErrorMessage(condition); } + return defaultErrorMessage(condition); } } instance; return instance;