#vfx #clique #filesequence

bin+lib cliquers

Manage filesequences with a common numeric component

4 releases (breaking)

0.3.0 Jul 8, 2020
0.2.0 Jul 1, 2020
0.1.0 Jun 29, 2020
0.0.1 Jun 21, 2020

#1446 in Data structures

Apache-2.0

37KB
825 lines

Cliquers

crates.io

Manage filesequences with a common numeric component in Rust.

Usage

Using the commandline

$ cliquers --help
cliquers 0.2.0

USAGE:
    cliquers [FLAGS] [OPTIONS] [--] [paths]...

FLAGS:
    -h, --help              Prints help information
    -r, --recurse           Recurse down subdirectories
    -s, --show-remainder    Print files not in a collection
    -V, --version           Prints version information

OPTIONS:
    -f, --format <format>           Optional format of filesequences, default format: "{head}{padding}{tail} [{ranges}]"
    -p, --patterns <patterns>...    Optional custom pattern for grouping collections of files, default pattern:
                                    "(?P<index>(?P<padding>0*)\d+)"

ARGS:
    <paths>...    The path to list files and filesequences under
$ cliquers /shot/task/main
/shot/task/main/render.%04d.exr [1001-1005]

$ cliquers -r /shot/task
/shot/task/main/render.%04d.exr [1001-1005]
/shot/task/foo/render.%04d.exr [1001-1005]
/shot/task/bar/render.%04d.exr [1001-1005]

$ cliquers --format "{head}####{tail}" /shot/task/main
/shot/task/main/render.####.exr

$ cliquers --patterns "v(?P<index>(?P<padding>0*)\d+)" /shot/task/main
/shot/task/main/render.1001.exr
/shot/task/main/render.1002.exr
/shot/task/main/render.1003.exr
/shot/task/main/render.1004.exr
/shot/task/main/render.1005.exr

$ cliquers --patterns "(?P<index>(?P<padding>0*)\d+)" /shot/task/main
/shot/task/main/render.%04d.exr [1001-1005]

Using the library

use cliquers;

let files = vec![
    "/shot/task/main/render.1001.exr",
    "/shot/task/main/render.1002.exr",
    "/shot/task/main/render.1003.exr",
    "/shot/task/main/render.1004.exr",
    "/shot/task/main/render.1005.exr",
];
let (collections, remainders) = cliquers.assemble(&files, None);
let c = &collections[0];

// access structure of file sequence
assert_eq!(c.head, "/shot/task/main/render.");
assert_eq!(c.tail, ".exr");
assert_eq!(c.padding, 4);
assert_eq!(c.indexes, vec![1001, 1002, 1003, 1004, 1005]);
assert_eq!(c.format(None), "/shot/task/main/render.%04d.exr [1001-1005]");
assert_eq!(c.format(Some("{head}####{tail}")), "/shot/task/main/render.####.exr");

// iterate over files of filesequence
let mut iter = c.into_iter();
assert_eq!(iter.next(), Some("/shot/task/main/render.1001.exr".to_string()));

Documentation

Origin

This library is a direct port of the fantastic Python module Clique.

This is still a work in progress, so is not a complete port... yet!

Dependencies

~7MB
~125K SLoC