Compiler projects using llvm
; This testcase checks to make sure that we can write PDB files.  It
; works by first reading a known good PDB file and dumping the contents
; to YAML.  Then it tries to reconstruct as much of the original PDB as
; possible, although depending on what flags are specified when generating
; the YAML, the PDB might be missing data required for any standard tool
; to recognize it.  Finally, it dumps the same set of fields from the newly
; constructed PDB to YAML, and verifies that the YAML is the same as the
; original YAML generated from the good PDB.  Note that when doing the
; final comparison it must dump the original and the new pdb without any
; stream metadata, since the layout of the MSF file might be different
; (for example if we don't write the entire stream)
;
; RUN: llvm-pdbutil pdb2yaml -stream-metadata -stream-directory \
; RUN:   -pdb-stream -tpi-stream -module-syms %p/Inputs/empty.pdb > %t.1
; RUN: llvm-pdbutil yaml2pdb -pdb=%t.2 %t.1
; RUN: llvm-pdbutil pdb2yaml -pdb-stream -tpi-stream \
; RUN:   -module-syms -no-file-headers %p/Inputs/empty.pdb > %t.3
; RUN: llvm-pdbutil pdb2yaml -pdb-stream -tpi-stream \
; RUN:   -module-syms -no-file-headers %t.2 > %t.4
; RUN: diff %t.3 %t.4