GitHub issuesGitHub licenseCrates.ioGitHub all releasesDiscord

Diplo is a script runner and dependency manager made in rust mainly for Deno.

Documentation Tricked.pro/diplo

Installing

You can download diplo from the releases tab or install it using cargo install diplo

After that you can run diplo init for a interactive setup.
or use diplo init -y for a one command setup

Features

File watching

Diplo can replace Denon in terms of restarting on file change.
To restart a script on save you just have to append --watch to diplo run <script>

sh $ diplo run <script> --watch

Easy dependencies

Adding a new dependency is as simple as running diplo add natico or whatever else you need

Multiple dependencies at once are supported

$ diplo add natico info: Successfully added natico@3.0.0-rc.1 to the dependencies

adding std modules

$ diplo add -s fs info: Successfully added https://deno.land/std@0.110.0/fs/mod.ts to the dependencies

Add

Script running

You can easily create scripts like you do with npm and yarn

if you want to run the script just do diplo run start to run the start script.

json { "scripts": { "start": "deno run -A mod.ts", "node": "node index.js" } }

Toml

toml [scripts] start = "deno run -A mod.ts" node = "node index.js"

Dependencies

Diplo will automatically create a deps.ts file in the .diplo folder if you have dependencies specified in the diplo.json file

json { "dependencies": { "natico": "https://deno.land/x/natico/mod.ts", "server": "https://deno.land/std@0.110.0/http/server.ts" } }

Toml

toml [dependencies] natico= "https://deno.land/x/natico/mod.ts" server= "https://deno.land/std@0.110.0/http/server.ts"

Updating Dependencies

updating dependencies is a as simple as running diplo update note this will only update deno.land/x/ packages

$ diplo update info: updated discordeno to 12.0.1 from 11.0.1 info: updated harmony to v2.2.0 from v1.2.0 info: updated std to 0.110.0 from 0.10.0 info: updating done!

Import Map Support

Typescript users will have to add this to the vscode settings.json (.vscode/settings.json)

ts import * as server from 'server';

json { "import_map": true }

Toml

toml import_map=true

Dotenv Support

Diplo can automatically add environment variables using the rust dotenv module instead of the deno based one

json { "load_env": true }

Toml

toml load_env=true

Example Config

This is a example of a json config file located at diplo.json.
You can also use a toml config file named diplo.toml

json { "scripts": { "test": "deno run -A mod.ts", "build": "deno bundle a.ts" }, "import_map": false, "load_env": true, "dependencies": { "natico": "https://deno.land/x/natico/mod.ts" }, "watcher": { "directory": ".", "clear": true } }

Donating

You can support the project by donating to my xmr address 89prBkdG58KU15jv5LTbP3MgdJ2ikrcyu1vmdTKTGEVdhKRvbxgRN671jfFn3Uivk4Er1JXsc1xFZFbmFCGzVZNLPQeEwZc

License

This project is licensed under the terms of the Apache License 2.0