fprime/Svc/AssertFatalAdapter/AssertFatalAdapterComponentImpl.cpp
Joshua Anderson 3cccd731d9
Refactor FW_OBJECT_NAMES switches and fix building without object names
Instead of adding the name argument to a constructor when FW_OBJECT_NAMES
is enabled, always supply a name argument.

Add a marco that conditionally sets the name to "" if FW_OBJECT_NAMES is not set.
This cleans up a lot of the conditional compilation switches that weren't being tested
and would silently break, while still stripping the strings from the binary.
2020-10-07 17:19:05 -07:00

160 lines
4.6 KiB
C++

// ======================================================================
// \title AssertFatalAdapterImpl.cpp
// \author tcanham
// \brief cpp file for AssertFatalAdapter component implementation class
//
// \copyright
// Copyright 2009-2015, by the California Institute of Technology.
// ALL RIGHTS RESERVED. United States Government Sponsorship
// acknowledged.
//
// ======================================================================
#include <Svc/AssertFatalAdapter/AssertFatalAdapterComponentImpl.hpp>
#include "Fw/Types/BasicTypes.hpp"
#include <Fw/Types/Assert.hpp>
#include <Fw/Logger/Logger.hpp>
#include <assert.h>
#include <stdio.h>
namespace Fw {
void defaultReportAssert
(
FILE_NAME_ARG file,
NATIVE_UINT_TYPE lineNo,
NATIVE_UINT_TYPE numArgs,
AssertArg arg1,
AssertArg arg2,
AssertArg arg3,
AssertArg arg4,
AssertArg arg5,
AssertArg arg6,
I8* destBuffer,
NATIVE_INT_TYPE buffSize
);
}
namespace Svc {
// ----------------------------------------------------------------------
// Construction, initialization, and destruction
// ----------------------------------------------------------------------
AssertFatalAdapterComponentImpl ::
AssertFatalAdapterComponentImpl(
const char *const compName
) : AssertFatalAdapterComponentBase(compName)
{
// register component with adapter
this->m_adapter.regAssertReporter(this);
// register adapter
this->m_adapter.registerHook();
}
void AssertFatalAdapterComponentImpl ::
init(
const NATIVE_INT_TYPE instance
)
{
AssertFatalAdapterComponentBase::init(instance);
}
AssertFatalAdapterComponentImpl ::
~AssertFatalAdapterComponentImpl(void)
{
}
void AssertFatalAdapterComponentImpl::AssertFatalAdapter::reportAssert(
FILE_NAME_ARG file,
NATIVE_UINT_TYPE lineNo,
NATIVE_UINT_TYPE numArgs,
AssertArg arg1,
AssertArg arg2,
AssertArg arg3,
AssertArg arg4,
AssertArg arg5,
AssertArg arg6
) {
if (m_compPtr) {
m_compPtr->reportAssert(file,lineNo,numArgs,
arg1,arg2,arg3,arg4,arg5,arg6);
} else {
// Can't assert, what else can we do? Maybe somebody will see it.
Fw::Logger::logMsg("Svc::AssertFatalAdapter not registered!\n");
assert(0);
}
}
void AssertFatalAdapterComponentImpl::AssertFatalAdapter::regAssertReporter(AssertFatalAdapterComponentImpl* compPtr) {
this->m_compPtr = compPtr;
}
AssertFatalAdapterComponentImpl::AssertFatalAdapter::AssertFatalAdapter() : m_compPtr(0) {
}
AssertFatalAdapterComponentImpl::AssertFatalAdapter::~AssertFatalAdapter() {
}
void AssertFatalAdapterComponentImpl::AssertFatalAdapter::doAssert(void) {
// do nothing since there will be a FATAL
}
void AssertFatalAdapterComponentImpl::reportAssert(
FILE_NAME_ARG file,
NATIVE_UINT_TYPE lineNo,
NATIVE_UINT_TYPE numArgs,
AssertArg arg1,
AssertArg arg2,
AssertArg arg3,
AssertArg arg4,
AssertArg arg5,
AssertArg arg6
) {
#if FW_ASSERT_LEVEL == FW_FILEID_ASSERT
Fw::LogStringArg fileArg;
fileArg.format("0x%08X",file);
#else
Fw::LogStringArg fileArg((const char*)file);
#endif
I8 msg[FW_ASSERT_TEXT_SIZE];
Fw::defaultReportAssert(file,lineNo,numArgs,arg1,arg2,arg3,arg4,arg5,arg6,msg,sizeof(msg));
fprintf(stderr, "%s\n",(const char*)msg);
switch (numArgs) {
case 0:
this->log_FATAL_AF_ASSERT_0(fileArg,lineNo);
break;
case 1:
this->log_FATAL_AF_ASSERT_1(fileArg,lineNo,arg1);
break;
case 2:
this->log_FATAL_AF_ASSERT_2(fileArg,lineNo,arg1,arg2);
break;
case 3:
this->log_FATAL_AF_ASSERT_3(fileArg,lineNo,arg1,arg2,arg3);
break;
case 4:
this->log_FATAL_AF_ASSERT_4(fileArg,lineNo,arg1,arg2,arg3,arg4);
break;
case 5:
this->log_FATAL_AF_ASSERT_5(fileArg,lineNo,arg1,arg2,arg3,arg4,arg5);
break;
case 6:
this->log_FATAL_AF_ASSERT_6(fileArg,lineNo,arg1,arg2,arg3,arg4,arg5,arg6);
break;
default:
this->log_FATAL_AF_UNEXPECTED_ASSERT(fileArg,lineNo,numArgs);
break;
}
}
} // end namespace Svc