Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/drjson/stackedit-wavedrom

User extension for StackEdit that supports WaveDrom graphs.
https://github.com/drjson/stackedit-wavedrom

Last synced: 3 months ago
JSON representation

User extension for StackEdit that supports WaveDrom graphs.

Awesome Lists containing this project

README

        

# Making StackEdit Work With WaveDrom
A user extension hack for StackEdit. [View on StackEdit](https://stackedit.io/viewer#!url=https://raw.github.com/drjson/stackedit-wavedrom/master/README.md).
![Example Screenshot](https://raw.githubusercontent.com/drjson/stackedit-wavedrom/master/screenshot.png "Example Screenshot")

[TOC]

## Overview
I wanted to integrate the excellent [WaveDrom][1] timing diagram tool within the [StackEdit][2] tool for documentation of hardware timing. This documents the required settings and items for getting it to work. Open this document in StackEdit to confirm operation of the plugin by viewing the included examples.

## Implementation
### Theory of Operation
Using the StackEdit user extension, a fenced code block is used which has the type of `wavedrom`. This code block is replaced with a `` block compatible with WaveDrom during the editor output generation. In the case of exporting to HTML template, this is compatible with the WaveDrom `ProcessAll()` function or with the user extension for the preview.

### Current Version and Limitations
Currently the preview and export is working with a custom user extension by utilizing the fencing code blocks with a type of `wavedrom`. You can also use the templates and view the output in the templated HTML output. This plugin works with StackEdit version 4.

### Installation
#### User Extension Code
Copy the following code into the user extension area of StackEdit under `Settings->Extensions->UserCustom Extension`.
```javascript
// create <script>
var waveDromScript = document.createElement('script');
waveDromScript.src = 'https://cdnjs.cloudflare.com/ajax/libs/wavedrom/1.6.2/wavedrom.js';

var waveDromTheme = document.createElement('script');
waveDromTheme.src = 'https://cdnjs.cloudflare.com/ajax/libs/wavedrom/1.6.2/skins/default.js';

// append <script>
var firstScript = document.getElementsByTagName('script')[0];
firstScript.parentNode.insertBefore(waveDromTheme, firstScript);
firstScript.parentNode.insertBefore(waveDromScript, firstScript);

// Setup parsing
userCustom.onPagedownConfigure = function(editor) {
var previewContentsElt = document.getElementById('preview-contents');
editor.hooks.chain("onPreviewRefresh", function() {
$(previewContentsElt)
.find('.prettyprint > .language-wavedrom')
.each(function()
{
$(this).replaceWith("<script type=\"WaveDrom\">"
+ this.textContent
+ "");
});
});
};

// Callback to update the preview pane.
userCustom.onPreviewFinished = function() {
var index = 0;

$('#preview-contents script[type=WaveDrom]').each(function() {
$(this).parent().children().not('script').remove();
$(this).attr("id","WaveDrom_JSON_"+index);

$(this).parent().append('

');
WaveDrom.RenderWaveForm(index, WaveDrom.eva(this.id), 'WaveDrom_Display_');
index++;
});

};
```

#### Template Output Updates
In order to export to a standalone HTML file, add the following to the default template (`Settings->Advanced->Default Template`) in the `` tag:
```html

```

And add the following to the `` tag of the template:
```html

```

When exporting, choose Template instead of HTML or Markdown. This can be combined with other custom templates.

### Examples
Examples from [WaveDrom tutorials](http://wavedrom.com/tutorial.html).

#### Simple Example

```wavedrom
{ signal : [
{ name: "clk", wave: "p......" },
{ name: "bus", wave: "x.34.5x", data: "head body tail" },
{ name: "wire", wave: "0.1..0." },
{ name: "additional", wave: "0...1.." }
]}
```

#### Spacers and Gaps
```wavedrom
{ signal: [
{ name: "clk", wave: "p.....|..." },
{ name: "Data", wave: "x.345x|=.x", data: ["head", "body", "tail", "data"] },
{ name: "Request", wave: "0.1..0|1.0" },
{},
{ name: "Acknowledge", wave: "1.....|01." }
]}
```

#### DDR Timing

```wavedrom
{ signal: [
{ name: "CK", wave: "P.......", period: 2 },
{ name: "CMD", wave: "x.3x=x4x=x=x=x=x", data: "RAS NOP CAS NOP NOP NOP NOP", phase: 0.5 },
{ name: "ADDR", wave: "x.=x..=x........", data: "ROW COL", phase: 0.5 },
{ name: "DQS", wave: "z.......0.1010z." },
{ name: "DQ", wave: "z.........5555z.", data: "D0 D1 D2 D3" }
]}
```

#### Headers, Footers, and Indexes

```wavedrom
{signal: [
{name:'clk', wave: 'p.....PPPPp....' },
{name:'dat', wave: 'x....2345x.....', data: 'a b c d' },
{name:'req', wave: '0....1...0.....' }
],
head: {text:
['tspan',
['tspan', {class:'error h1'}, 'error '],
['tspan', {class:'warning h2'}, 'warning '],
['tspan', {class:'info h3'}, 'info '],
['tspan', {class:'success h4'}, 'success '],
['tspan', {class:'muted h5'}, 'muted '],
['tspan', {class:'h6'}, 'h6 '],
'default ',
['tspan', {fill:'pink', 'font-weight':'bold', 'font-style':'italic'}, 'pink-bold-italic']
]
},
foot: {text:
['tspan', 'E=mc',
['tspan', {dy:'-5'}, '2'],
['tspan', {dy: '5'}, '. '],
['tspan', {'font-size':'25'}, 'B '],
['tspan', {'text-decoration':'overline'},'over '],
['tspan', {'text-decoration':'underline'},'under '],
['tspan', {'baseline-shift':'sub'}, 'sub '],
['tspan', {'baseline-shift':'super'}, 'super ']
],tock:-5
}
}
```
#### Logic Diagrams

```wavedrom
{assign:[
["out",
["|",
["&", ["~", "a"], "b"],
["&", ["~", "b"], "a"]
]
],
["y", ["~", "x"]],
["y", ["=", "x"]],
["y", ["&", "a" ,"b"]],
["y", ["~&", "a", "b"]],
["y", ["|", "a", "b"]],
["y", ["~|", "a", "b"]],
["y", ["^", "a", "b"]],
["y", ["~^", "a", "b"]],
["y", ["+", "a", "b"]],
["y", ["*", "a", "b"]]
]}
```

#### Register description

```wavedrom
{reg: [
{bits: 8, name: 'IPO', attr: 'RO'},
{bits: 7},
{bits: 5, name: 'BRK', attr: 'RW'},
{bits: 1, name: 'CPK'},
{bits: 3, name: 'Clear'},
{bits: 8}
]}
```

[1]: http://wavedrom.com "WaveDrom"
[2]: http://stackedit.io "StackEdit"