• Stars
    star
    3,472
  • Rank 12,835 (Top 0.3 %)
  • Language
    C++
  • License
    Other
  • Created almost 9 years ago
  • Updated about 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

The cling C++ interpreter

Cling - The Interactive C++ Interpreter

The main repository is at https://github.com/root-project/cling

Overview

Cling is an interactive C++ interpreter, built on top of Clang and LLVM compiler infrastructure. Cling realizes the read-eval-print loop (REPL) concept, in order to leverage rapid application development. Implemented as a small extension to LLVM and Clang, the interpreter reuses their strengths such as the praised concise and expressive compiler diagnostics.

See also cling's web page.

Please note that some of the resources are rather old and most of the stated limitations are outdated.

Installation

Release Notes

See our release notes to find what's new.

Binaries

Our nightly binary snapshots can be found here.

Building from Source with Cling Packaging Tool

Cling's tree has a user-friendly, command-line utility written in Python called Cling Packaging Tool (CPT) which can build Cling from source and generate installer bundles for a wide range of platforms. CPT requires Python 3 or later.

If you have Cling's source cloned locally, you can find the tool in tools/packaging directory. Alternatively, you can download the script manually, or by using wget:

wget https://raw.githubusercontent.com/root-project/cling/master/tools/packaging/cpt.py
chmod +x cpt.py
./cpt.py --check-requirements && ./cpt.py --create-dev-env Debug --with-workdir=./cling-build/

Full documentation of CPT can be found in tools/packaging.

Usage

./cling '#include <stdio.h>' 'printf("Hello World!\n")'

To get started run:

./cling --help

or type

./cling
[cling]$ .help

Jupyter

Cling comes with a Jupyter kernel. After building cling, install Jupyter and cling's kernel by following the README.md in tools/Jupyter. Make sure cling is in your PATH when you start jupyter!

Citing Cling

% Peer-Reviewed Publication
%
% 19th International Conference on Computing in High Energy and Nuclear Physics (CHEP)
% 21-25 May, 2012, New York, USA
%
@inproceedings{Cling,
  author = {Vassilev,V. and Canal,Ph. and Naumann,A. and Moneta,L. and Russo,P.},
  title = {{Cling} -- The New Interactive Interpreter for {ROOT} 6}},
  journal = {Journal of Physics: Conference Series},
  year = 2012,
  month = {dec},
  volume = {396},
  number = {5},
  pages = {052071},
  doi = {10.1088/1742-6596/396/5/052071},
  url = {https://iopscience.iop.org/article/10.1088/1742-6596/396/5/052071/pdf},
  publisher = {{IOP} Publishing}
}

Developers' Corner

Cling's latest doxygen documentation

Contributions

Every contribution is considered a donation and its copyright and any other related rights become exclusive ownership of the person who merged the code or in any other case the main developers of the "Cling Project".

We warmly welcome external contributions to the Cling! By providing code, you agree to transfer your copyright on the code to the "Cling project". Of course you will be duly credited and your name will appear on the contributors page, the release notes, and in the CREDITS file shipped with every binary and source distribution. The copyright transfer is necessary for us to be able to effectively defend the project in case of litigation.

License

Please see our LICENSE.

Releases

Our release steps to follow when cutting a new release:

  1. Update release notes
  2. Remove ~dev suffix from VERSION
  3. Add a new entry in the news section of our website
  4. Commit the changes.
  5. git tag -a v0.x -m "Tagging release v0.x"
  6. Tag cling-patches of clang.git: git tag -a cling-v0.x -m "Tagging clang for cling v0.x"
  7. Create a draft release in github and copy the contents of the release notes.
  8. Wait for green builds.
  9. Upload binaries to github (Travis should do this automatically).
  10. Publish the tag and announce it on the mailing list.
  11. Increment the current version and append ~dev.

More Repositories

1

root

The official repository for ROOT: analyzing, storing and visualizing big data, scientifically
C++
2,676
star
2

jsroot

JavaScript ROOT
JavaScript
187
star
3

training

ROOT training material and tutorials
Jupyter Notebook
127
star
4

veccore

C++ Library for Portable SIMD Vectorization
C++
79
star
5

roottest

The ROOT test suite
C++
39
star
6

NotebookPrimer

The interactive ROOT Primer based on Jupyter notebooks
Jupyter Notebook
33
star
7

root-docker

Docker recipes for ROOT
Dockerfile
31
star
8

web

root.cern
Python
29
star
9

software-carpentry

ROOT material for Software Carpentries
Jupyter Notebook
23
star
10

student-course

ROOT course for students
Jupyter Notebook
22
star
11

rootbench

Collection of benchmarks and performance monitoring applications
C++
20
star
12

jenkins-pipelines

Pipelines for building ROOT on pipeline jobs in Jenkins
Groovy
13
star
13

docker-examples

Examples for using the ROOT Docker container.
C
12
star
14

vecmath

SIMD Vectorization Math Library, built on top of veccore
CMake
9
star
15

root-evolution

JavaScript
6
star
16

rootspi

Infrastructure scripts: Jenkins, documentation, etc.
Python
5
star
17

analysis-grand-challenge

The Analysis Grand Challenge benchmarks with ROOT
Python
5
star
18

gcc-problem-matcher-improved

Creates annotations for compiler warnings and errors in GitHub Workflows
JavaScript
3
star
19

root-ci-images

Images for the ROOT continuous integration system
Dockerfile
3
star
20

opendata-benchmarks

Example repository showing benchmarks with open data
C++
3
star
21

summer-student-course

Exercises for the ROOT Summer Student course at CERN
Jupyter Notebook
2
star
22

doxyvers

Version selection for Doxygen documentation
JavaScript
1
star
23

annotation-failure-action

GitHub action that extends the usage of workflow annotations
JavaScript
1
star