llvm/llvm/utils/TableGen/jupyter/README.md

# Jupyter Tools for TableGen

This folder contains notebooks relating to TableGen and a Jupyter kernel for
TableGen.

## Notebooks

[LLVM_TableGen.ipynb](LLVM_TableGen.ipynb) - A demo of the kernel's capabilities.

[tablegen_tutorial_part_1.ipynb](tablegen_tutorial_part_1.ipynb) - A tutorial on the TableGen language.

[sql_query_backend.ipynb](sql_query_backend.ipynb) - How to write a backend using
JSON output and Python.

Notebooks can be viewed in browser on Github or downloaded and run locally. If
that is not possible, there are Markdown versions next to the notebook files.

## TableGen Kernel

To use the kernel, first install it into jupyter.

If you have installed Jupyter into a virtual environment, adjust `python3` to
be the interpreter for that environment. This will ensure that tools run the
kernel in the correct context.

```shell
    python3 -m tablegen_kernel.install
```

If you are going to open the notebook in an IDE like Visual Studio Code,
you should restart it now so that it will find the newly installed kernel.

Then run one of:

```shell
    jupyter notebook
    # Then in the notebook interface, select 'LLVM TableGen' from the 'New' menu.

    # To run the example notebook in this folder.
    jupyter notebook LLVM_TableGen.ipynb

    # To use the kernel from the command line.
    jupyter console --kernel tablegen
```

Or open the notebook in a tool with built in Jupyter support.

`llvm-tblgen` is expected to be either in the `PATH` or you can set
the environment variable `LLVM_TBLGEN_EXECUTABLE` to point to it directly.

If you see an error like this:
```shell
  Cell In[8], line 2
    // This is some tablegen
    ^
SyntaxError: invalid syntax
```

You are probably running the notebook using the iPython kernel. Make sure you
 have selected the tablegen kernel.

To run the kernel's doctests do:

```shell
    python3 tablegen_kernel/kernel.py
```