Virtual Machine used to represent, run, and maintain the state of programs for Scratch 3.0
Find a file
2016-06-30 18:56:23 -04:00
playground Update playground to use unified interface and worker 2016-06-21 15:30:36 -04:00
src Rename primitiveReturnValue -> primitiveReportedValue 2016-06-30 18:56:23 -04:00
test Add regression test for adapter's empty field handling 2016-06-14 18:14:15 -04:00
.editorconfig Add .editorconfig 2016-06-08 16:27:38 -04:00
.eslintrc Allow console timers 2016-06-30 18:56:23 -04:00
.gitignore Initial commit 2016-04-08 13:10:37 -04:00
.travis.yml Add travis config 2016-04-18 17:22:23 -04:00
LICENSE Initial commit 2016-03-28 12:53:44 -04:00
Makefile Add dev server to help with WebWorker development 2016-06-21 14:42:24 -04:00
package.json Use absolute version number for webpack-dev-server 2016-06-21 15:28:47 -04:00
README.md Update README.md with new block change listener calls 2016-06-08 17:30:22 -04:00
TRADEMARK Initial commit 2016-03-28 12:53:44 -04:00
vm.js Recompile June 8 2016-06-08 17:31:18 -04:00
vm.min.js Recompile June 8 2016-06-08 17:31:18 -04:00
webpack.config.js Implement WebWorker interface 2016-06-21 15:30:27 -04:00

scratch-vm

Scratch VM is a library for representing, running, and maintaining the state of computer programs written using Scratch Blocks.

Build Status Dependency Status devDependency Status

Installation

npm install scratch-vm

Setup

var VirtualMachine = require('scratch-vm');
var vm = new VirtualMachine();

// Block events
workspace.addChangeListener(vm.blockListener);
var flyoutWorkspace = workspace.toolbox_.flyout_.workspace_;
flyoutWorkspace.addChangeListener(vm.flyoutBlockListener);

// Run threads
vm.runtime.start();

Standalone Build

make build
<script src="/path/to/vm.js"></script>
<script>
    var vm = new window.VirtualMachine();
    // do things
</script>

Abstract Syntax Tree

Overview

The Virtual Machine constructs and maintains the state of an Abstract Syntax Tree (AST) by listening to events emitted by the scratch-blocks workspace via the blockListener. At any time, the current state of the AST can be viewed by inspecting the vm.runtime.blocks object.

Anatomy of a Block

{
    "7AJZR#NA;m*b}R]pdq63": {
      "id": "7AJZR#NA;m*b}R]pdq63",
      "opcode": "control_wait",
      "inputs": {
        "DURATION": {
          "name": "DURATION",
          "block": ",xA8/S!Z6+kR,9dph.rO"
        }
      },
      "fields": {},
      "next": null,
      "topLevel": true
    },
    ",xA8/S!Z6+kR,9dph.rO": {
      "id": ",xA8/S!Z6+kR,9dph.rO",
      "opcode": "math_number",
      "inputs": {},
      "fields": {
        "NUM": {
          "name": "NUM",
          "value": "1"
        }
      },
      "next": null,
      "topLevel": false
    }
  }

Testing

make test
make coverage

Donate

We provide Scratch free of charge, and want to keep it that way! Please consider making a donation to support our continued engineering, design, community, and resource development efforts. Donations of any size are appreciated. Thank you!