Let's start by looking at some of the built-in functions that DCli supports.
DCli exposes a range of built-in functions that are exposed as Dart global functions.
These functions are the core of how DCli provides a very Bash-like feel to writing DCli scripts.
These functions make strong use of named arguments with intelligent defaults so mostly you can use the minimal form of the function.
Take note, there are no Futures or awaits here. Each function runs synchronously.
import'package:path/path.dart';import'package:dcli/dcli.dart';voidmain() {// Use the global DCli Settings to enable debug output.Settings().setVerbose(enabled:true);// Print the current working directoryprint('PWD: ${pwd}');// Create a directory and if necessary// its parent directories.var pathToImages ='tools/images';createDir(pathToImages, recursive:true);var pathToGoodJpg =join(pathToImages, 'good.jpg');// create a file (it's empty)touch(pathToGoodJpg, create:true);// update the last modified time on an existing filetouch(pathToGoodJpg);print('Showing all files');// print out all files in the current directory.// [file] is just a [String]find('*.*', recursive:false).forEach((file) =>print(file));// take a nap for a couple of seconds.sleep(2);print('Find file matching *.jpg');// Find all files that end with .jpg// in the current directory and any subdirectoriesfor (var file infind('*.jpg', workingDirectory: pathToImages).toList()) {print(file); }var pathToBadJpg =join(pathToImages, "bad.jpg");// Move/rename a filemove(pathToGoodJpg, pathToBadJpg);// check if a file exists.if (exists(pathToBadJpg)) {print("bad.jpg exists"); }// Delete a file asking the user first.delete(pathToBadJpg, ask:true);}
As you can see we have achieved much of the power of Bash without any of the ugly grammar, and what's more we only used one type of quote!