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

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;