You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							160 lines
						
					
					
						
							5.6 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							160 lines
						
					
					
						
							5.6 KiB
						
					
					
				
								/* /////////////////////////////////////////////////////////////////////////
							 | 
						|
								 * File:        pantheios/severity/levels.hpp
							 | 
						|
								 *
							 | 
						|
								 * Purpose:     Definition of the pantheios::level class template, which may
							 | 
						|
								 *              be used to generate levels pseudo-constants.
							 | 
						|
								 *
							 | 
						|
								 * Created:     22nd July 2006
							 | 
						|
								 * Updated:     23rd July 2010
							 | 
						|
								 *
							 | 
						|
								 * Home:        http://www.pantheios.org/
							 | 
						|
								 *
							 | 
						|
								 * Copyright (c) 2006-2010, Matthew Wilson and Synesis Software
							 | 
						|
								 * All rights reserved.
							 | 
						|
								 *
							 | 
						|
								 * Redistribution and use in source and binary forms, with or without
							 | 
						|
								 * modification, are permitted provided that the following conditions are
							 | 
						|
								 * met:
							 | 
						|
								 *
							 | 
						|
								 * - Redistributions of source code must retain the above copyright notice,
							 | 
						|
								 *   this list of conditions and the following disclaimer.
							 | 
						|
								 * - Redistributions in binary form must reproduce the above copyright
							 | 
						|
								 *   notice, this list of conditions and the following disclaimer in the
							 | 
						|
								 *   documentation and/or other materials provided with the distribution.
							 | 
						|
								 * - Neither the name(s) of Matthew Wilson and Synesis Software nor the
							 | 
						|
								 *   names of any contributors may be used to endorse or promote products
							 | 
						|
								 *   derived from this software without specific prior written permission.
							 | 
						|
								 *
							 | 
						|
								 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
							 | 
						|
								 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
							 | 
						|
								 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
							 | 
						|
								 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
							 | 
						|
								 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
							 | 
						|
								 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
							 | 
						|
								 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
							 | 
						|
								 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
							 | 
						|
								 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
							 | 
						|
								 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
							 | 
						|
								 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
							 | 
						|
								 *
							 | 
						|
								 * ////////////////////////////////////////////////////////////////////// */
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								/** \file pantheios/severity/levels.hpp
							 | 
						|
								 *
							 | 
						|
								 * [C++ only] Definition of the pantheios::level class template, which can
							 | 
						|
								 *   be used to generate levels pseudo-constants.
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								#ifndef PANTHEIOS_INCL_PANTHEIOS_SEVERITY_HPP_LEVELS
							 | 
						|
								#define PANTHEIOS_INCL_PANTHEIOS_SEVERITY_HPP_LEVELS
							 | 
						|
								
							 | 
						|
								/* /////////////////////////////////////////////////////////////////////////
							 | 
						|
								 * Version information
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								#ifndef PANTHEIOS_DOCUMENTATION_SKIP_SECTION
							 | 
						|
								# define PANTHEIOS_VER_PANTHEIOS_SEVERITY_HPP_LEVELS_MAJOR      2
							 | 
						|
								# define PANTHEIOS_VER_PANTHEIOS_SEVERITY_HPP_LEVELS_MINOR      0
							 | 
						|
								# define PANTHEIOS_VER_PANTHEIOS_SEVERITY_HPP_LEVELS_REVISION   2
							 | 
						|
								# define PANTHEIOS_VER_PANTHEIOS_SEVERITY_HPP_LEVELS_EDIT       23
							 | 
						|
								#endif /* !PANTHEIOS_DOCUMENTATION_SKIP_SECTION */
							 | 
						|
								
							 | 
						|
								/* /////////////////////////////////////////////////////////////////////////
							 | 
						|
								 * Includes
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								#ifndef PANTHEIOS_INCL_PANTHEIOS_H_PANTHEIOS
							 | 
						|
								# include <pantheios/pantheios.h>
							 | 
						|
								#endif /* !PANTHEIOS_INCL_PANTHEIOS_H_PANTHEIOS */
							 | 
						|
								#ifndef PANTHEIOS_INCL_PANTHEIOS_QUALITY_H_CONTRACT
							 | 
						|
								# include <pantheios/quality/contract.h>
							 | 
						|
								#endif /* !PANTHEIOS_INCL_PANTHEIOS_QUALITY_H_CONTRACT */
							 | 
						|
								
							 | 
						|
								/* /////////////////////////////////////////////////////////////////////////
							 | 
						|
								 * Namespace
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								#if !defined(PANTHEIOS_NO_NAMESPACE)
							 | 
						|
								namespace pantheios
							 | 
						|
								{
							 | 
						|
								#endif /* !PANTHEIOS_NO_NAMESPACE */
							 | 
						|
								
							 | 
						|
								/* /////////////////////////////////////////////////////////////////////////
							 | 
						|
								 * Classes
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								/** Class that acts as an integer value - indicating a severity
							 | 
						|
								 *   level - but which also facilitates the provision of 28-bits of
							 | 
						|
								 *   extended severity information.
							 | 
						|
								 *
							 | 
						|
								 * In normal use, the levels instances - pantheios::debug,
							 | 
						|
								 * pantheios::informational ... pantheios::emergency - can be used in the
							 | 
						|
								 * place of the pan_severity_t enumerators.
							 | 
						|
								 *
							 | 
						|
								 * \warning The levels values must not be used in the definition of a
							 | 
						|
								 *   front-end or back-end. This is because the levels values are static
							 | 
						|
								 *   instances, and will likely be in a race with the API Schwarz counter
							 | 
						|
								 *   (static) initialiser instances. It is likely that using one of the
							 | 
						|
								 *   levels values in that case will yield the value 0.
							 | 
						|
								 */
							 | 
						|
								template <int Level>
							 | 
						|
								class level
							 | 
						|
								{
							 | 
						|
								/// \name Member Types
							 | 
						|
								/// @{
							 | 
						|
								public:
							 | 
						|
								    typedef level<Level>    class_type;
							 | 
						|
								/// @}
							 | 
						|
								
							 | 
						|
								/// \name Construction
							 | 
						|
								/// @{
							 | 
						|
								public:
							 | 
						|
								    level()
							 | 
						|
								    {}
							 | 
						|
								/// @}
							 | 
						|
								
							 | 
						|
								/// \name Operators
							 | 
						|
								/// @{
							 | 
						|
								public:
							 | 
						|
								    /// Implicit conversion to the underlying level value
							 | 
						|
								    operator pan_sev_t () const
							 | 
						|
								    {
							 | 
						|
								        return Level;
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    /// Function-call operator that allows extended severity information
							 | 
						|
								    /// to be provided to the front-/back-ends
							 | 
						|
								    ///
							 | 
						|
								    /// \param extendedSeverityInformation28 28-bits of extended
							 | 
						|
								    ///   information to be included in the
							 | 
						|
								    ///
							 | 
						|
								    /// \pre 0 == (extendedSeverityInformation28 & ~0xf0000000)
							 | 
						|
								    pan_sev_t operator ()(pan_sev_t extendedSeverityInformation28) const
							 | 
						|
								    {
							 | 
						|
								        PANTHEIOS_CONTRACT_ENFORCE_PRECONDITION_PARAMS_APPL_LAYER(extendedSeverityInformation28 < 0x10000000, "Extended severity information is limited to 28-bits");
							 | 
						|
								
							 | 
						|
								        return (Level & 0x0f) | ((extendedSeverityInformation28 << 4) & ~0x0f);
							 | 
						|
								    }
							 | 
						|
								/// @}
							 | 
						|
								
							 | 
						|
								/// \name Not to be implemented
							 | 
						|
								/// @{
							 | 
						|
								private:
							 | 
						|
								    class_type& operator =(class_type const&);
							 | 
						|
								/// @}
							 | 
						|
								};
							 | 
						|
								
							 | 
						|
								/* /////////////////////////////////////////////////////////////////////////
							 | 
						|
								 * Namespace
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								#if !defined(PANTHEIOS_NO_NAMESPACE)
							 | 
						|
								} /* namespace pantheios */
							 | 
						|
								#endif /* !PANTHEIOS_NO_NAMESPACE */
							 | 
						|
								
							 | 
						|
								/* ////////////////////////////////////////////////////////////////////// */
							 | 
						|
								
							 | 
						|
								#endif /* !PANTHEIOS_INCL_PANTHEIOS_SEVERITY_HPP_LEVELS */
							 | 
						|
								
							 | 
						|
								/* ///////////////////////////// end of file //////////////////////////// */
							 |