Skip to content
  • Richard Smith's avatar
    Teach Expr::HasSideEffects about all the Expr types, and fix a bug where it · 0421ce7b
    Richard Smith authored
    was mistakenly classifying dynamic_casts which might throw as having no side
    effects.
    
    Switch it from a visitor to a switch, so it is kept up-to-date as future Expr
    nodes are added. Move it from ExprConstant.cpp to Expr.cpp, since it's not
    really related to constant expression evaluation.
    
    Since we use HasSideEffect to determine whether to emit an unused global with
    internal linkage, this has the effect of suppressing emission of globals in
    some cases.
    
    I've left many of the Objective-C cases conservatively assuming that the
    expression has side-effects. I'll leave it to someone with better knowledge
    of Objective-C than mine to improve them.
    
    llvm-svn: 161388
    0421ce7b
Loading