package dune-glob

  1. Overview
  2. Docs
Glob string matching language supported by dune

Install

Dune Dependency

Authors

Maintainers

Sources

dune-3.15.3.tbz
sha256=3c27c7676414056f0368a71fdc670d2b0a59898090c78a1b68230984e5beb713
sha512=c88ac7a6ed9334a4bc6231ecfb0efaa961dda99bc386fd5b92505151ff833dfaf058d75305fbb64c496e570058ec9000ac6add06dda7a395e757e924af1d1a7f

doc/index.html

dune-glob - file globbing

Introduction

A glob is a way of referring to a set of files that match a certain pattern, such as "files with the .ml extension" or "files with test in their name".

dune-glob exposes an abstraction so that we can refer to the first group as *.ml and the second one as *test*.

This library is used by Dune to implement this syntax in several places in dune files, but it can be used in other contexts as well.

Example

This is an executable that takes a glob as a command line argument, and lists the contents of the current directory that matches it:

let () =
  let glob_string = Sys.argv.(1) in
  let glob = Dune_glob.V1.of_string glob_string in
  let files = Sys.readdir "." in
  ArrayLabels.iter files ~f:(fun n ->
    if Dune_glob.V1.test glob n then
      print_endline n)

API documentation

The entry point for this library is Dune_glob.V1.

Note on stability

This library is fairly stable, but does not come with strong stability guarantees. In particular, while the module name suggests the API is versioned, it is not in the strict sense.

OCaml

Innovation. Community. Security.