Changeset 800bae1
- Timestamp:
- Jun 17, 2019, 3:37:00 PM (6 years ago)
- Branches:
- ADT, arm-eh, ast-experimental, enum, forall-pointer-decay, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, pthread-emulation, qualifiedEnum
- Children:
- 54b3fde, 6e55240
- Parents:
- 89faa82 (diff), aba20d2 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - Files:
-
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
configure
r89faa82 r800bae1 796 796 with_cfa_name 797 797 with_target_hosts 798 enable_gprofiler 798 799 enable_dependency_tracking 799 800 enable_shared … … 1455 1456 --enable-silent-rules less verbose build output (undo: "make V=1") 1456 1457 --disable-silent-rules verbose build output (undo: "make V=0") 1458 --enable-gprofiler whether or not to enable gprofiler tools (if available) 1457 1459 --enable-dependency-tracking 1458 1460 do not reject slow dependency extractors … … 3283 3285 \'--with-target-hosts=*) ;; 3284 3286 3287 # skip gprofiler for libcfa 3288 \'--enable-gprofiler=*) ;; 3289 \'--disable-gprofiler) ;; 3290 3285 3291 # append all other arguments to the sub configure arguments 3286 3292 *) LIBCFA_GENERAL_ARGS="${LIBCFA_GENERAL_ARGS} $var";; … … 3384 3390 else 3385 3391 target_hosts=${default_target} 3392 fi 3393 3394 3395 # Check whether --enable-gprofiler was given. 3396 if test "${enable_gprofiler+set}" = set; then : 3397 enableval=$enable_gprofiler; enable_gprofiler=$enableval 3398 else 3399 enable_gprofiler=yes 3386 3400 fi 3387 3401 … … 16704 16718 fi 16705 16719 16706 if test " $HAVE_LIBPROFILER" -eq 1; then16720 if test "x$enable_gprofiler" = "xyes" -a "$HAVE_LIBPROFILER" -eq 1; then 16707 16721 WITH_LIBPROFILER_TRUE= 16708 16722 WITH_LIBPROFILER_FALSE='#' … … 16755 16769 fi 16756 16770 16757 if test " $HAVE_LIBTCMALLOC" -eq 1; then16771 if test "x$enable_gprofiler" = "xyes" -a "$HAVE_LIBTCMALLOC" -eq 1; then 16758 16772 WITH_LIBTCMALLOC_TRUE= 16759 16773 WITH_LIBTCMALLOC_FALSE='#' -
configure.ac
r89faa82 r800bae1 94 94 # skip the target hosts 95 95 \'--with-target-hosts=*) ;; 96 97 # skip gprofiler for libcfa 98 \'--enable-gprofiler=*) ;; 99 \'--disable-gprofiler) ;; 96 100 97 101 # append all other arguments to the sub configure arguments … … 125 129 target_hosts=$withval, target_hosts=${default_target}) 126 130 131 AC_ARG_ENABLE(gprofiler, 132 [ --enable-gprofiler whether or not to enable gprofiler tools (if available)], 133 enable_gprofiler=$enableval, enable_gprofiler=yes) 134 127 135 AC_SUBST(TARGET_HOSTS, ${target_hosts}) 128 136 … … 192 200 193 201 AC_CHECK_LIB([profiler], [ProfilingIsEnabledForAllThreads], [HAVE_LIBPROFILER=1], [HAVE_LIBPROFILER=0]) 194 AM_CONDITIONAL([WITH_LIBPROFILER], [test " $HAVE_LIBPROFILER" -eq 1])202 AM_CONDITIONAL([WITH_LIBPROFILER], [test "x$enable_gprofiler" = "xyes" -a "$HAVE_LIBPROFILER" -eq 1]) 195 203 196 204 AC_CHECK_LIB([tcmalloc], [malloc], [HAVE_LIBTCMALLOC=1], [HAVE_LIBTCMALLOC=0]) 197 AM_CONDITIONAL([WITH_LIBTCMALLOC], [test " $HAVE_LIBTCMALLOC" -eq 1])205 AM_CONDITIONAL([WITH_LIBTCMALLOC], [test "x$enable_gprofiler" = "xyes" -a "$HAVE_LIBTCMALLOC" -eq 1]) 198 206 199 207 # Checks for header files. -
src/AST/Convert.cpp
r89faa82 r800bae1 576 576 if ( srcInferred.mode == ast::Expr::InferUnion::Params ) { 577 577 const ast::InferredParams &srcParams = srcInferred.inferParams(); 578 for (auto srcParam : srcParams) {579 tgtInferParams[srcParam.first] =ParamEntry(578 for (auto & srcParam : srcParams) { 579 auto res = tgtInferParams.emplace(srcParam.first, ParamEntry( 580 580 srcParam.second.decl, 581 581 get<Declaration>().accept1(srcParam.second.declptr), … … 583 583 get<Type>().accept1(srcParam.second.formalType), 584 584 get<Expression>().accept1(srcParam.second.expr) 585 ); 585 )); 586 assert(res.second); 586 587 } 587 588 } else if ( srcInferred.mode == ast::Expr::InferUnion::Slots ) { … … 1982 1983 if ( !oldInferParams.empty() ) { 1983 1984 ast::InferredParams &tgt = newInferred.inferParams(); 1984 for (auto old : oldInferParams) {1985 for (auto & old : oldInferParams) { 1985 1986 tgt[old.first] = ast::ParamEntry( 1986 1987 old.second.decl, -
src/Common/Stats/Heap.cc
r89faa82 r800bae1 21 21 #include <iostream> 22 22 23 #if defined( NO_STATISTICS ) || defined( TCMALLOC ) 24 #define NO_HEAP_STATISTICS 23 #if defined(__has_feature) 24 #if __has_feature(address_sanitizer) 25 #define NO_HEAP_STATISTICS 26 # endif 27 #endif 28 29 #if defined( NO_STATISTICS ) || defined( TCMALLOC ) || defined(__SANITIZE_ADDRESS__) 30 #if !defined(NO_HEAP_STATISTICS) 31 #define NO_HEAP_STATISTICS 32 #endif 25 33 #endif 26 34 -
src/ResolvExpr/ResolveAssertions.cc
r89faa82 r800bae1 325 325 entry.second.expr = postmutate( entry.second.expr ); 326 326 // xxx - look at entry.second.inferParams? 327 expr->inferParams[ entry.first ] = entry.second; 327 auto res = expr->inferParams.emplace( entry.first, entry.second ); 328 assert(res.second); 328 329 } 329 330 } -
src/SynTree/ApplicationExpr.cc
r89faa82 r800bae1 28 28 #include "Type.h" // for Type, PointerType, FunctionType 29 29 30 ParamEntry::ParamEntry( UniqueId decl, Declaration * declptr, Type * actualType, Type * formalType, Expression* expr ) 31 : decl( decl ), declptr( declptr ), actualType( actualType ), formalType( formalType ), expr( expr ) { 32 } 33 30 34 ParamEntry::ParamEntry( const ParamEntry &other ) : 31 decl( other.decl ), declptr( maybeClone( other.declptr ) ), actualType( maybeClone( other.actualType ) ), formalType( maybeClone( other.formalType ) ), expr( maybeClone( other.expr ) )/*, inferParams( new InferredParams( *other.inferParams ) )*/ { 32 } 33 34 ParamEntry &ParamEntry::operator=( const ParamEntry &other ) { 35 if ( &other == this ) return *this; 36 const_cast<UniqueId &>(decl) = other.decl; 37 const_cast<Declaration * &>(declptr) = maybeClone( other.declptr ); 38 // xxx - this looks like a memory leak 39 const_cast<Type * &>(actualType) = maybeClone( other.actualType ); 40 const_cast<Type * &>(formalType) = maybeClone( other.formalType ); 41 expr = maybeClone( other.expr ); 42 // *inferParams = *other.inferParams; 43 return *this; 35 decl( other.decl ), declptr( maybeClone( other.declptr ) ), actualType( maybeClone( other.actualType ) ), formalType( maybeClone( other.formalType ) ), expr( maybeClone( other.expr ) ) { 44 36 } 45 37 … … 52 44 53 45 ParamEntry::ParamEntry( ParamEntry && other ) : 54 decl( other.decl ), declptr( other.declptr ), actualType( other.actualType ), formalType( other.formalType ), expr( other.expr )/*, inferParams( std::move( other.inferParams ) )*/ { 55 const_cast<Declaration * &>(other.declptr) = nullptr; 56 const_cast<Type * &>(other.actualType) = nullptr; 57 const_cast<Type * &>(other.formalType) = nullptr; 58 other.expr = nullptr; 46 decl( other.decl ), declptr( other.declptr ), actualType( other.actualType ), formalType( other.formalType ), expr( other.expr ) { 47 new (&other) ParamEntry(); 59 48 } 60 49 61 50 ParamEntry & ParamEntry::operator=( ParamEntry && other ) { 62 51 if ( &other == this ) return *this; 63 delete declptr; 64 delete actualType; 65 delete formalType; 66 delete expr; 67 const_cast<UniqueId &>(decl) = other.decl; 68 const_cast<Declaration * &>(declptr) = other.declptr; 69 const_cast<Type * &>(actualType) = other.actualType; 70 const_cast<Type * &>(formalType) = other.formalType; 71 expr = other.expr; 72 const_cast<Declaration * &>(other.declptr) = nullptr; 73 const_cast<Type * &>(other.actualType) = nullptr; 74 const_cast<Type * &>(other.formalType) = nullptr; 75 other.expr = nullptr; 76 // inferParams = std::move( other.inferParams ); 52 this->~ParamEntry(); 53 new (this) ParamEntry(other.decl, other.declptr, other.actualType, other.formalType, other.expr); 54 new (&other) ParamEntry(); 55 77 56 return *this; 78 57 } -
src/SynTree/Expression.h
r89faa82 r800bae1 39 39 /// but subject to decay-to-pointer and type parameter renaming 40 40 struct ParamEntry { 41 ParamEntry(): decl( 0 ), declptr(nullptr), actualType( 0 ), formalType( 0 ), expr( 0 )/*, inferParams( new InferredParams )*/ {} 42 ParamEntry( UniqueId decl, Declaration * declptr, Type * actualType, Type * formalType, Expression* expr ) 43 : decl( decl ), declptr( declptr ), actualType( actualType ), formalType( formalType ), expr( expr )/*, inferParams( new InferredParams )*/ { 44 } 41 ParamEntry(): decl( 0 ), declptr( nullptr ), actualType( nullptr ), formalType( nullptr ), expr( nullptr ) {} 42 ParamEntry( UniqueId decl, Declaration * declptr, Type * actualType, Type * formalType, Expression* expr ); 45 43 ParamEntry( const ParamEntry & other ); 46 44 ParamEntry( ParamEntry && other ); 47 45 ~ParamEntry(); 48 ParamEntry & operator=( const ParamEntry & other );49 46 ParamEntry & operator=( ParamEntry && other ); 50 47 … … 54 51 Type * const formalType; 55 52 Expression * expr; 56 // std::unique_ptr< InferredParams > inferParams;57 53 }; 58 54
Note: See TracChangeset
for help on using the changeset viewer.