/*----------------------------------------------------------------------------
 *
 * File:
 * eas_report.c
 *
 * Contents and purpose:
 * This file contains the debug message handling routines for the EAS library.
 * These routines should be modified as needed for your system.
 *
 * Copyright 2005 Sonic Network Inc.

 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 *----------------------------------------------------------------------------
 * Revision Control:
 *   $Revision: 659 $
 *   $Date: 2007-04-24 13:36:35 -0700 (Tue, 24 Apr 2007) $
 *----------------------------------------------------------------------------
*/

#ifdef _lint
#include "lint_stdlib.h"
#else
#include <stdlib.h>
#include <stdio.h>
#include <stdarg.h>
#endif

#include "eas_report.h"

static int severityLevel = 9999;

/* debug file */
static FILE *debugFile = NULL;
int flush = 0;

#ifndef _NO_DEBUG_PREPROCESSOR

/* structure should have an #include for each error message header file */
S_DEBUG_MESSAGES debugMessages[] =
{
#ifndef UNIFIED_DEBUG_MESSAGES
#include "eas_config_msgs.h"


#include "eas_host_msgs.h"
#include "eas_hostmm_msgs.h"
#include "eas_math_msgs.h"
#include "eas_midi_msgs.h"
#include "eas_mixer_msgs.h"
#include "eas_pcm_msgs.h"
#include "eas_public_msgs.h"
#include "eas_smf_msgs.h"
#include "eas_wave_msgs.h"
#include "eas_voicemgt_msgs.h"

#ifdef _FM_SYNTH
#include "eas_fmsynth_msgs.h"
#include "eas_fmengine_msgs.h"
#endif

#ifdef _WT_SYNTH
#include "eas_wtsynth_msgs.h"
#include "eas_wtengine_msgs.h"
#endif

#ifdef _ARM_TEST_MAIN
#include "arm_main_msgs.h"
#endif

#ifdef _EAS_MAIN
#include "eas_main_msgs.h"
#endif

#ifdef _EAS_MAIN_IPC
#include "eas_main_ipc_msgs.h"
#endif

#ifdef _METRICS_ENABLED
#include "eas_perf_msgs.h"
#endif

#ifdef _COMPRESSOR_ENABLED
#include "eas_compressor_msgs.h"
#endif

#ifdef _ENHANCER_ENABLED
#include "eas_enhancer_msgs.h"
#endif

#ifdef _WOW_ENABLED
#include "eas_wow_msgs.h"
#endif

#ifdef _SMAF_PARSER
#include "eas_smaf_msgs.h"
#endif

#ifdef _OTA_PARSER
#include "eas_ota_msgs.h"
#endif

#ifdef _IMELODY_PARSER
#include "eas_imelody_msgs.h"
#endif

#ifdef _WAVE_PARSER
#include "eas_wavefile_msgs.h"
#endif

#if defined(_CMX_PARSER) || defined(_MFI_PARSER)
#include "eas_cmf_msgs.h"
#endif

#if defined(_CMX_PARSER) || defined(_MFI_PARSER) || defined(_WAVE_PARSER)
#include "eas_imaadpcm_msgs.h"
#endif

#else
#include "eas_debugmsgs.h"
#endif

/* denotes end of error messages */
{ 0,0,0 }
};

/*----------------------------------------------------------------------------
 * EAS_ReportEx()
 *
 * This is the error message handler. The default handler outputs error
 * messages to stdout. Modify this as needed for your system.
 *----------------------------------------------------------------------------
*/
void EAS_ReportEx (int severity, unsigned long hashCode, int serialNum, ...)
{
    va_list vargs;
    int i;

    /* check severity level */
    if (severity > severityLevel)
        return;

    /* find the error message and output to stdout */
    /*lint -e{661} we check for NULL pointer - no fence post error here */
    for (i = 0; debugMessages[i].m_pDebugMsg; i++)
    {
        if ((debugMessages[i].m_nHashCode == hashCode) &&
        (debugMessages[i].m_nSerialNum == serialNum))
        {
            /*lint -e{826} <allow variable args> */
            va_start(vargs, serialNum);
            if (debugFile)
            {
                vfprintf(debugFile, debugMessages[i].m_pDebugMsg, vargs);
                if (flush)
                    fflush(debugFile);
            }
            else
            {
                vprintf(debugMessages[i].m_pDebugMsg, vargs);
            }
            va_end(vargs);
            return;
        }
    }
    printf("Unrecognized error: Severity=%d; HashCode=%lu; SerialNum=%d\n", severity, hashCode, serialNum);
} /* end EAS_ReportEx */

#else
/*----------------------------------------------------------------------------
 * EAS_Report()
 *
 * This is the error message handler. The default handler outputs error
 * messages to stdout. Modify this as needed for your system.
 *----------------------------------------------------------------------------
*/
void EAS_Report (int severity, const char *fmt, ...)
{
    va_list vargs;

    /* check severity level */
    if (severity > severityLevel)
        return;

    /*lint -e{826} <allow variable args> */
    va_start(vargs, fmt);
    if (debugFile)
    {
        vfprintf(debugFile, fmt, vargs);
        if (flush)
            fflush(debugFile);
    }
    else
    {
        vprintf(fmt, vargs);
    }
    va_end(vargs);
} /* end EAS_Report */

/*----------------------------------------------------------------------------
 * EAS_ReportX()
 *
 * This is the error message handler. The default handler outputs error
 * messages to stdout. Modify this as needed for your system.
 *----------------------------------------------------------------------------
*/
void EAS_ReportX (int severity, const char *fmt, ...)
{
    va_list vargs;

    /* check severity level */
    if (severity > severityLevel)
        return;

    /*lint -e{826} <allow variable args> */
    va_start(vargs, fmt);
    if (debugFile)
    {
        vfprintf(debugFile, fmt, vargs);
        if (flush)
            fflush(debugFile);
    }
    else
    {
        vprintf(fmt, vargs);
    }
    va_end(vargs);
} /* end EAS_ReportX */
#endif

/*----------------------------------------------------------------------------
 * EAS_SetDebugLevel()
 *
 * Sets the level for debug message output
 *----------------------------------------------------------------------------
*/

void EAS_SetDebugLevel (int severity)
{
    severityLevel = severity;
} /* end EAS_SetDebugLevel */

/*----------------------------------------------------------------------------
 * EAS_SetDebugFile()
 *
 * Redirect debugger output to the specified file.
 *----------------------------------------------------------------------------
*/
void EAS_SetDebugFile (void *file, int flushAfterWrite)
{
    debugFile = (FILE*) file;
    flush = flushAfterWrite;
} /* end EAS_SetDebugFile */