Skip to content

Latest commit

 

History

History
43 lines (29 loc) · 2.57 KB

README.md

File metadata and controls

43 lines (29 loc) · 2.57 KB

Recent statistics can be found at

Requirements

  • Node.js version 12+
  • npm
  • A bunch of code files (.xml or .catrobat).

Install

  • Install npm dependencies with npm install

Usage

  • Calculate statistics by using
    • npm start -- <arguments> (note the additional --) or
    • node --experimental-modules --es-module-specifier-resolution=node --experimental-worker index.js <arguments>
argument description status default
‑‑program‑folder A single .xml or .catrobat file, or a folder which will be searched recursively for .xml or .catrobat files required, deprecating
‑‑output‑file If specified, the output JSON will be written to the file. If not specified, the output will be written to the console which can be useful by using the > operator (e.g. node ... > path/to/statistics.json) optional
-‑‑cache‑folder- By setting a cache folder, calculated statistics of each program will be stored. This drastically improves performance if you calculate statistics on all of these programs. However, each time you change program‑stats.js and related source files, clear the cache folder. not working
‑‑workers Speeds up calculating statistics for each program by using as many forked workers as possible. By using 1, no workers will be forked (helpful for debugging). #cpus

Example

  • npm start -- --program-folder path/to/programs --output-file path/to/output/statistics.json (note the additional --)
  • node --experimental-modules --es-module-specifier-resolution=node --experimental-worker index.js --program-folder path/to/programs --output-file path/to/output/statistics.json

Troubleshoot

  • UNKNOWN_VALUE is caused when using npm start and you forget to add -- to separate npm start from the program arguments. See examples on how to use it.
  • index.js is a link pointing to src/index.js. It may cause problems on some machines. Just try node ... src/index ... instead.

Test

  • Place tests in the test/assets folder. Each test is a folder containing a
    • code.xml
    • stats.json. It isn't necessary to place all data in the json, only set, not empty, not 0 ones. A skeleton is used to fill out the data which is specified at text/utils.js.
  • Run npm test (don't forget to install dependencies by running npm install first)