InDesign SDK  20.5
 All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
PMFlavorStream.h
1 //========================================================================================
2 //
3 // $File$
4 //
5 // Owner: Dave Burnard
6 //
7 // $Author$
8 //
9 // $DateTime$
10 //
11 // $Revision$
12 //
13 // $Change$
14 //
15 // Copyright 1997-2010 Adobe Systems Incorporated. All rights reserved.
16 //
17 // NOTICE: Adobe permits you to use, modify, and distribute this file in accordance
18 // with the terms of the Adobe license agreement accompanying it. If you have received
19 // this file from a source other than Adobe, then your use, modification, or
20 // distribution of it requires the prior written permission of Adobe.
21 //
22 //
23 // Provides an accessor class for obtaining and automatically releasing
24 // Read or Write streams from data exchange data objects.
25 //
26 //========================================================================================
27 
28 #ifndef __PMFlavorStream__
29 #define __PMFlavorStream__
30 
31 #include "IPMDataObject.h"
32 #include "PMFlavorTypes.h"
33 
34 class IPMStream;
35 
36 // -------------------------------------------------------------
37 // Class PMFlavorStream
38 // -------------------------------------------------------------
39 enum eFlavorStreamType {kReadFlavorStream = 0, kWriteFlavorStream = 1};
40 
47 {
48  public:
54  PMFlavorStream(IPMDataObject* dataObject, ExternalPMFlavor flavor,
55  eFlavorStreamType type = kReadFlavorStream)
56  : fDataObject(dataObject), fStream(nil)
57  {
58  if (type == kReadFlavorStream)
59  fStream = fDataObject->GetStreamForReading(flavor);
60  else if (type == kWriteFlavorStream)
61  fStream = fDataObject->GetStreamForWriting(flavor);
62  }
63 
66  {
67  if (fStream != nil)
68  fDataObject->FinishedWithStream(fStream);
69  fDataObject = nil;
70  fStream = nil;
71  }
72 
74  operator IPMStream*() { return fStream; }
75  // We allow the cast operator to return a nil pointer
76  // since it is valid to test against nil and may be valid
77  // to pass a nil pointer to some methods.
78 
81  {
82  #ifdef DEBUG
83  ASSERT_MSG(fStream != nil,"About to use nil PMFlavorStream!");
84  #endif
85  return fStream;
86  }
87 
88  private:
89  IPMDataObject* fDataObject;
90  IPMStream * fStream;
91 };
92 
93 #endif