head 1.1; branch 1.1.1; access; symbols netbsd-11-0-RC4:1.1.1.2 netbsd-11-0-RC3:1.1.1.2 netbsd-11-0-RC2:1.1.1.2 netbsd-11-0-RC1:1.1.1.2 perseant-exfatfs-base-20250801:1.1.1.2 netbsd-11:1.1.1.2.0.10 netbsd-11-base:1.1.1.2 netbsd-10-1-RELEASE:1.1.1.2 perseant-exfatfs-base-20240630:1.1.1.2 perseant-exfatfs:1.1.1.2.0.8 perseant-exfatfs-base:1.1.1.2 netbsd-8-3-RELEASE:1.1.1.1 netbsd-9-4-RELEASE:1.1.1.1 netbsd-10-0-RELEASE:1.1.1.2 netbsd-10-0-RC6:1.1.1.2 netbsd-10-0-RC5:1.1.1.2 netbsd-10-0-RC4:1.1.1.2 netbsd-10-0-RC3:1.1.1.2 netbsd-10-0-RC2:1.1.1.2 netbsd-10-0-RC1:1.1.1.2 netbsd-10:1.1.1.2.0.6 netbsd-10-base:1.1.1.2 netbsd-9-3-RELEASE:1.1.1.1 cjep_sun2x:1.1.1.2.0.4 cjep_sun2x-base:1.1.1.2 cjep_staticlib_x-base1:1.1.1.2 netbsd-9-2-RELEASE:1.1.1.1 cjep_staticlib_x:1.1.1.2.0.2 cjep_staticlib_x-base:1.1.1.2 netbsd-9-1-RELEASE:1.1.1.1 phil-wifi-20200421:1.1.1.2 phil-wifi-20200411:1.1.1.2 phil-wifi-20200406:1.1.1.2 netbsd-8-2-RELEASE:1.1.1.1 netbsd-9-0-RELEASE:1.1.1.1 netbsd-9-0-RC2:1.1.1.1 netbsd-9-0-RC1:1.1.1.1 netbsd-9:1.1.1.1.0.18 netbsd-9-base:1.1.1.1 phil-wifi-20190609:1.1.1.1 netbsd-8-1-RELEASE:1.1.1.1 netbsd-8-1-RC1:1.1.1.1 pgoyette-compat-merge-20190127:1.1.1.1 pgoyette-compat-20190127:1.1.1.1 pgoyette-compat-20190118:1.1.1.1 pgoyette-compat-1226:1.1.1.1 pgoyette-compat-1126:1.1.1.1 pgoyette-compat-1020:1.1.1.1 pgoyette-compat-0930:1.1.1.1 pgoyette-compat-0906:1.1.1.1 pgoyette-compat-0728:1.1.1.1 clang-337282:1.1.1.1 netbsd-8-0-RELEASE:1.1.1.1 phil-wifi:1.1.1.1.0.16 phil-wifi-base:1.1.1.1 pgoyette-compat-0625:1.1.1.1 netbsd-8-0-RC2:1.1.1.1 pgoyette-compat-0521:1.1.1.1 pgoyette-compat-0502:1.1.1.1 pgoyette-compat-0422:1.1.1.1 netbsd-8-0-RC1:1.1.1.1 pgoyette-compat-0415:1.1.1.1 pgoyette-compat-0407:1.1.1.1 pgoyette-compat-0330:1.1.1.1 pgoyette-compat-0322:1.1.1.1 pgoyette-compat-0315:1.1.1.1 pgoyette-compat:1.1.1.1.0.14 pgoyette-compat-base:1.1.1.1 clang-319952:1.1.1.1 matt-nb8-mediatek:1.1.1.1.0.12 matt-nb8-mediatek-base:1.1.1.1 clang-309604:1.1.1.1 perseant-stdc-iso10646:1.1.1.1.0.10 perseant-stdc-iso10646-base:1.1.1.1 netbsd-8:1.1.1.1.0.8 netbsd-8-base:1.1.1.1 prg-localcount2-base3:1.1.1.1 prg-localcount2-base2:1.1.1.1 prg-localcount2-base1:1.1.1.1 prg-localcount2:1.1.1.1.0.6 prg-localcount2-base:1.1.1.1 pgoyette-localcount-20170426:1.1.1.1 bouyer-socketcan-base1:1.1.1.1 pgoyette-localcount:1.1.1.1.0.4 pgoyette-localcount-20170320:1.1.1.1 clang-294123:1.1.1.1 bouyer-socketcan:1.1.1.1.0.2 bouyer-socketcan-base:1.1.1.1 clang-291444:1.1.1.1 LLVM:1.1.1; locks; strict; comment @// @; 1.1 date 2017.01.11.10.38.32; author joerg; state Exp; branches 1.1.1.1; next ; commitid CNnUNfII1jgNmxBz; 1.1.1.1 date 2017.01.11.10.38.32; author joerg; state Exp; branches 1.1.1.1.4.1 1.1.1.1.16.1; next 1.1.1.2; commitid CNnUNfII1jgNmxBz; 1.1.1.2 date 2019.11.13.22.21.57; author joerg; state dead; branches; next ; commitid QD8YATxuNG34YJKB; 1.1.1.1.4.1 date 2017.01.11.10.38.32; author pgoyette; state dead; branches; next 1.1.1.1.4.2; commitid jjw7cAwgyKq7RfKz; 1.1.1.1.4.2 date 2017.03.20.06.53.21; author pgoyette; state Exp; branches; next ; commitid jjw7cAwgyKq7RfKz; 1.1.1.1.16.1 date 2020.04.13.07.49.22; author martin; state dead; branches; next ; commitid X01YhRUPVUDaec4C; desc @@ 1.1 log @Initial revision @ text @// RUN: rm -rf %t // RUN: %clang_cc1 -fmodules -fmodules-cache-path=%t -fimplicit-module-maps -I%S/Inputs/suggest-include %s -verify #include "empty.h" // import the module file // expected-note@@usetextual1.h:2 {{previous}} // expected-note@@textual2.h:1 {{previous}} // expected-note@@textual3.h:1 {{previous}} // expected-note@@textual4.h:1 {{previous}} // expected-note@@textual5.h:1 {{previous}} // expected-note@@private1.h:1 {{previous}} // expected-note@@private2.h:1 {{previous}} // expected-note@@private3.h:1 {{previous}} void f() { (void)::usetextual1; // expected-error {{missing '#include "usetextual1.h"'}} (void)::usetextual2; // expected-error {{missing '#include "usetextual2.h"'}} (void)::textual3; // expected-error-re {{{{^}}missing '#include "usetextual3.h"'}} // Don't suggest a #include that includes the entity via a path that leaves // the module. In that case we can't be sure that we've picked the right header. (void)::textual4; // expected-error-re {{{{^}}declaration of 'textual4'}} (void)::textual5; // expected-error-re {{{{^}}declaration of 'textual5'}} // Don't suggest #including a private header. // FIXME: We could suggest including "useprivate1.h" here, as it's the only // public way to get at this declaration. (void)::private1; // expected-error-re {{{{^}}declaration of 'private1'}} // FIXME: Should we be suggesting an import at all here? Should declarations // in private headers be visible when the surrounding module is imported? (void)::private2; // expected-error-re {{{{^}}declaration of 'private2'}} // Even if we suggest an include for private1, we should not do so here. (void)::private3; // expected-error-re {{{{^}}declaration of 'private3'}} } @ 1.1.1.1 log @Import Clang pre-4.0.0 r291444. @ text @@ 1.1.1.1.16.1 log @Mostly merge changes from HEAD upto 20200411 @ text @@ 1.1.1.2 log @Mark old LLVM instance as dead. @ text @@ 1.1.1.1.4.1 log @file suggest-include.cpp was added on branch pgoyette-localcount on 2017-03-20 06:53:21 +0000 @ text @d1 33 @ 1.1.1.1.4.2 log @Sync with HEAD @ text @a0 33 // RUN: rm -rf %t // RUN: %clang_cc1 -fmodules -fmodules-cache-path=%t -fimplicit-module-maps -I%S/Inputs/suggest-include %s -verify #include "empty.h" // import the module file // expected-note@@usetextual1.h:2 {{previous}} // expected-note@@textual2.h:1 {{previous}} // expected-note@@textual3.h:1 {{previous}} // expected-note@@textual4.h:1 {{previous}} // expected-note@@textual5.h:1 {{previous}} // expected-note@@private1.h:1 {{previous}} // expected-note@@private2.h:1 {{previous}} // expected-note@@private3.h:1 {{previous}} void f() { (void)::usetextual1; // expected-error {{missing '#include "usetextual1.h"'}} (void)::usetextual2; // expected-error {{missing '#include "usetextual2.h"'}} (void)::textual3; // expected-error-re {{{{^}}missing '#include "usetextual3.h"'}} // Don't suggest a #include that includes the entity via a path that leaves // the module. In that case we can't be sure that we've picked the right header. (void)::textual4; // expected-error-re {{{{^}}declaration of 'textual4'}} (void)::textual5; // expected-error-re {{{{^}}declaration of 'textual5'}} // Don't suggest #including a private header. // FIXME: We could suggest including "useprivate1.h" here, as it's the only // public way to get at this declaration. (void)::private1; // expected-error-re {{{{^}}declaration of 'private1'}} // FIXME: Should we be suggesting an import at all here? Should declarations // in private headers be visible when the surrounding module is imported? (void)::private2; // expected-error-re {{{{^}}declaration of 'private2'}} // Even if we suggest an include for private1, we should not do so here. (void)::private3; // expected-error-re {{{{^}}declaration of 'private3'}} } @