TypeMut.hxx

Go to the documentation of this file.
00001 #ifndef TYPEMUT_HXX
00002 #define TYPEMUT_HXX
00003 
00004 /**************************************************************************
00005  *
00006  * Copyright (C) 2008, Johns Hopkins University.
00007  * All rights reserved.
00008  *
00009  * Redistribution and use in source and binary forms, with or
00010  * without modification, are permitted provided that the following
00011  * conditions are met:
00012  *
00013  *   - Redistributions of source code must contain the above 
00014  *     copyright notice, this list of conditions, and the following
00015  *     disclaimer. 
00016  *
00017  *   - Redistributions in binary form must reproduce the above
00018  *     copyright notice, this list of conditions, and the following
00019  *     disclaimer in the documentation and/or other materials 
00020  *     provided with the distribution.
00021  *
00022  *   - Neither the names of the copyright holders nor the names of any
00023  *     of any contributors may be used to endorse or promote products
00024  *     derived from this software without specific prior written
00025  *     permission. 
00026  *
00027  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00028  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00029  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
00030  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
00031  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00032  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00033  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00034  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00035  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00036  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00037  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00038  *
00039  **************************************************************************/
00040 
00041 #include <stdlib.h>
00042 #include <dirent.h>
00043 #include <fstream>
00044 #include <iostream>
00045 #include <string>
00046 #include "AST.hxx"
00047 #include "Type.hxx"
00048  
00049 /* Different options for creating type records. These helper
00050    functions are in place so that all maybe-records are created at one
00051    place. Some functions exist so that we can flip copy behaviors in
00052    some cases easily */
00053 
00054  
00055 /* All type-variables are maybe-types by default, 
00056    We use bare tvars in some cases (ex: when the sole purpose of
00057    creating the type variable is unification of the types across all
00058    legs of a datastructure or expression.*/
00059 
00060 static inline boost::shared_ptr<Type> 
00061 newTvar()
00062 {
00063   return Type::make(ty_tvar);
00064 }
00065 
00066 // MBF introduces variability of mutation at the top (outermost) shell
00067 // of a record and also at all fields (recursively) within that record
00068 // up to the ref boundary. This is almost always the one you want.
00069 static inline boost::shared_ptr<Type> 
00070 MBF(boost::shared_ptr<Type> t)
00071 {
00072   return Type::make(ty_mbFull, newTvar(), t->minMutConstless());
00073 }
00074 
00075 // MBT introduces variability of mutation at the top (outermost) shell
00076 // of a record. It says nothing about the mutability of the elements.
00077 static inline boost::shared_ptr<Type> 
00078 MBT(boost::shared_ptr<Type> t)
00079 {
00080   return Type::make(ty_mbTop, newTvar(), t->getBareType());
00081 }
00082 
00083 static inline boost::shared_ptr<Type> 
00084 Mutable(boost::shared_ptr<Type> t)
00085 {
00086   return Type::make(ty_mutable, t->getBareType());
00087 }
00088 
00089 #endif /* TYPEMUT_HXX */

Generated on Thu May 17 23:59:16 2012 for BitC Compiler by  doxygen 1.4.7