Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
Pyston
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
Pyston
Commits
54efb940
Commit
54efb940
authored
Dec 16, 2014
by
Kevin Modzelewski
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #242 from dagar/cmake
fixes #238 CMake issues
parents
51d65601
0ed9c200
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
67 additions
and
11 deletions
+67
-11
CMakeLists.txt
CMakeLists.txt
+23
-1
docs/INSTALLING.md
docs/INSTALLING.md
+44
-10
No files found.
CMakeLists.txt
View file @
54efb940
...
@@ -15,12 +15,34 @@ if(NOT ${CMAKE_BUILD_TYPE} STREQUAL "Release" AND NOT ${CMAKE_BUILD_TYPE} STREQU
...
@@ -15,12 +15,34 @@ if(NOT ${CMAKE_BUILD_TYPE} STREQUAL "Release" AND NOT ${CMAKE_BUILD_TYPE} STREQU
message
(
FATAL_ERROR
"CMAKE_BUILD_TYPE must be set to Release or Debug"
)
message
(
FATAL_ERROR
"CMAKE_BUILD_TYPE must be set to Release or Debug"
)
endif
()
endif
()
option
(
ENABLE_CCACHE
"enable caching compiler output"
ON
)
option
(
ENABLE_GIL
"threading use GIL"
ON
)
option
(
ENABLE_GIL
"threading use GIL"
ON
)
option
(
ENABLE_GOLD
"enable the gold linker"
ON
)
option
(
ENABLE_GRWL
"threading use GRWL"
OFF
)
option
(
ENABLE_GRWL
"threading use GRWL"
OFF
)
option
(
ENABLE_INTEL_JIT_EVENTS
"LLVM support for Intel JIT Events API"
OFF
)
option
(
ENABLE_INTEL_JIT_EVENTS
"LLVM support for Intel JIT Events API"
OFF
)
option
(
ENABLE_LLVM_DEBUG
"LLVM debug symbols"
OFF
)
option
(
ENABLE_LLVM_DEBUG
"LLVM debug symbols"
OFF
)
option
(
ENABLE_VALGRIND
"pyston valgrind support"
OFF
)
option
(
ENABLE_VALGRIND
"pyston valgrind support"
OFF
)
# automatically use ccache if found
if
(
ENABLE_CCACHE
)
find_program
(
CCACHE ccache
)
if
(
CCACHE
)
message
(
STATUS
"found ccache
${
CCACHE
}
"
)
set_property
(
GLOBAL PROPERTY RULE_LAUNCH_COMPILE
${
CCACHE
}
)
set_property
(
GLOBAL PROPERTY RULE_LAUNCH_LINK
${
CCACHE
}
)
endif
()
endif
()
# automatically use the gold linker if found
if
(
ENABLE_GOLD
)
find_program
(
GOLD_LINKER ld.gold
)
if
(
GOLD_LINKER
)
message
(
STATUS
"found the gold linker
${
GOLD_LINKER
}
"
)
set
(
CMAKE_LINKER
"
${
GOLD_LINKER
}
"
)
set
(
CMAKE_CXX_LINK_FLAGS
"
${
CMAKE_CXX_LINK_FLAGS
}
-B
${
CMAKE_SOURCE_DIR
}
/tools/build_system"
)
endif
()
endif
()
# initial clang flags (set here so they're used when building llvm)
# initial clang flags (set here so they're used when building llvm)
set
(
CLANG_FLAGS
"-Qunused-arguments -fcolor-diagnostics"
CACHE STRING
"Clang specific C and CXX flags"
)
set
(
CLANG_FLAGS
"-Qunused-arguments -fcolor-diagnostics"
CACHE STRING
"Clang specific C and CXX flags"
)
if
(
"
${
CMAKE_C_COMPILER_ID
}
"
STREQUAL
"Clang"
)
if
(
"
${
CMAKE_C_COMPILER_ID
}
"
STREQUAL
"Clang"
)
...
@@ -32,7 +54,7 @@ endif()
...
@@ -32,7 +54,7 @@ endif()
# llvm disable debug info unless ENABLE_LLVM_DEBUG is ON
# llvm disable debug info unless ENABLE_LLVM_DEBUG is ON
if
(
${
CMAKE_BUILD_TYPE
}
STREQUAL
"Debug"
AND NOT ENABLE_LLVM_DEBUG
)
if
(
${
CMAKE_BUILD_TYPE
}
STREQUAL
"Debug"
AND NOT ENABLE_LLVM_DEBUG
)
set
(
CMAKE_CXX_FLAGS_DEBUG
"-
g0
"
CACHE STRING
""
FORCE
)
set
(
CMAKE_CXX_FLAGS_DEBUG
"-
O3
"
CACHE STRING
""
FORCE
)
endif
()
endif
()
execute_process
(
COMMAND cat llvm_revision.txt WORKING_DIRECTORY
${
CMAKE_SOURCE_DIR
}
OUTPUT_VARIABLE LLVMREV OUTPUT_STRIP_TRAILING_WHITESPACE
)
execute_process
(
COMMAND cat llvm_revision.txt WORKING_DIRECTORY
${
CMAKE_SOURCE_DIR
}
OUTPUT_VARIABLE LLVMREV OUTPUT_STRIP_TRAILING_WHITESPACE
)
...
...
docs/INSTALLING.md
View file @
54efb940
...
@@ -290,24 +290,58 @@ CC="ccache $HOME/pyston_deps/gcc-4.8.2-install/bin/gcc" CXX="ccache $HOME/pyston
...
@@ -290,24 +290,58 @@ CC="ccache $HOME/pyston_deps/gcc-4.8.2-install/bin/gcc" CXX="ccache $HOME/pyston
~/pyston_deps/ninja/ninja check-pyston
~/pyston_deps/ninja/ninja check-pyston
```
```
On Ubuntu 12.04, you need a new cmake in order to use ninja, but can install ninja using
`sudo apt-get install ninja-build`
. Then
:
If your system provides a new enough GCC and cmake, you can just do
:
```
```
mkdir ~/pyston-build
mkdir ~/pyston-build && cd ~/pyston-build
cd ~/pyston-build
cmake -GNinja ~/pyston
CC="ccache $HOME/pyston_deps/gcc-4.8.2-install/bin/gcc" CXX="ccache $HOME/pyston_deps/gcc-4.8.2-install/bin/g++" ~/pyston_deps/cmake-3.0.0/bin/cmake -GNinja ~/pyston -DCMAKE_EXE_LINKER_FLAGS="-Wl,-rpath,$HOME/pyston_deps/gcc-4.8.2-install/lib64" -DGCC_INSTALL_PREFIX=~/pyston_deps/gcc-4.8.2-install
ninja check-pyston
ninja check-pyston
```
```
If your system provides a new enough GCC and cmake, you can just do:
**Ubuntu 12.04**
```
sudo add-apt-repository --yes ppa:ubuntu-toolchain-r/test
sudo add-apt-repository --yes ppa:kubuntu-ppa/backports
sudo apt-get -qq update
sudo apt-get install -yq git cmake ninja-build ccache libncurses5-dev liblzma-dev libreadline-dev libgmp3-dev autoconf libtool python-dev texlive-extra-utils clang-3.4 libstdc++-4.8-dev
git clone --recursive https://github.com/dropbox/pyston.git ~/pyston
git clone git://github.com/llvm-mirror/llvm.git ~/pyston_deps/llvm-trunk
git clone git://github.com/llvm-mirror/clang.git ~/pyston_deps/llvm-trunk/tools/clang
mkdir ~/pyston-build && cd ~/pyston-build
CC='clang' CXX='clang++' cmake -GNinja ~/pyston
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
ninja llvm_up
ninja check-pyston # run the test suite
```
```
mkdir ~/pyston-build
cd ~/pyston-build
**Ubuntu 14.04**
CC='ccache gcc' CXX='ccache g++' cmake -GNinja ~/pyston
```
ninja check-pyston
sudo apt-get install -yq git cmake ninja-build ccache libncurses5-dev liblzma-dev libreadline-dev libgmp3-dev autoconf libtool python-dev texlive-extra-utils clang-3.5
git clone --recursive https://github.com/dropbox/pyston.git ~/pyston
git clone git://github.com/llvm-mirror/llvm.git ~/pyston_deps/llvm-trunk
git clone git://github.com/llvm-mirror/clang.git ~/pyston_deps/llvm-trunk/tools/clang
mkdir ~/pyston-build && cd ~/pyston-build
CC='clang' CXX='clang++' cmake -GNinja ~/pyston
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
ninja llvm_up
ninja check-pyston # run the test suite
```
```
Other important options:
Other important options:
-
`-DCMAKE_BUILD_TYPE=Debug`
(or Release, but defaults to Release I believe)
-
`-DCMAKE_BUILD_TYPE=Debug`
(defaults to Release)
-
`-DENABLE_LLVM_DEBUG=1`
for full LLVM debug
-
`-DENABLE_CCACHE=0`
to disable ccache
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment