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

ref_clone_changer.h

Go to the documentation of this file.
00001 // ----------------------------------------------------------------------
00002 //
00003 //  C-Breeze
00004 //  C Compiler Framework
00005 // 
00006 //  Copyright (c) 2000 University of Texas at Austin
00007 // 
00008 //  Samuel Z. Guyer
00009 //  Daniel A. Jimenez
00010 //  Calvin Lin
00011 // 
00012 //  Permission is hereby granted, free of charge, to any person
00013 //  obtaining a copy of this software and associated documentation
00014 //  files (the "Software"), to deal in the Software without
00015 //  restriction, including without limitation the rights to use, copy,
00016 //  modify, merge, publish, distribute, sublicense, and/or sell copies
00017 //  of the Software, and to permit persons to whom the Software is
00018 //  furnished to do so, subject to the following conditions:
00019 //  
00020 //  The above copyright notice and this permission notice shall be
00021 //  included in all copies or substantial portions of the Software.
00022 //  
00023 //  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
00024 //  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
00025 //  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
00026 //  NONINFRINGEMENT.  IN NO EVENT SHALL THE UNIVERSITY OF TEXAS AT
00027 //  AUSTIN BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
00028 //  IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
00029 //  OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
00030 //  THE SOFTWARE.
00031 //
00032 //  We acknowledge the C-to-C Translator from MIT Laboratory for
00033 //  Computer Science for inspiring parts of the C-Breeze design.
00034 //
00035 // ----------------------------------------------------------------------
00036 
00037 #ifndef CBZ_REF_CLONE_CHANGER_H
00038 #define CBZ_REF_CLONE_CHANGER_H
00039 
00040 
00041 typedef map< Node *,
00042              Node *,
00043              less< Node * > > node_map;
00044 
00045 typedef node_map::iterator node_map_p;
00046 
00047 class ref_clone_changer : public Changer
00048 {
00049 public:
00050 
00051   static Node * clone(Node * n, bool nil_bad_links);
00052 
00053 private:
00054 
00055   node_map * _map;
00056 
00057 public:
00058 
00059   ref_clone_changer()
00060     : Changer(Preorder, Subtree, false),
00061       _map(new node_map())
00062   {}
00063 
00064   node_map * map() const { return _map; }
00065 
00066   Node * at_node(Node * the_node, Order ord)
00067   {
00068     Node * newnode =  the_node->clone();
00069     (*_map)[the_node] = newnode;
00070     return newnode;
00071   }
00072 
00073   
00074 };
00075 
00076 class ref_fix_walker : public Walker
00077 {
00078 private:
00079 
00080   node_map * _map;
00081   bool _nil_bad_links;
00082 
00083   Node * lookup(Node * old);
00084 
00085 public:
00086 
00087   ref_fix_walker(node_map * m, bool nil_bad_links)
00088     : Walker(Preorder, Subtree),
00089       _map(m),
00090       _nil_bad_links(nil_bad_links)
00091   {}
00092 
00093   virtual void at_tdef(tdefNode * the_tdef, Order ord);
00094   virtual void at_id(idNode * the_id, Order ord);
00095   virtual void at_call(callNode * the_call, Order ord);
00096   virtual void at_label(labelNode * the_label, Order ord);
00097   virtual void at_case(caseNode * the_case, Order ord);
00098   virtual void at_switch(switchNode * the_switch, Order ord);
00099   virtual void at_goto(gotoNode * the_goto, Order ord);
00100   virtual void at_continue(continueNode * the_continue, Order ord);
00101   virtual void at_break(breakNode * the_break, Order ord);
00102   virtual void at_return(returnNode * the_return, Order ord);
00103 };
00104 
00105 
00106 #endif // CBZ_REF_CLONE_CHANGER_H

Generated on Thu Jan 10 12:06:20 2002 for C-Breeze by doxygen1.2.13.1 written by Dimitri van Heesch, © 1997-2001