STLSoft - ... Robust, Lightweight, Cross-platform, Template Software ... ATLSTL - Template Software for the Active Template Library COMSTL - The Standard Template Library meets the Component Object Model .netSTL - Standard Template Library meets the Microsoft.NET Common Language Runtime InetSTL - The Standard Template Library meets WinInet MFCSTL - Template Software for the Microsoft Foundation Classes UNIXSTL - Template Software for the UNIX Operating System WinSTL - where the Standard Template Library meets the Win32 API

Main Page   Modules   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

comstl_refcount_functions.h

Go to the documentation of this file.
00001 /* 
00002  * File:        comstl_refcount_functions.h
00003  *
00004  * Purpose:     Reference-counting helper functions.
00005  *
00006  * Created:
00007  * Updated:     11th September 2004
00008  *
00009  * Home:        http://stlsoft.org/
00010  *
00011  * Copyright (c) 2002-2004, Matthew Wilson and Synesis Software
00012  * All rights reserved.
00013  *
00014  * Redistribution and use in source and binary forms, with or without
00015  * modification, are permitted provided that the following conditions are met:
00016  *
00017  * - Redistributions of source code must retain the above copyright notice, this
00018  *   list of conditions and the following disclaimer.
00019  * - Redistributions in binary form must reproduce the above copyright notice,
00020  *   this list of conditions and the following disclaimer in the documentation
00021  *   and/or other materials provided with the distribution.
00022  * - Neither the name(s) of Matthew Wilson and Synesis Software nor the names of
00023  *   any contributors may be used to endorse or promote products derived from
00024  *   this software without specific prior written permission.
00025  *
00026  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00027  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00028  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00029  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
00030  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00031  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00032  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00033  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00034  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00035  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00036  * POSSIBILITY OF SUCH DAMAGE.
00037  *
00038  * 
00039 
00040 
00044 
00045 #ifndef COMSTL_INCL_H_COMSTL_REFCOUNT_FUNCTIONS
00046 #define COMSTL_INCL_H_COMSTL_REFCOUNT_FUNCTIONS
00047 
00048 #ifndef __STLSOFT_DOCUMENTATION_SKIP_SECTION
00049 # define COMSTL_VER_H_COMSTL_REFCOUNT_FUNCTIONS_MAJOR       2
00050 # define COMSTL_VER_H_COMSTL_REFCOUNT_FUNCTIONS_MINOR       0
00051 # define COMSTL_VER_H_COMSTL_REFCOUNT_FUNCTIONS_REVISION    1
00052 # define COMSTL_VER_H_COMSTL_REFCOUNT_FUNCTIONS_EDIT        30
00053 #endif /* !__STLSOFT_DOCUMENTATION_SKIP_SECTION */
00054 
00055 /* 
00056  * Includes
00057  */
00058 
00059 #ifndef COMSTL_INCL_H_COMSTL
00060 # include "comstl.h"    // Include the COMSTL root header
00061 #endif /* !COMSTL_INCL_H_COMSTL */
00062 
00063 /* 
00064  * Namespace
00065  *
00066  * The COMSTL components are contained within the comstl namespace. This is
00067  * actually an alias for stlsoft::comstl_project,
00068  *
00069  * The definition matrix is as follows:
00070  *
00071  * _STLSOFT_NO_NAMESPACE    _COMSTL_NO_NAMESPACE    comstl definition
00072  * ---------------------    --------------------    -----------------
00073  *  not defined              not defined             = stlsoft::comstl_project
00074  *  not defined              defined                 not defined
00075  *  defined                  not defined             comstl
00076  *  defined                  defined                 not defined
00077  *
00078  */
00079 
00080 #ifndef _COMSTL_NO_NAMESPACE
00081 # if defined(_STLSOFT_NO_NAMESPACE) || \
00082      defined(__STLSOFT_DOCUMENTATION_SKIP_SECTION)
00083 /* There is no stlsoft namespace, so must define ::comstl */
00084 namespace comstl
00085 {
00086 # else
00087 /* Define stlsoft::comstl_project */
00088 
00089 namespace stlsoft
00090 {
00091 
00092 namespace comstl_project
00093 {
00094 
00095 # endif /* _STLSOFT_NO_NAMESPACE */
00096 #endif /* !_COMSTL_NO_NAMESPACE */
00097 
00098 /* 
00099 
00104 
00105 /* 
00106  * Functions
00107  */
00108 
00112 inline void addref(LPUNKNOWN punk)
00113 {
00114     punk->AddRef();
00115 }
00116 
00120 inline void release(LPUNKNOWN punk)
00121 {
00122     punk->Release();
00123 }
00124 
00128 inline void safe_addref(LPUNKNOWN punk)
00129 {
00130     if(0 != punk)
00131     {
00132         addref(punk);
00133     }
00134 }
00135 
00139 inline void safe_release(LPUNKNOWN punk)
00140 {
00141     if(0 != punk)
00142     {
00143         release(punk);
00144     }
00145 }
00146 
00150 template <ss_typename_param_k T>
00151 inline void release_set_null(T *&pt)
00152 {
00153     if(0 != pt)
00154     {
00155         release(pt);
00156         pt = 0;
00157     }
00158 }
00159 
00161 // Unit-testing
00162 
00163 #ifdef STLSOFT_UNITTEST
00164 
00165 namespace unittest
00166 {
00167     ss_bool_t test_comstl_refcount_functions(unittest_reporter *r)
00168     {
00169         using stlsoft::unittest::unittest_initialiser;
00170 
00171         ss_bool_t               bSuccess    =   true;
00172 
00173         unittest_initialiser    init(r, "COMSTL", "refcount_functions", __FILE__);
00174 
00175 #if 0
00176         if(<<TODO>>)
00177         {
00178             r->report("<<TODO>> failed ", __LINE__);
00179             bSuccess = false;
00180         }
00181 #endif /* 0 */
00182 
00183         return bSuccess;
00184     }
00185 
00186     unittest_registrar    unittest_comstl_refcount_functions(test_comstl_refcount_functions);
00187 
00188 } // namespace unittest
00189 
00190 #endif /* STLSOFT_UNITTEST */
00191 
00192 /* 
00193 
00195 
00196 /* 
00197 
00198 #ifndef _COMSTL_NO_NAMESPACE
00199 # if defined(_STLSOFT_NO_NAMESPACE) || \
00200      defined(__STLSOFT_DOCUMENTATION_SKIP_SECTION)
00201 } // namespace comstl
00202 # else
00203 } // namespace comstl_project
00204 } // namespace stlsoft
00205 # endif /* _STLSOFT_NO_NAMESPACE */
00206 #endif /* !_COMSTL_NO_NAMESPACE */
00207 
00208 /* 
00209 
00210 #endif /* !COMSTL_INCL_H_COMSTL_REFCOUNT_FUNCTIONS */
00211 
00212 /* 

STLSoft Libraries documentation © Synesis Software Pty Ltd, 2001-2004