Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/khinsen/leibniz-pharo
Leibniz - a Digital Scientific Notation
https://github.com/khinsen/leibniz-pharo
computational-science pharo pharo-smalltalk
Last synced: 4 months ago
JSON representation
Leibniz - a Digital Scientific Notation
- Host: GitHub
- URL: https://github.com/khinsen/leibniz-pharo
- Owner: khinsen
- License: mit
- Created: 2018-11-17T14:43:27.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-08-15T14:16:47.000Z (5 months ago)
- Last Synced: 2024-09-26T21:40:22.447Z (4 months ago)
- Topics: computational-science, pharo, pharo-smalltalk
- Language: Smalltalk
- Homepage:
- Size: 6.89 MB
- Stars: 34
- Watchers: 6
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-pharo-ml - Leibniz-pharo
README
# leibniz-pharo
The second iteration of [Leibniz](http://github.com/khinsen/leibniz), implemented in [Pharo](http://www.pharo.org/) making heavy use of the [Glamorous Toolkit](https://gtoolkit.com/)
![screenshot](./screenshot.png)
## Installation
### Install a font with all the math symbols
Leibniz makes generous use of Unicode glyphs that are not contained in the default fonts used by GToolkit. The best free code font (monospaced) I have found is [JuliaMono](https://juliamono.netlify.app/). For standard text fonts, the options I am aware of are [Arial Unicode MS](https://docs.microsoft.com/en-us/typography/font-list/arial-unicode-ms) and [Noto Sans Math](https://github.com/google/fonts/tree/main/ofl/notosansmath). Leibniz will automatically select one of them, if available. Otherwise it will use the default code font of Glamorous Toolkit. It lacks many of the maths symbols that Leibniz uses. Some of them will be substituted from other fonts if possible, making the text readable but often ugly. Others will be replaced by a default glyph, making the code unreadable.
Note that you must install a suiteable font *before* installing the Leibniz package into Glamorous Toolkit. The font is chosen at installation time.
### Install [Glamorous Toolkit](https://gtoolkit.com/)
The easiest option is downloading a ready-to-run binary for your system from [the download page](https://gtoolkit.com/download).
### Install Leibniz
1. Open Glamorous Toolkit and click on the playground icon near the top left.
![screenshot](./leibniz-installation-1.png)
2. Paste the following lines of code into the playground:
```
Metacello new
baseline: 'LeibnizForGToolkit';
repository: 'github://khinsen/leibniz-pharo/src';
load.
```
Then click on the arrow highlighted in the screenshot below. Wait until the pane on the right appears. This may take a few minutes. Close the playground
by clicking on the cross highlighted in the screenshot below.![screenshot](./leibniz-installation-2.png)
3. Open the Leibniz Book
The installation process has added a big icon labelled "Leibniz Book" to the home screen of Glamorous Toolkit. Click on it to open it.
![screenshot](./leibniz-installation-3.png)
4. Start reading and exploring
Read the first page, and move on as you like, either following links or navigating through the table of contents.
![screenshot](./leibniz-installation-4.png)
## Dependencies
The following list is provided for information. All the dependencies will be installed automatically in the procedure explained above.
- [SingletonTrait](https://github.com/khinsen/singletontrait) is used for a few singleton classes.
- [RecursiveWriteBarrier](https://github.com//khinsen/RecursiveWriteBarrier) is used to make some objects fully immutable.
- [EqualityThroughVariablesTrait](https://github.com/khinsen/EqualityThroughVariablesTrait) is a trait that implements object equality in terms of equality of instance and indexed variables.