# Raku Text::CodeProcessing [![Build Status](https://app.travis-ci.com/antononcube/Raku-Text-CodeProcessing.svg?branch=main)](https://app.travis-ci.com/github/antononcube/Raku-Text-CodeProcessing) [![License: Artistic-2.0](https://img.shields.io/badge/License-Artistic%202.0-0298c3.svg)](https://opensource.org/licenses/Artistic-2.0) ## In brief The main goal of this package is to facilitate [Literate Programming](https://en.wikipedia.org/wiki/Literate_programming) with Raku. The package has functions and a script for the evaluations of code chunks in documents of different types (like [Markdown](https://daringfireball.net/projects/markdown/), [Org Mode](https://orgmode.org), [Pod6](https://docs.raku.org/language/pod).) ------ ## Installation Package installations from both sources use [zef installer](https://github.com/ugexe/zef) (which should be bundled with the "standard" [Rakudo](https://rakudo.org) installation file.) To install the package from [Raku Modules / PAUSE](https://modules.raku.org) use the shell command: ``` zef install Text::CodeProcessing ``` To install the package from the GitHub repository use the shell command: ``` zef install https://github.com/antononcube/Raku-Text-CodeProcessing.git ``` ------ ## Usage ### Main function The package provides the function `FileCodeChunksEvaluation` for the evaluation of code chunks in files. The first argument is a file name string: ```perl6 FileCodeChunksEvaluation( $fileName, ... ) ``` Here are the (optional) parameters: - `Str :$outputFileName` : output file name - `Str :$evalOutputPrompt = 'AUTO'` : code chunk output prompt - `Str :$evalErrorPrompt = 'AUTO'` : code chunk error prompt - `Bool :$noteOutputFileName = False` : whether to print out the name of the new file - `Bool :$promptPerLine = True` : whether to put prompt to each output or error line or just the first one When the prompt arguments are given the value `'AUTO'` then the actual prompt values are selected according to the file type: - Markdown : `evalOutputPrompt = '# '`, `evalErrorPrompt = '#ERROR: '` - Org-mode : `evalOutputPrompt = ': '`, `evalErrorPrompt = ':ERROR: '` - Pod6 : `evalOutputPrompt = '# '`, `evalErrorPrompt = '#ERROR: '` ### Scripts The [directory "./examples"](./examples) has a script files, [`file-code-chunks-eval`](bin/file-code-chunks-eval) and [`file-code-chunks-extract`](bin/file-code-chunks-extract), that can be used from the command line. Here are script invocation examples for the code chunks evaluation in a file named "doc.md": ```shell file-code-chunks-eval doc.md ``` ```shell file-code-chunks-eval file-code-chunks-eval.raku --evalOutputPrompt="## OUTPUT :: " --evalErrorPrompt="## ERROR :: " -o=doc_newly_weaved.md doc.md ``` Here is a script invocation example for code extraction from code chunks in a file named "doc.md": ```shell file-code-chunks-extract -o=doc_new_extract.md doc.md ``` If no output file name is specified then the script [`file-code-chunks-eval`](bin/file-code-chunks-eval) ([`file-code-chunks-extract`](bin/file-code-chunks-extract)) makes a new file in the same directory with the string "_woven" ("_tangled") inserted into the input file name. ------ ## Implementation notes The implementation uses a greatly reduced version of the class [`Jupyter::Kernel::Sandbox`](https://github.com/bduggan/p6-jupyter-kernel/blob/master/lib/Jupyter/Kernel/Sandbox.rakumod) of Raku Jupyter kernel package/repository [BD1]. (See the class [REPLSandbox](./lib/Text/CodeProcessing/REPLSandbox.rakumod).) Just using [`EVAL`](https://docs.raku.org/routine/EVAL), (as in [SO1]) did not provide state persistence between code chunks evaluations. For example, creating and assigning variables or loading packages in the first code chunk did not make those variables and packages "available" in the subsequent code chunks. That problem is resolved by setting up a separate Raku REPL (sandbox) object. ----- ## TODO The following TODO items are ordered by priority, the most important are on top. - [X] Provide a function that works on strings. (By refactoring the main function `FileCodeChunksEvaluation`.) - [ ] Add unit tests for: - [X] Code chunks evaluation - [X] Persistence of REPL state(s) - [ ] REPL availability - [X] File code chunks evaluation - [X] File code extraction from chunks - [X] Implement handling of code chunk parameters. - [ ] Implement data arguments for code chunks. (As in [Babel org-mode](https://orgmode.org/manual/Environment-of-a-Code-Block.html).) - [ ] Implement evaluation of Raku code chunks in Mathematica notebooks. - [ ] Make the functionalities to work with languages other than Raku. - This is both difficult and low priority. - [X] Comprehensive help for the CLI functions. ----- ## References [BD1] Brian Duggan et al., [p6-jupyter-kernel](https://github.com/bduggan/p6-jupyter-kernel), (2017-2020), [GitHub/bduggan](https://github.com/bduggan). [DS1] Daniel Sockwell, ["Weaving Raku: semiliterate programming in a beautiful language"](https://www.codesections.com/blog/weaving-raku/), (2020), [codesections.com](https://www.codesections.com). [SO1] Suman Khanal et al., ["Capture and execute multiline code and incorporate result in raku"](https://stackoverflow.com/q/57127263), (2017), [Stack Overflow](https://stackoverflow.com).