File: README.md

package info (click to toggle)
kseexpr 4.0.4.0-8
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,732 kB
  • sloc: cpp: 19,563; yacc: 662; python: 242; lex: 242; ruby: 179; sh: 7; makefile: 6
file content (123 lines) | stat: -rw-r--r-- 3,987 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
# KSeExpr - An embeddable expression evaluation engine

This repository hosts the fork of [Disney Animation's SeExpr expression 
library](https://wdas.github.io/SeExpr), that is used in [Krita](https://invent.kde.org/graphics/krita).

This fork was created as part of the GSoC 2020 project, [Dynamic Fill 
Layers in Krita using SeExpr](https://summerofcode.withgoogle.com/archive/2020/projects/6233717216903168/),
to enable the provision of fixes and translations needed to embed 
SeExpr into the Krita painting suite.

**WARNING**: This version is not ABI-compatible with projects using upstream SeExpr. Use it at your own discretion.

## Super impatient CMake building and installing guide

Prerequisites:

* A C++ compiler supporting **at least** the C++14 standard
* CMake >= 3.8.0
* Qt >= 5.9

```bash
$ mkdir kseexpr
$ cd kseexpr
$ git clone https://invent.kde.org/graphics/seexpr.git src
$ mkdir build
$ cd build
$ cmake ../src
$ cmake --build . --target install
```

## The full package

If you want optional stuff (not used in Krita):
* Ninja
* For building the parser, otherwise specify `-DUSE_PREGENERATED_FILES=OFF`:
  * bison
  * flex
* For LLVM support, otherwise specify `-DENABLE_LLVM_BACKEND=OFF`:
  * LLVM >= 3.8.0
* For building the documentation, otherwise specify `-DBUILD_DOC=OFF`:
  * doxygen
* For building the tests, otherwise specify `-DBUILD_TESTS=OFF`:
  * gtest
* For building the translations (if you have a release tarball, you can disable it with `-DBUILD_TRANSLATIONS=OFF`):
  * ECM >= 5.64

Then, on your shell, issue the following commands:

```bash
$ mkdir kseexpr
$ cd kseexpr
$ git clone https://invent.kde.org/graphics/seexpr.git src
$ mkdir build
$ cd build
$ cmake ../src
$ cmake --build . --target install
```

You can try the test application asciiGraph which is a simple
function grapher... e.g.
```bash
./asciiGraph "x^3-8*x"
```

## Getting started

Examining the demo applications in `src/demos` is a great way to see
some usage examples of the library. The basic strategy is to subclass
the `Expression` class and implement the methods that describe what
extra functions and variables your expression evaluation will need.

## Documentation

We (the Krita team) provided a set of tutorials, an adapted Quick Reference, and
other docs at [the Krita manual](https://docs.krita.org/en/tutorials/seexpr.html).

The original Doxygen-based documentation provided by Disney is at:
- <http://wdas.github.io/SeExpr/doxygen/>
- <http://wdas.github.io/SeExpr/doxygen/v1> (for older documentation)

## Source code overview

```
cmake/       CMake boilerplate and macros
generated/   Pregenerated parser files
LICENSES/    SPDX licenses
packaging/   Krita packaging scripts
po/          (only on release tarballs) Translations supplied by the KDE i18n team
src/
  build/     CMake helper macros
  demos/     Demo Applications
  doc/       Doxygen generation
  KSeExpr/   Library code
  KSeExprUI/ User Interface components for editing
  tests/     Regression Tests
  utils/     Various example tools
```

## License

KSeExpr is made available subject to the terms of the [GNU General Public License v3.0 or later](LICENSES/GPL-3.0-or-later.txt).

It is based on code from SeExpr, which is (C) Disney Enterprises, Inc. and made available under the Apache 2.0 License with section 6 rewrite. Please see the [LICENSE](LICENSES/LicenseRef-Apache-2.0.txt) for more details.

The translation loader is a modified version of the one provided by k18n under the [BSD 3-Clause "New" or "Revised" License](LICENSES/BSD-3-Clause.txt).

The `crack_atof` function by Tian Bo (in Utils.cpp) is licensed under the [MIT](LICENSES/MIT.txt).

The packaging scripts are made available under the [BSD 3-Clause "New" or "Revised" License](LICENSES/BSD-3-Clause.txt).

## Original SeExpr Developers

 * David Aguilar
 * Janet Berlin
 * Brent Burley
 * Lawrence Chai
 * Noah Kagan
 * Jared Reisweber
 * Andrew Selle
 * Dan Teece
 * Tom Thompson

Walt Disney Animation Studios