• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * ATokPtrImpl.h (formerly ATokPtr.cpp)
3  *
4  * This is #included in ATokBuffer.cpp for historical reasons.
5  * It has been renamed because of problems with the .cpp extension
6  * when used with IDE.
7  *
8  *
9  * ANTLRToken MUST be defined before entry to this file.
10  *
11  * SOFTWARE RIGHTS
12  *
13  * We reserve no LEGAL rights to the Purdue Compiler Construction Tool
14  * Set (PCCTS) -- PCCTS is in the public domain.  An individual or
15  * company may do whatever they wish with source code distributed with
16  * PCCTS or the code generated by PCCTS, including the incorporation of
17  * PCCTS, or its output, into commerical software.
18  *
19  * We encourage users to develop software with PCCTS.  However, we do ask
20  * that credit is given to us for developing PCCTS.  By "credit",
21  * we mean that if you incorporate our source code into one of your
22  * programs (commercial product, research project, or otherwise) that you
23  * acknowledge this fact somewhere in the documentation, research report,
24  * etc...  If you like PCCTS and have developed a nice tool with the
25  * output, please mention that you developed it using PCCTS.  In
26  * addition, we ask that this header remain intact in our source code.
27  * As long as these guidelines are kept, we expect to continue enhancing
28  * this system and expect to make other tools available as they are
29  * completed.
30  *
31  * ANTLR 1.33
32  * Written by Russell Quong June 30, 1995
33  * Adapted by Terence Parr to ANTLR stuff
34  * Parr Research Corporation
35  * with Purdue University and AHPCRC, University of Minnesota
36  * 1989-2000
37  */
38 
39 #include "pcctscfg.h"
40 
41 PCCTS_NAMESPACE_STD
42 
43 #include "ATokPtr.h"
44 
ref()45 void ANTLRTokenPtr::ref() const
46 {
47     if (ptr_ != NULL) {
48 		ptr_->ref();
49 	}
50 }
51 
deref()52 void ANTLRTokenPtr::deref()
53 {
54     if (ptr_ != NULL)
55     {
56 		ptr_->deref();
57 		if ( ptr_->nref()==0 )
58 		{
59 		    delete ptr_;
60 			ptr_ = NULL;
61 		}
62     }
63 }
64 
~ANTLRTokenPtr()65 ANTLRTokenPtr::~ANTLRTokenPtr()
66 {
67     deref();
68 }
69 
70 //
71 //  8-Apr-97	MR1	Make operator -> a const member function
72 //			  as weall as some other member functions
73 //
74 ANTLRTokenPtr& ANTLRTokenPtr::operator = (const ANTLRTokenPtr & lhs)    // MR1
75 {
76     lhs.ref();	// protect against "xp = xp"; ie same underlying object
77     deref();
78     ptr_ = lhs.ptr_;
79     return *this;
80 }
81 
82 ANTLRTokenPtr& ANTLRTokenPtr::operator = (ANTLRAbstractToken *addr)
83 {
84     if (addr != NULL) {
85 	addr->ref();
86     }
87     deref();
88     ptr_ = addr;
89     return *this;
90 }
91