Blob Blame History Raw
/*      -*- linux-c -*-
 *
 * (C) Copyright IBM Corp. 2005
 *
 * 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.  This
 * file and program are licensed under a BSD style license.  See
 * the Copying file included with the OpenHPI distribution for
 * full licensing terms.
 *
 * Author(s):
 *    W. David Ashley <dashley@us.ibm.com>
 */


#include <stdlib.h>
#include <string.h>
#include <stdio.h>
extern "C"
{
#include <SaHpi.h>
}
#include "oSaHpiTypesEnums.hpp"
#include "oSaHpiSensorReading.hpp"
#include "oSaHpiSensorRange.hpp"
#include "oSaHpiSensorDataFormat.hpp"


/**
 * Default constructor.
 */
oSaHpiSensorDataFormat::oSaHpiSensorDataFormat() {
    oSaHpiSensorReading *sr;

    IsSupported = 0;
    ReadingType = SAHPI_SENSOR_READING_TYPE_INT64;
    BaseUnits = SAHPI_SU_UNSPECIFIED;
    ModifierUnits = SAHPI_SU_UNSPECIFIED;
    ModifierUse = SAHPI_SMUU_NONE;
    Percentage = false;
    Range.Flags = 0;
    sr = (oSaHpiSensorReading *)&Range.Max;
    sr->initSensorReading(sr);
    sr = (oSaHpiSensorReading *)&Range.Min;
    sr->initSensorReading(sr);
    sr = (oSaHpiSensorReading *)&Range.Nominal;
    sr->initSensorReading(sr);
    sr = (oSaHpiSensorReading *)&Range.NormalMax;
    sr->initSensorReading(sr);
    sr = (oSaHpiSensorReading *)&Range.NormalMin;
    sr->initSensorReading(sr);
    AccuracyFactor = 0;
};


/**
 * Constructor.
 *
 * @param buf    The reference to the class to be copied.
 */
oSaHpiSensorDataFormat::oSaHpiSensorDataFormat(const oSaHpiSensorDataFormat& df) {
    memcpy(this, &df, sizeof(SaHpiSensorDataFormatT));
}


/**
 * Assign a field in the SaHpiSensorDataFormatT struct a value.
 *
 * @param field  The pointer to the struct (class).
 * @param field  The field name as a text string (case sensitive).
 * @param value  The character string value to be assigned to the field. This
 *               value will be converted as necessary.
 *
 * @return True if there was an error, otherwise false.
 */
bool oSaHpiSensorDataFormat::assignField(SaHpiSensorDataFormatT *ptr,
                                         const char *field,
                                         const char *value) {
    if (ptr == NULL || field == NULL || value == NULL) {
        return true;
    }
    if (strcmp(field, "IsSupported") == 0) {
        ptr->IsSupported = oSaHpiTypesEnums::str2torf(value);
        return false;
    }
    else if (strcmp(field, "ReadingType") == 0) {
        ptr->ReadingType = oSaHpiTypesEnums::str2sensorreadingtype(value);
        return false;
    }
    else if (strcmp(field, "BaseUnits") == 0) {
        ptr->BaseUnits = oSaHpiTypesEnums::str2sensorunits(value);
        return false;
    }
    else if (strcmp(field, "ModifierUnits") == 0) {
        ptr->ModifierUnits = oSaHpiTypesEnums::str2sensorunits(value);
        return false;
    }
    else if (strcmp(field, "ModifierUse") == 0) {
        ptr->ModifierUse = oSaHpiTypesEnums::str2sensoruse(value);
        return false;
    }
    else if (strcmp(field, "Percentage") == 0) {
        ptr->Percentage = oSaHpiTypesEnums::str2torf(value);
        return false;
    }
    else if (strcmp(field, "AccuracyFactor") == 0) {
        ptr->AccuracyFactor = (SaHpiFloat64T)atof(value);
        return false;
    }
    return true;
};


/**
 * Print the contents of the entity.
 *
 * @param stream Target stream.
 * @param buffer Address of the SaHpiSensorReadingT struct.
 *
 * @return True if there was an error, otherwise false.
 */
bool oSaHpiSensorDataFormat::fprint(FILE *stream,
                                    const int indent,
                                    const SaHpiSensorDataFormatT *df) {
	int i, err = 0;
    char indent_buf[indent + 1];

    if (stream == NULL || df == NULL) {
        return true;
    }
    for (i = 0; i < indent; i++) {
        indent_buf[i] = ' ';
    }
    indent_buf[indent] = '\0';

    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "IsSupported = %s\n", oSaHpiTypesEnums::torf2str(df->IsSupported));
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "ReadingType = %s\n", oSaHpiTypesEnums::sensorreadingtype2str(df->ReadingType));
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "BaseUnits = %s\n", oSaHpiTypesEnums::sensorunits2str(df->BaseUnits));
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "ModifierUnits = %s\n", oSaHpiTypesEnums::sensorunits2str(df->ModifierUnits));
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "ModifierUse = %s\n", oSaHpiTypesEnums::sensoruse2str(df->ModifierUse));
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "Percentage = %s\n", oSaHpiTypesEnums::torf2str(df->Percentage));
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "Range\n");
    if (err < 0) {
        return true;
    }
    const SaHpiSensorRangeT *sr = (const SaHpiSensorRangeT *)&df->Range;
    err = oSaHpiSensorRange::fprint(stream, indent + 3, sr);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "%s", indent_buf);
    if (err < 0) {
        return true;
    }
    err = fprintf(stream, "AccuracyFactor = %f\n", df->AccuracyFactor);
    if (err < 0) {
        return true;
    }

	return false;
}