EnglishFrenchSpanish

Ad


OnWorks favicon

git-clone-subset - Online in the Cloud

Run git-clone-subset in OnWorks free hosting provider over Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator

This is the command git-clone-subset that can be run in the OnWorks free hosting provider using one of our multiple free online workstations such as Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator

PROGRAM:

NAME


git-clone-subset - Clones a subset of a git repository

SYNOPSIS


git-clone-subset [options] repository destination-dir pattern

DESCRIPTION


Clones a repository into a destination-dir and runs on the clone
git filter-branch --prune-empty --tree-filter 'git rm ...' -- --all
to prune from history all files except the ones matching pattern, effectively creating a
clone with a subset of files (and history) of the original repository.

Useful for creating a new repository out of a set of files from another repository,
migrating (only) their associated history. Very similar to what
git filter-branch --subdirectory-filter
does, but for a file pattern instead of just a single directory.

OPTIONS


-h, --help
show usage information.

repository
URL or local path to the git repository to be cloned.

destination-dir
Directory to create the clone. Same rules for git-clone applies: it will be
created if it does not exist and it must be empty otherwise. But, unlike git-
clone, this argument is not optional: git-clone uses several rules to determine
the "Humane" dir name of a cloned repo, and git-clone-subset will not risk parse
its output, let alone predict the chosen name.

pattern Glob pattern to match the desired files/dirs. It will be ultimately evaluated by a
call to bash, NOT git or sh, using extended glob '!(<pattern>)' rule. Quote it or
escape it on command line, so it does not get evaluated prematurely by your
current shell. Only a single pattern is allowed: if more are required, use
extglob's "|" syntax. Globs will be evaluated with bash's shopt dotglob set, so
beware. Patterns should not contain spaces or special chars like " ' $ ( ) { } `,
not even quoted or escaped, since that might interphere with the !() syntax after
pattern expansion.

Pattern Examples:

"*.png"
"*.png|*icon*"
"*.h|src/|lib"

LIMITATIONS


Renames are NOT followed. As a workaround, list the rename history with 'git log --follow
--name-status --format='%H' -- file | grep "^[RAD]"' and include all multiple names of a
file in the pattern, as in "currentname|oldname|initialname". As a side efect, if a
different file has taken place of an old name, it will be preserved too, and there is no
way around this using this tool.

There is no (easy) way to keep some files in a dir: using 'dir/foo*' as pattern will not
work. So keep the whole dir and remove files afterwards, using git filter-branch and a
(quite complex) combination of cloning, remote add, rebases, etc.

Pattern matching is quite limited, and many of bash's escaping and quoting does not work
properly when pattern is expanded inside !().

Use git-clone-subset online using onworks.net services


Free Servers & Workstations

Download Windows & Linux apps

  • 1
    Firebird
    Firebird
    Firebird RDBMS offers ANSI SQL features
    & runs on Linux, Windows &
    several Unix platforms. Features
    excellent concurrency & performance
    & power...
    Download Firebird
  • 2
    KompoZer
    KompoZer
    KompoZer is a wysiwyg HTML editor using
    the Mozilla Composer codebase. As
    Nvu's development has been stopped
    in 2005, KompoZer fixes many bugs and
    adds a f...
    Download KompoZer
  • 3
    Free Manga Downloader
    Free Manga Downloader
    The Free Manga Downloader (FMD) is an
    open source application written in
    Object-Pascal for managing and
    downloading manga from various websites.
    This is a mirr...
    Download Free Manga Downloader
  • 4
    UNetbootin
    UNetbootin
    UNetbootin allows you to create bootable
    Live USB drives for Ubuntu, Fedora, and
    other Linux distributions without
    burning a CD. It runs on Windows, Linux,
    and ...
    Download UNetbootin
  • 5
    Dolibarr ERP - CRM
    Dolibarr ERP - CRM
    Dolibarr ERP - CRM is an easy to use
    ERP and CRM open source software package
    (run with a web php server or as
    standalone software) for businesses,
    foundations...
    Download Dolibarr ERP - CRM
  • 6
    SQuirreL SQL Client
    SQuirreL SQL Client
    SQuirreL SQL Client is a graphical SQL
    client written in Java that will allow
    you to view the structure of a JDBC
    compliant database, browse the data in
    tables...
    Download SQuirreL SQL Client
  • More »

Linux commands

Ad