[llvm-commits] CVS: llvm/lib/AsmParser/llvmAsmParser.y

Reid Spencer rspencer at reidspencer.com
Fri Dec 8 10:29:11 PST 2006


Andrew,

It looks like you haven't accounted for global constants of packed
structure type here. 

Reid.

On Fri, 2006-12-08 at 12:07 -0600, Andrew Lenharth wrote:
> 
> Changes in directory llvm/lib/AsmParser:
> 
> llvmAsmParser.y updated: 1.288 -> 1.289
> ---
> Log message:
> 
> Packed Structures
> 
> ---
> Diffs of the changes:  (+14 -0)
> 
>  llvmAsmParser.y |   14 ++++++++++++++
>  1 files changed, 14 insertions(+)
> 
> 
> Index: llvm/lib/AsmParser/llvmAsmParser.y
> diff -u llvm/lib/AsmParser/llvmAsmParser.y:1.288 llvm/lib/AsmParser/llvmAsmParser.y:1.289
> --- llvm/lib/AsmParser/llvmAsmParser.y:1.288	Wed Dec  6 19:30:31 2006
> +++ llvm/lib/AsmParser/llvmAsmParser.y	Fri Dec  8 12:06:15 2006
> @@ -1209,6 +1209,20 @@
>      $$ = new PATypeHolder(StructType::get(std::vector<const Type*>()));
>      CHECK_FOR_ERROR
>    }
> +  | '<' '{' TypeListI '}' '>' {
> +    std::vector<const Type*> Elements;
> +    for (std::list<llvm::PATypeHolder>::iterator I = $3->begin(),
> +           E = $3->end(); I != E; ++I)
> +      Elements.push_back(*I);
> +
> +    $$ = new PATypeHolder(HandleUpRefs(StructType::get(Elements, true)));
> +    delete $3;
> +    CHECK_FOR_ERROR
> +  }
> +  | '<' '{' '}' '>' {                         // Empty structure type?
> +    $$ = new PATypeHolder(StructType::get(std::vector<const Type*>(), true));
> +    CHECK_FOR_ERROR
> +  }
>    | UpRTypes '*' {                             // Pointer type?
>      if (*$1 == Type::LabelTy)
>        GEN_ERROR("Cannot form a pointer to a basic block");
> 
> 
> 
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits




More information about the llvm-commits mailing list