|
|
View previous topic :: View next topic |
Author |
Message |
benoitstjean
Joined: 30 Oct 2007 Posts: 566 Location: Ottawa, Ontario, Canada
|
Difference between COMPILE and BUILD ALL |
Posted: Thu Oct 24, 2013 7:31 pm |
|
|
Version: 4.137
I know this might sound like a silly question to some but hey, I can't know everything! ;)
I am seeing some very strange behavior that I just don't understand.
First-off, I just hit the "COMPILE UNIT F9" button four times in a row and in all four times, I never got the same end-result splash screen:
First compile:
RAM: 61%
ROM: 64%
Second compile:
RAM: 51%
ROM: 63%
Third compile:
RAM: 41%
ROM: 63%
Fourth compile:
RAM: 65%
ROM: 63%
I mean, I just hit COMPILE, then when it's done, I hit COMPILE, then I hit COMPILE again and the RAM percentage jumps all over the place. The reason I am doing this is because I got to this situation where I hit COMPILE and got a "not enough RAM for all variables". So I started clearing some code and suddenly compiled and got like 83% RAM usage which did not make sense because I had just cleared-up some unused strings and stuff... Then I hit recompile and got like 87%. Then recompile and it changes everytime. Why??
Second question: what's the difference between COMPILE and the BUILD ALL button (blue-red-yellow squares in a triangular fashion)? Which one should I use?
Thanks,
Ben |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Thu Oct 24, 2013 11:34 pm |
|
|
What it is meant to do....
'Build all', forces _everything_ to recompile.
'Compile', only rebuilds stuff where the source file has changed.
This is a 'standard' for compilers, _but_ on your version (and most pre V5 versions), compile runs, even if nothing has changed.
Now generally it shouldn't make very much difference, unless you are using linked modules, in a larger project, where only recompiling the stuff that has changed will be significantly quicker. However occasionally enough will have changed that it is worth forcing everything to compile.
Your 'different each time' behaviour is certainly not normal. Multiple calls shouldn't make anything different happen. I've only seen things like this happen, when another program was 'touching' the source files.
"I had just cleared-up some unused strings and stuff". Strings unless declared as 'const', are copied into RAM when the code starts, so tidying a few strings that are not used, will save a lot of RAM. If 'const', they will also be copied to RAM, if you have the option 'PASS_STRINGS=IN_RAM", but not automatically till used.
The different compilation may be specific to your compiler version, and chip (haven't got this one to test here). If there is no significant time difference on your project, then 'build all' should force a full recompile.
Best Wishes |
|
|
benoitstjean
Joined: 30 Oct 2007 Posts: 566 Location: Ottawa, Ontario, Canada
|
|
Posted: Mon Nov 04, 2013 7:16 am |
|
|
Ok, another weird thing I just noticed: I commented-out several hundred lines of code. When I compile, it STILL tells me that I don't have enough RAM for all variables AND it still tells me I have 10899 lines of code. And if I uncomment the lines of code, it still tells me I have 10899 lines.
I mean, the lines are literally commented-out by chunks using /* */ so I don't see how the compiler sees them. I should compile and have like 10600 lines or something.
Any idea? |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Mon Nov 04, 2013 8:15 am |
|
|
The 'count' is just the number of lines. It still has to look at them, to 'know' that the comment hasn't ended, so they are counted. Exactly the same happens in Microsoft VC.
Best Wishes |
|
|
benoitstjean
Joined: 30 Oct 2007 Posts: 566 Location: Ottawa, Ontario, Canada
|
|
Posted: Mon Nov 04, 2013 8:28 am |
|
|
Hmmm... well if that was true, then removing a single comment line should bring the count down by one. It doesn't. I actually removed three lines of comments bumping my code up in the page and it still counts 10899 lines.... unless I don't understand your explanation. |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
Powered by phpBB © 2001, 2005 phpBB Group
|