File: MIUtilSingletonHelper.h

package info (click to toggle)
llvm-toolchain-3.5 1%3A3.5-10
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 282,028 kB
  • ctags: 310,872
  • sloc: cpp: 1,883,926; ansic: 310,731; objc: 86,612; python: 79,565; asm: 65,844; sh: 9,829; makefile: 6,057; perl: 5,589; ml: 5,254; pascal: 3,285; lisp: 1,640; xml: 686; cs: 239; csh: 117
file content (94 lines) | stat: -rw-r--r-- 3,176 bytes parent folder | download | duplicates (2)
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
//===-- 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