aboutsummaryrefslogtreecommitdiff
path: root/tools/lldb-mi/MIUtilSingletonHelper.h
blob: ad36366830b79e12dbe13bf16acd6e4b26fad7d9 (plain) (blame)
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
//===-- MIUtilSingletonHelper.h ---------------------------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

//++
// File:		MIUtilSingletonHelper.h
//
// Overview:	Contains template functions to aid the initialisation and
//				shutdown of MI modules. MI modules (or components) can 
//				use other MI modules to help them achieve their one task
//				(Modules only do one task).
//
// Environment:	Compilers:	Visual C++ 12.
//							gcc (Ubuntu/Linaro 4.8.1-10ubuntu9) 4.8.1
//				Libraries:	See MIReadmetxt. 
//
// Copyright:	None.
//--

#pragma once

namespace MI
{

// In house headers:
#include "MIUtilString.h"
#include "MICmnResources.h"

//++ ============================================================================
// Details:	Short cut helper function to simplify repeated initialisation of
//			MI components (singletons) required by a client module.
// Type:	Template method.
// Args:	vErrorResrcId	- (R)  The string resource ID error message identifier to place in errMsg.
//			vwrbOk			- (RW) On input True = Try to initalise MI driver module.
//								   On output True = MI driver module initialise successfully.
//			vwrErrMsg		- (W)  MI driver module initialise error description on failure.
// Return:	MIstatus::success - Functional succeeded.
//			MIstatus::failure - Functional failed.
// Authors:	Aidan Dodds 17/03/2014.
// Changes:	None.
//--
template< typename T >
bool ModuleInit( const MIint vErrorResrcId, bool & vwrbOk, CMIUtilString & vwrErrMsg )
{
	if( vwrbOk && !T::Instance().Initialize() )
	{
		vwrbOk = MIstatus::failure;
		vwrErrMsg = CMIUtilString::Format( MIRSRC( vErrorResrcId ), T::Instance().GetErrorDescription().c_str() );
	}

	return vwrbOk;
}

//++ ============================================================================
// Details:	Short cut helper function to simplify repeated shutodown of
//			MI components (singletons) required by a client module.
// Type:	Template method.
// Args:	vErrorResrcId	- (R)  The string resource ID error message identifier 
//								   to place in errMsg.
//			vwrbOk			- (W)  If not already false make false on module 
//								   shutdown failure.
//			vwrErrMsg		- (RW) Append to existing error description string MI 
//								   driver module initialise error description on 
//								   failure.
// Return:	True - Module shutdown succeeded.
//			False - Module shutdown failed.
// Authors:	Aidan Dodds 17/03/2014.
// Changes:	None.
//--
template< typename T >
bool ModuleShutdown( const MIint vErrorResrcId, bool & vwrbOk, CMIUtilString & vwrErrMsg )
{
	bool bOk = MIstatus::success;

	if( !T::Instance().Shutdown() )
	{
		const bool bMoreThanOneError( !vwrErrMsg.empty() );
		bOk = MIstatus::failure;
		if( bMoreThanOneError )
			vwrErrMsg += ", ";
		vwrErrMsg += CMIUtilString::Format( MIRSRC( vErrorResrcId ), T::Instance().GetErrorDescription().c_str() );
	}
	
	vwrbOk = bOk ? vwrbOk : MIstatus::failure;

	return bOk;
}

} // namespace MI