mbed Connector Endpoint interface. This interface permits a mbed endpoint to easily setup MDS resources and emit those resources to an MDS server.

Dependents:   IoT_LED_demo ServoTest uWater_Project hackathon ... more

Committer:
sam_grove
Date:
Tue Jan 27 23:41:34 2015 +0000
Revision:
2:853f9ecc12df
Parent:
0:b438482ebbfc
Child:
5:a929d65eb385
Use auto-format on code and add markup to render class documentation

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ansond 0:b438482ebbfc 1 /**
ansond 0:b438482ebbfc 2 * @file Logger.h
ansond 0:b438482ebbfc 3 * @brief mbed CoAP Endpoint logging class
ansond 0:b438482ebbfc 4 * @author Doug Anson/Chris Paola
ansond 0:b438482ebbfc 5 * @version 1.0
sam_grove 2:853f9ecc12df 6 * @see
ansond 0:b438482ebbfc 7 *
ansond 0:b438482ebbfc 8 * Copyright (c) 2014
ansond 0:b438482ebbfc 9 *
ansond 0:b438482ebbfc 10 * Licensed under the Apache License, Version 2.0 (the "License");
ansond 0:b438482ebbfc 11 * you may not use this file except in compliance with the License.
ansond 0:b438482ebbfc 12 * You may obtain a copy of the License at
ansond 0:b438482ebbfc 13 *
ansond 0:b438482ebbfc 14 * http://www.apache.org/licenses/LICENSE-2.0
ansond 0:b438482ebbfc 15 *
ansond 0:b438482ebbfc 16 * Unless required by applicable law or agreed to in writing, software
ansond 0:b438482ebbfc 17 * distributed under the License is distributed on an "AS IS" BASIS,
ansond 0:b438482ebbfc 18 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
ansond 0:b438482ebbfc 19 * See the License for the specific language governing permissions and
ansond 0:b438482ebbfc 20 * limitations under the License.
ansond 0:b438482ebbfc 21 */
sam_grove 2:853f9ecc12df 22
sam_grove 2:853f9ecc12df 23 #ifndef __LOGGER_H__
sam_grove 2:853f9ecc12df 24 #define __LOGGER_H__
sam_grove 2:853f9ecc12df 25
sam_grove 2:853f9ecc12df 26 // mbed API
sam_grove 2:853f9ecc12df 27 #include "mbed.h"
sam_grove 2:853f9ecc12df 28
sam_grove 2:853f9ecc12df 29 // Support for std args
sam_grove 2:853f9ecc12df 30 #include <stdarg.h>
sam_grove 2:853f9ecc12df 31
sam_grove 2:853f9ecc12df 32 // Depends on use of BufferedSerial
sam_grove 2:853f9ecc12df 33 #include "BufferedSerial.h"
sam_grove 2:853f9ecc12df 34
sam_grove 2:853f9ecc12df 35 /** Logger class
sam_grove 2:853f9ecc12df 36 */
sam_grove 2:853f9ecc12df 37 class Logger
sam_grove 2:853f9ecc12df 38 {
sam_grove 2:853f9ecc12df 39 public:
sam_grove 2:853f9ecc12df 40 /**
sam_grove 2:853f9ecc12df 41 Default constructor
sam_grove 2:853f9ecc12df 42 @param pc input BufferedSerial instance for debugging (if NULL, no debugging output will occur in the library)
sam_grove 2:853f9ecc12df 43 */
sam_grove 2:853f9ecc12df 44 Logger(const BufferedSerial *pc);
ansond 0:b438482ebbfc 45
sam_grove 2:853f9ecc12df 46 /**
sam_grove 2:853f9ecc12df 47 Copy constructor
sam_grove 2:853f9ecc12df 48 @param logger input Logger instance to deep copy
sam_grove 2:853f9ecc12df 49 */
sam_grove 2:853f9ecc12df 50 Logger(const Logger &logger);
sam_grove 2:853f9ecc12df 51
sam_grove 2:853f9ecc12df 52 /**
sam_grove 2:853f9ecc12df 53 Destructor
sam_grove 2:853f9ecc12df 54 */
sam_grove 2:853f9ecc12df 55 virtual ~Logger();
sam_grove 2:853f9ecc12df 56
sam_grove 2:853f9ecc12df 57 /**
sam_grove 2:853f9ecc12df 58 Log output
sam_grove 2:853f9ecc12df 59 @param format input format for the logging
sam_grove 2:853f9ecc12df 60 @param ... input (variable arguments to display)
sam_grove 2:853f9ecc12df 61 */
sam_grove 2:853f9ecc12df 62 void log(const char *format, ...);
sam_grove 2:853f9ecc12df 63 protected:
sam_grove 2:853f9ecc12df 64
sam_grove 2:853f9ecc12df 65 private:
sam_grove 2:853f9ecc12df 66 BufferedSerial *m_pc;
sam_grove 2:853f9ecc12df 67 };
sam_grove 2:853f9ecc12df 68
sam_grove 2:853f9ecc12df 69 #endif // __LOGGER_H__