Pragma once

763 views
Skip to first unread message

Nico Weber

unread,
Jul 21, 2010, 6:07:13 PM7/21/10
to Chromium-dev
Hi,

dpranke suggested that external include guards might speed up
compilation on windows quite a bit. External include guard means that
instead of including a file like this

#include "base/string16.h"

you include it like this:

#ifndef BASE_STRING16_H_
#include "base/string16.h"
#endif

(assuming that BASE_STRING16_H_ is the include guard used in string16.h).

The idea is that if string16.h has been included already, the compiler
doesn't even need to start string16.h a second time.

Another approach to achieve more or less the same is to add #pragma
once to string16.h. This is nicer in that including files don't need
to be littered with #ifndef/#endif noise. The downside is that not all
compilers support #pragma once (but both gcc and msvc do, and other
compilers just ignore it, so it doesn't really hurt).

gcc doesn't need external include guards and does this optimization
itself, but msvc doesn't seem to do this.
http://www.gamearchitect.net/Articles/ExperimentsWithIncludes.html
suggests that as well.

I tried doing clean builds of chrome on my windows box (z600). I did
this only for base, chrome, gfx for testing, but that should be good
enough to get an idea. Results:

Normal clean build: 40 min (I'm apparently not using /mp?)
Clean build w/ #pragma once to all headers in chrome, base, and gfx: 36 min
Clean build w / external include guards: 35 min

This suggests we should add "#pragma once" to all our header files
(except for the _messages_internal headers used for IPC, cause that
breaks stuff). Is anyone opposed to this idea?

Nico

ps:
pragma once: http://codepad.org/AXRjx93w
external guards: http://codepad.org/jxdtJDc8

Dirk Pranke

unread,
Jul 21, 2010, 6:25:53 PM7/21/10
to tha...@chromium.org, Chromium-dev
Is it easy to do the same test on Mac and Linux and verify that we're
not seeing any benefit w/ gcc or clang? (and that they still work
correctly)?

-- Dirk

> --
> Chromium Developers mailing list: chromi...@chromium.org
> View archives, change email options, or unsubscribe:
>    http://groups.google.com/a/chromium.org/group/chromium-dev
>

Nico Weber

unread,
Jul 21, 2010, 6:27:04 PM7/21/10
to Dirk Pranke, Chromium-dev
Try! :-)

Nico Weber

unread,
Jul 21, 2010, 7:53:49 PM7/21/10
to Dirk Pranke, Chromium-dev
I just tested on Mac with, and as expected build times didn't change.

I retested on windows /mp, and build times went from 13 to 11 minutes.

http://src.chromium.org/viewvc/chrome/trunk/src/tools/pragmaonce/pragmaonce.py?view=markup&pathrev=53271
does now contain the script I intend to run on our source some time
next week (if I hear no objections until then).

Nico

On Wed, Jul 21, 2010 at 3:25 PM, Dirk Pranke <dpr...@chromium.org> wrote:

Peter Kasting

unread,
Jul 21, 2010, 8:09:57 PM7/21/10
to tha...@chromium.org, Dirk Pranke, Chromium-dev
On Wed, Jul 21, 2010 at 4:53 PM, Nico Weber <tha...@chromium.org> wrote:
I just tested on Mac with, and as expected build times didn't change.

I retested on windows /mp, and build times went from 13 to 11 minutes.

http://src.chromium.org/viewvc/chrome/trunk/src/tools/pragmaonce/pragmaonce.py?view=markup&pathrev=53271
does now contain the script I intend to run on our source some time
next week (if I hear no objections until then).

When you do that, make sure to list in the change description what files are being skipped and why.  (I assume before you do that you'll fix anything that's just flat broken.)

PK 

Nico Weber

unread,
Jul 27, 2010, 12:21:01 PM7/27/10
to Elliot Glaysher, Chromium-dev
I added #pragma once to ~2700 header files yesterday. Judging from

http://build.chromium.org/buildbot/waterfall/stats/Chromium%20XP
http://build.chromium.org/buildbot/waterfall/stats/Chromium%20Builder
http://build.chromium.org/buildbot/waterfall/stats/Chromium%20Builder%20(dbg)

, build times on the bots didn't go down at all (how often are these
charts updated? They're not labeled).

On Wed, Jul 21, 2010 at 3:10 PM, Elliot Glaysher <e...@google.com> wrote:
> Feel free to send the review to me when you do this.

Nico Weber

unread,
Jul 27, 2010, 12:30:31 PM7/27/10
to Thomas Van Lenten, Elliot Glaysher, Chromium-dev
Sounds like the Right Thing is to revert the #pragma once patch and to
blame my local 10% speedup on disk cache effects or something? (Though
I would've thought linking chrome evicts every cache in this world.)

On Tue, Jul 27, 2010 at 9:25 AM, Thomas Van Lenten <thom...@google.com> wrote:
> I believe they update with every run.
> TVL

Albert J. Wong (王重傑)

unread,
Jul 27, 2010, 12:42:42 PM7/27/10
to tha...@chromium.org, Thomas Van Lenten, Elliot Glaysher, Chromium-dev
Before reverting maybe someone else should try to see if there's a local speedup?  If it helps local devs, it could still be worth it, and the change doesn't really hurt does it?

-Albert

Nicolas Sylvain

unread,
Jul 27, 2010, 7:02:50 PM7/27/10
to tha...@chromium.org, Elliot Glaysher, Chromium-dev
On Tue, Jul 27, 2010 at 9:21 AM, Nico Weber <tha...@chromium.org> wrote:
I added #pragma once to ~2700 header files yesterday. Judging from

http://build.chromium.org/buildbot/waterfall/stats/Chromium%20XP
http://build.chromium.org/buildbot/waterfall/stats/Chromium%20Builder
http://build.chromium.org/buildbot/waterfall/stats/Chromium%20Builder%20(dbg)

, build times on the bots didn't go down at all (how often are these
charts updated? They're not labeled).
The charts are live. Always up to date.  Maybe it just does not help with incredibuild?

Nicolas

Darin Fisher

unread,
Jul 28, 2010, 2:32:13 AM7/28/10
to ajw...@chromium.org, tha...@chromium.org, Thomas Van Lenten, Elliot Glaysher, Chromium-dev
It adds maintenance burden.  Everyone will need to learn to maintain this and add #pragma once to new files.  That is not free.

-Darin

Jeremy Orlow

unread,
Jul 28, 2010, 7:30:22 AM7/28/10
to da...@google.com, ajw...@chromium.org, tha...@chromium.org, Thomas Van Lenten, Elliot Glaysher, Chromium-dev
Sure, but if it makes everyone's build faster (even by 10%), it seems worth it.

Peter Kasting

unread,
Jul 28, 2010, 2:34:49 PM7/28/10
to da...@google.com, ajw...@chromium.org, tha...@chromium.org, Thomas Van Lenten, Elliot Glaysher, Chromium-dev
On Tue, Jul 27, 2010 at 11:32 PM, Darin Fisher <da...@chromium.org> wrote:
It adds maintenance burden.  Everyone will need to learn to maintain this and add #pragma once to new files.  That is not free.

I create new files by starting with a partial or complete copy of an old file.  I would imagine most others do too, in order to get e.g. the license text correct.  In that sense, I don't see this as adding any maintenance burden, any more than the license does.

PK 

Darin Fisher

unread,
Jul 29, 2010, 12:26:58 AM7/29/10
to Peter Kasting, ajw...@chromium.org, tha...@chromium.org, Thomas Van Lenten, Elliot Glaysher, Chromium-dev
Maybe I'm the odd one, but I always start fresh when creating a new file so that I don't have anything residual left over from an existing file that I didn't intend.  I just open an existing file and copy/paste the 3 lines of license into the new file.

Anyways, while we could take a poll and optimize around that, I don't think that's the point.  We're talking about something that would need to go into the style guide and be enforced at review time.  Perhaps a presubmit check could be written.  If this is really worth it, then we should probably implement that.

-Darin

Robert Sesek

unread,
Jul 29, 2010, 11:07:30 AM7/29/10
to da...@google.com, Peter Kasting, ajw...@chromium.org, tha...@chromium.org, Thomas Van Lenten, Elliot Glaysher, Chromium-dev
On Thu, Jul 29, 2010 at 12:26 AM, Darin Fisher <da...@chromium.org> wrote:
Perhaps a presubmit check could be written.  If this is really worth it, then we should probably implement that.

I agree that a presubmit check is the best way to enforce this.


rsesek / @chromium.org

Matthew Harris

unread,
Sep 9, 2010, 9:32:58 PM9/9/10
to Chromium-dev
If this is part of the new Chromium style, could you please add it to
the style guide? <http://dev.chromium.org/developers/coding-style>

I'm speaking as a Google readability reviewer attempting to ensure
compliance with the style guide. The Google C++ Style Guide forbids
#pragma once <http://google-styleguide.googlecode.com/svn/trunk/
cppguide.xml?showone=Windows_Code#Windows_Code> and the Chromium
additions don't currently mention it.


Matthew

Dirk Pranke

unread,
Sep 9, 2010, 9:39:59 PM9/9/10
to mha...@google.com, Chromium-dev
I think this ended up being unclear if it was a win or not, so we're
not currently requiring it (or forbidding it).

-- Dirk

Peter Kasting

unread,
Sep 10, 2010, 12:40:37 AM9/10/10
to dpr...@google.com, mha...@google.com, Chromium-dev
On Thu, Sep 9, 2010 at 6:39 PM, Dirk Pranke <dpr...@chromium.org> wrote:
I think this ended up being unclear if it was a win or not, so we're
not currently requiring it (or forbidding it).

I added it to the style guide.

AFAIK we're going with it.  It's easy for us to reverse course and back it out, and change the style guide accordingly, but unless and until that happens, I don't think the files should all be one way and the style guide the other.

PK
Reply all
Reply to author
Forward
0 new messages