/usr/include/uhd/utils/msg.hpp is in libuhd-dev 3.7.3-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 | //
// Copyright 2011-2013 Ettus Research LLC
//
// This program 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.
//
// This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
//
#ifndef INCLUDED_UHD_UTILS_MSG_HPP
#define INCLUDED_UHD_UTILS_MSG_HPP
#include <uhd/config.hpp>
#include <uhd/utils/pimpl.hpp>
#include <ostream>
#include <iomanip>
#include <string>
/*!
* A UHD message macro with configurable type.
* Usage: UHD_MSG(warning) << "some warning message" << std::endl;
*/
#define UHD_MSG(type) \
uhd::msg::_msg(uhd::msg::type)()
//! Helpful debug tool to print site info
#define UHD_HERE() \
UHD_MSG(status) << __FILE__ << ":" << __LINE__ << std::endl
//! Helpful debug tool to print a variable
#define UHD_VAR(var) \
UHD_MSG(status) << #var << " = " << var << std::endl;
//! Helpful debug tool to print a variable in hex
#define UHD_HEX(var) \
UHD_MSG(status) << #var << " = 0x" << std::hex << std::setfill('0') << std::setw(8) << var << std::dec << std::endl;
namespace uhd{ namespace msg{
//! Possible message types
enum type_t{
status = 's',
warning = 'w',
error = 'e',
fastpath= 'f'
};
//! Typedef for a user-registered message handler
typedef void (*handler_t)(type_t, const std::string &);
/*!
* Register the handler for uhd system messages.
* Only one handler can be registered at once.
* This replaces the default std::cout/cerr handler.
* \param handler a new handler callback function
*/
UHD_API void register_handler(const handler_t &handler);
//! Internal message object (called by UHD_MSG macro)
class UHD_API _msg{
public:
_msg(const type_t type);
~_msg(void);
std::ostream &operator()(void);
private:
UHD_PIMPL_DECL(impl) _impl;
};
}} //namespace uhd::msg
#endif /* INCLUDED_UHD_UTILS_MSG_HPP */
|