cat function Null safety

Future<int> cat(
  1. List<String> paths,
  2. {List<String>? log,
  3. bool showEnds = false,
  4. bool numberNonBlank = false,
  5. bool showLineNumbers = false,
  6. bool showTabs = false,
  7. bool squeezeBlank = false}
)

Concatenates files in paths to stdout

The parameters are similar to the GNU cat utility. Specify a log for debugging purpose.

Implementation

Future<int> cat(List<String> paths,
    {List<String>? log,
    bool showEnds = false,
    bool numberNonBlank = false,
    bool showLineNumbers = false,
    bool showTabs = false,
    bool squeezeBlank = false}) async {
  var lineNumber = 1;
  var returnCode = 0;
  log?.clear();
  if (paths.isEmpty) {
    final lines = await _readStdin();
    await _writeLines(lines, lineNumber, log, showEnds, showLineNumbers,
        numberNonBlank, showTabs, squeezeBlank);
  } else {
    for (final path in paths) {
      try {
        final Stream<String> lines;
        if (path == '-') {
          lines = await _readStdin();
        } else {
          lines = utf8.decoder
              .bind(File(path).openRead())
              .transform(const LineSplitter());
        }
        lineNumber = await _writeLines(lines, lineNumber, log, showEnds,
            showLineNumbers, numberNonBlank, showTabs, squeezeBlank);
      } on FileSystemException catch (e) {
        final String? osMessage = e.osError?.message;
        final String message;
        if (osMessage != null && osMessage.isNotEmpty) {
          message = osMessage;
        } else {
          message = e.message;
        }
        returnCode = await printError(message, path: path);
      } on FormatException {
        returnCode = await printError('Binary file not supported.', path: path);
      } catch (e) {
        returnCode = await printError(e.toString(), path: path);
      }
    }
  }
  return returnCode;
}