CRUCAR.H
Upload User: bangxh
Upload Date: 2007-01-31
Package Size: 42235k
Code Size: 6k
Category:

Windows Develop

Development Platform:

Visual C++

  1. /*+==========================================================================
  2.   File:      CRUCAR.H
  3.   Summary:   Include file for the aggregatable COCruiseCar COM object class.
  4.              CRUCAR showcases the construction of the COCruiseCar COM
  5.              object class with the IUnknown, ICar, and ICruise interfaces.
  6.              This is done through Aggregation reuse of a COCar COM
  7.              object (specifically providing its ICar interface features).
  8.              This multiple interface COM Object Class is achieved via
  9.              the technique of nested classes: the implementation of the
  10.              ICar and ICruise interfaces are nested inside of the
  11.              COCruiseCar COM object class.
  12.              For a comprehensive tutorial code tour of this module's
  13.              contents and offerings see the tutorial COMOBJ.HTM
  14.              file.  For more specific technical details on the internal
  15.              workings see the comments dispersed throughout the
  16.              module's source code.
  17.   Classes:   COCruiseCar
  18.   Functions: .
  19.   Origin:    8-21-95: atrent - Editor inheritance from UTILCAR.H.
  20. ----------------------------------------------------------------------------
  21.   This file is part of the Microsoft COM Tutorial Code Samples.
  22.   Copyright (C) Microsoft Corporation, 1997.  All rights reserved.
  23.   This source code is intended only as a supplement to Microsoft
  24.   Development Tools and/or on-line documentation.  See these other
  25.   materials for detailed information regarding Microsoft code samples.
  26.   THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
  27.   KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  28.   IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
  29.   PARTICULAR PURPOSE.
  30. ==========================================================================+*/
  31. #if !defined(CRUCAR_H)
  32. #define CRUCAR_H
  33. #ifdef __cplusplus
  34. /*O+O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O+++O
  35.   ObjectClass: COCruiseCar
  36.   Summary:     COM Object Class for COCruiseCar COM Objects.  COM objects
  37.                of this class augment COCar COM objects (which offer ICar
  38.                interface features of Shift, Clutch, Speed, and Steer) with
  39.                ICruise interface features (Engage and Adjust).  This
  40.                COCruiseCar COM object class is constructed by aggregation
  41.                reuse of the COCar COM object class.  The mulitple
  42.                interfaces on this COM object class are constructed via
  43.                the nested interface classes technique.
  44.   Interfaces:  IUnknown
  45.                  Standard interface providing COM object features.
  46.                ICar
  47.                  Basic Car operation features.
  48.                ICruise
  49.                  Cruise control features.
  50.   Aggregation: Yes, COCruiseCar COM objects are aggregatable by passing
  51.                a non-NULL pUnkOuter IUnknown pointer into the constructor.
  52. O---O---O---O---O---O---O---O---O---O---O---O---O---O---O---O---O---O---O-O*/
  53. class COCruiseCar : public IUnknown
  54. {
  55.   public:
  56.     // Main Object Constructor & Destructor.
  57.     COCruiseCar(IUnknown* pUnkOuter);
  58.     ~COCruiseCar(void);
  59.     // A general public method for initializing this newly created
  60.     // COCruiseCar object. Creates any subordinate arrays, structures, or
  61.     // objects. Not exposed as a method in an interface.
  62.     HRESULT Init(void);
  63.     // IUnknown methods. Main object, non-delegating.
  64.     STDMETHODIMP         QueryInterface(REFIID, PPVOID);
  65.     STDMETHODIMP_(ULONG) AddRef(void);
  66.     STDMETHODIMP_(ULONG) Release(void);
  67.   private:
  68.     // We declare nested class interface implementations here.
  69.     // We implement the ICruise interface (ofcourse) in this COCruiseCar
  70.     // COM object class.  This is the interface that we are using as an
  71.     // augmentation to the existing COCar COM object class.
  72.     class CImpICruise : public ICruise
  73.     {
  74.       public:
  75.         // Interface Implementation Constructor & Destructor.
  76.         CImpICruise(COCruiseCar* pBackObj, IUnknown* pUnkOuter);
  77.         ~CImpICruise(void);
  78.         // IUnknown methods.
  79.         STDMETHODIMP         QueryInterface(REFIID, PPVOID);
  80.         STDMETHODIMP_(ULONG) AddRef(void);
  81.         STDMETHODIMP_(ULONG) Release(void);
  82.         // ICruise methods.
  83.         STDMETHODIMP Engage(BOOL bOnOff);
  84.         STDMETHODIMP Adjust(BOOL bUpDown);
  85.       private:
  86.         // Data private to this interface implementation of ICruise.
  87.         ULONG         m_cRefI;       // Interface Ref Count (for debugging).
  88.         COCruiseCar*  m_pBackObj;    // Parent Object back pointer.
  89.         IUnknown*     m_pUnkOuter;   // Outer unknown for Delegation.
  90.     };
  91.     // Make the otherwise private and nested ICar interface implementation
  92.     // a friend to COM object instantiations of this selfsame COCruiseCar
  93.     // COM object class.
  94.     friend CImpICruise;
  95.     // Private data of COCruiseCar COM objects.
  96.     // Nested ICruise implementation instantiation.  This ICruise interface
  97.     // is implemented inside this COCruiseCar object as a native interface.
  98.     CImpICruise     m_ImpICruise;
  99.     // Main Object reference count.
  100.     ULONG           m_cRefs;
  101.     // Outer unknown (aggregation & delegation). Used when this COCruiseCar
  102.     // object is being aggregated.  Otherwise it is used for delegation
  103.     // if this object is reused via containment.
  104.     IUnknown*       m_pUnkOuter;
  105.     // We need to save the IUnknown interface pointer on the COCar
  106.     // object that we aggregate.  We use this when we need to delegate
  107.     // IUnknown calls to this aggregated inner object.
  108.     IUnknown*       m_pUnkCar;
  109. };
  110. typedef COCruiseCar* PCOCruiseCar;
  111. #endif // __cplusplus
  112. #endif // CRUCAR_H