Modules: Do not serialize #pragma pack state
authorDuncan P. N. Exon Smith <dexonsmith@apple.com>
Sat, 15 Apr 2017 00:07:57 +0000 (00:07 +0000)
committerDuncan P. N. Exon Smith <dexonsmith@apple.com>
Sat, 15 Apr 2017 00:07:57 +0000 (00:07 +0000)
commit03df14c6dd2ae36b04d0a085ae9fa69aad8193ab
treed940bdde9086e4bb1732b2f3774825d870b2697a
parent044f956f9af8b8f4c8a2ccf5dde5cd48d34a5721
Modules: Do not serialize #pragma pack state

The modules side of r299226, which serializes #pragma pack state,
doesn't work well.

The main purpose was to make -include and -include-pch match semantics
(the PCH side).  We also started serializing #pragma pack in PCMs, in
the hopes of making modules and non-modules builds more consistent.  But
consider:

    $ cat a.h
    $ cat b.h
    #pragma pack(push, 2)
    $ cat module.modulemap
    module M {
        module a { header "a.h" }
        module b { header "b.h" }
    }
    $ cat t.cpp
    #include "a.h"
    #pragma pack(show)

As of r299226, the #pragma pack(show) gives "2", even though we've only
included "a.h".

- With -fmodules-local-submodule-visibility, this is clearly wrong.  We
  should get the default state (8 on x86_64).

- Without -fmodules-local-submodule-visibility, this kind of matches how
  other things work (as if include-the-whole-module), but it's still
  really terrible, and it doesn't actually make modules and non-modules
  builds more consistent.

This commit disables the serialization for modules, essentially a
partial revert of r299226.

Going forward:

 1. Having this #pragma pack stuff escape is terrible design (or, more
    often, a horrible bug).  We should prioritize adding warnings (maybe
    -Werror by default?).

 2. If we eventually reintroduce this for modules, it should only apply
    to -fmodules-local-submodule-visibility, and it should be tracked on
    a per-submodule basis.

llvm-svn: 300380
clang/lib/Serialization/ASTWriter.cpp
clang/test/Modules/Inputs/module.map
clang/test/Modules/Inputs/pragma_pack_push.h [deleted file]
clang/test/Modules/Inputs/pragma_pack_reset_push.h [deleted file]
clang/test/Modules/pragma-pack.c [deleted file]
clang/test/Modules/pragma-pack.cpp [new file with mode: 0644]