Static Analysis/Installing the Oink Stack: Difference between revisions

From MozillaWiki
Jump to navigation Jump to search
m (Reverted edits by Firefoxer2011 (Talk) to last revision by Benjamin Smedberg)
 
(9 intermediate revisions by 5 users not shown)
Line 1: Line 1:
This is a kinda rough scratchpad for how to install and use the oink stack on a Linux system to do [[Static Analysis]].
#REDIRECT [[MDC:Installing Pork]]
 
Base system: FC7
 
== Install GCC 3.4 ==
 
<pre>sudo yum install compat-gcc-34
sudo yum install compat-gcc-34-c++</pre>
 
You may want to do a test-build of Mozilla at this point to make sure that it builds and links correctly.
 
== Build and Install MCPP ==
 
<pre>svn co https://mcpp.svn.sourceforge.net/svnroot/mcpp/trunk mcpp
cd mcpp
./configure --enable-replace-cpp CC=gcc34 CXX=g++34
make
sudo make install</pre>
 
== Get Spidermonkey ==
 
System spidermonkey is used by dehydra:
 
<pre>sudo yum install js-devel</pre>
 
== Do the oink thing ==
 
<pre>wget http://people.mozilla.org/~tglek/checkout.sh
sh checkout.sh http://hg.mozilla.org</pre>
 
Now, depending on your version of hg, you may need to manually update the working directory for elsa and elkhound:
 
<pre>hg -R oink-stack/elkhound update -C tip
hg -R oink-stack/elsa update -C tip
hg -R oink-stack/oink update -C tip</pre>
 
Build it.
 
<pre>cd oink-stack;
make</pre>
 
== Building Mozilla with MCPP ==
 
To build Mozilla with MCPP to generate annotated .ii files, use the following configure command:
 
ac_cv_visibility_hidden=no CC="gcc34 -save-temps -Wp,-W0,-K" CXX="g++34 -save-temps -Wp,-W0,-K" CPPFLAGS=-DNS_DISABLE_LITERAL_TEMPLATE $srcdir/configure --enable-debug --disable-optimize --disable-accessibility --enable-application=browser --disable-crashreporter
 
Building will probably require disabling WARNINGS_AS_ERRORS:
 
make WARNINGS_AS_ERRORS=

Latest revision as of 21:51, 13 May 2010