Skip to main content

diagnostic_msgs.flex

// ROS is available under the BSD license Copyright (C) 2009, Willow Garage, Inc.  
// Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 
//   - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 
//   - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 
//   - Neither the names of Willow Garage, Inc. nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. 
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 
// BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 
// GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
module ROS::Common::v1.diagnostic_msgs

import ROS::Common::v1.std_msgs (Header)


enum DiagnosticStatusInt8Constants int8 {
    OK = 0;
    WARN = 1;
    ERROR = 2;
    STALE = 3;
}

// This message is used to send diagnostic information about the state of the robot
message struct DiagnosticArray {
    // for timestamp
    header: Header;
    // an array of components being reported on
    status: DiagnosticStatus[];
}

// This message holds the status of an individual component of the robot. Possible levels of operations
message struct DiagnosticStatus {
    // level of operation enumerated above
    level: int8;
    // a description of the test/component reporting
    name: string;
    // a description of the status
    _message: string;
    // a hardware unique string
    hardware_id: string;
    // an array of values associated with the status
    values: KeyValue[];
}

message struct KeyValue {
    // what to label this value when viewing
    key: string;
    // a value to track over time
    value: string;
}