All Projects → vcs-python → Vcspull

vcs-python / Vcspull

Licence: mit
🔄 synchronize projects via yaml/json manifest. built on libvcs

Programming Languages

python
139335 projects - #7 most used programming language

Projects that are alternatives of or similar to Vcspull

Tmuxp
💻 tmux session manager. built on libtmux
Stars: ✭ 3,269 (+1648.13%)
Mutual labels:  cli-utilities, cli, terminal, json, yaml
Cli
A simple, fast, and fun package for building command line apps in Go
Stars: ✭ 16,995 (+8988.24%)
Mutual labels:  cli, json, yaml
Autoserver
Create a full-featured REST/GraphQL API from a configuration file
Stars: ✭ 188 (+0.53%)
Mutual labels:  cli, json, yaml
Yaspin
A lightweight terminal spinner for Python with safe pipes and redirects 🎁
Stars: ✭ 413 (+120.86%)
Mutual labels:  cli-utilities, cli, terminal
Http Prompt
An interactive command-line HTTP and API testing client built on top of HTTPie featuring autocomplete, syntax highlighting, and more. https://twitter.com/httpie
Stars: ✭ 8,329 (+4354.01%)
Mutual labels:  cli, terminal, json
Remarshal
Convert between CBOR, JSON, MessagePack, TOML, and YAML
Stars: ✭ 421 (+125.13%)
Mutual labels:  cli, json, yaml
Httpie
As easy as /aitch-tee-tee-pie/ 🥧 Modern, user-friendly command-line HTTP client for the API era. JSON support, colors, sessions, downloads, plugins & more. https://twitter.com/httpie
Stars: ✭ 53,052 (+28270.05%)
Mutual labels:  cli, terminal, json
Yq
Command-line YAML, XML, TOML processor - jq wrapper for YAML/XML/TOML documents
Stars: ✭ 1,688 (+802.67%)
Mutual labels:  cli, json, yaml
Dasel
Query, update and convert data structures from the command line. Comparable to jq/yq but supports JSON, TOML, YAML, XML and CSV with zero runtime dependencies.
Stars: ✭ 759 (+305.88%)
Mutual labels:  cli, json, yaml
Structured Text Tools
A list of command line tools for manipulating structured text data
Stars: ✭ 6,180 (+3204.81%)
Mutual labels:  cli, json, yaml
Swagger Merger
🔗 Merge multiple swagger files into a swagger file, support JSON/YAML.
Stars: ✭ 94 (-49.73%)
Mutual labels:  cli, json, yaml
Oq
A performant, and portable jq wrapper to facilitate the consumption and output of formats other than JSON; using jq filters to transform the data.
Stars: ✭ 132 (-29.41%)
Mutual labels:  cli, json, yaml
Models
WordPress plugin to create custom post types and taxonomies using JSON, YAML or PHP files
Stars: ✭ 167 (-10.7%)
Mutual labels:  json, yaml
Source Integration
Source control integration plugin framework for MantisBT, including support for Github, Gitlab, Bitbucket, Gitweb, Cgit, Subversion, Mercurial and more
Stars: ✭ 167 (-10.7%)
Mutual labels:  svn, vcs
Cash Cli
💰💰 Convert currency rates directly from your terminal!
Stars: ✭ 168 (-10.16%)
Mutual labels:  cli, terminal
Vcs
VCS Repo management through a common interface in Go
Stars: ✭ 171 (-8.56%)
Mutual labels:  svn, vcs
Grex
A command-line tool and library for generating regular expressions from user-provided test cases
Stars: ✭ 4,847 (+2491.98%)
Mutual labels:  cli, terminal
Related
Nested Object Models in Python with dictionary, YAML, and JSON transformation support
Stars: ✭ 169 (-9.63%)
Mutual labels:  json, yaml
Tlog
Terminal I/O logger
Stars: ✭ 170 (-9.09%)
Mutual labels:  terminal, json
Live Stream Radio
24/7 live stream video radio station CLI / API 📹 📻
Stars: ✭ 175 (-6.42%)
Mutual labels:  cli, json

vcspull - synchronize your repos. built on libvcs_

|pypi| |docs| |build-status| |coverage| |license|

Manage your commonly used repos from YAML / JSON manifest(s). Compare to myrepos_.

Great if you use the same repos at the same locations across multiple machines or want to clone / update a pattern of repos without having to cd into each one.

  • clone /update to the latest repos with $ vcspull
  • use filters to specify a location, repo url or pattern in the manifest to clone / update
  • supports svn, git, hg version control systems
  • automatically checkout fresh repositories
  • Documentation_ and Examples_.
  • supports pip-style URL's (RFC3986-based url scheme_)

.. _myrepos: http://myrepos.branchable.com/

how to

install """""""

.. code-block:: sh

$ pip install --user vcspull

configure """""""""

add repos you want vcspull to manage to ~/.vcspull.yaml.

vcspull does not currently scan for repos on your system, but it may in the future

.. code-block:: yaml

~/code/:
  flask: "git+https://github.com/mitsuhiko/flask.git"
~/study/c:
  awesome: 'git+git://git.naquadah.org/awesome.git'
~/study/data-structures-algorithms/c:
  libds: 'git+https://github.com/zhemao/libds.git'
  algoxy: 
    repo: 'git+https://github.com/liuxinyu95/AlgoXY.git'
    remotes:
      tony: 'git+ssh://[email protected]/tony/AlgoXY.git'

(see the author's .vcspull.yaml, more examples.)

next, on other machines, copy your $HOME/.vcspull.yaml file or $HOME/.vcspull/ directory them and you can clone your repos consistently. vcspull automatically handles building nested directories. Updating already cloned/checked out repos is done automatically if they already exist.

clone / update your repos """""""""""""""""""""""""

.. code-block:: bash

$ vcspull

keep nested VCS repositories updated too, lets say you have a mercurial or svn project with a git dependency:

external_deps.yaml in your project root, (can be anything):

.. code-block:: yaml

./vendor/: sdl2pp: 'git+https://github.com/libSDL2pp/libSDL2pp.git'

clone / update repos::

$ vcspull -c external_deps.yaml

See the Quickstart_ for more.

pulling specific repos """"""""""""""""""""""

have a lot of repos?

you can choose to update only select repos through fnmatch_ patterns. remember to add the repos to your ~/.vcspull.{json,yaml} first.

The patterns can be filtered by by directory, repo name or vcs url.

.. code-block:: bash

# any repo starting with "fla"
$ vcspull "fla*"
# any repo with django in the name
$ vcspull "*django*"

# search by vcs + url
# since urls are in this format <vcs>+<protocol>://<url>
$ vcspull "git+*"

# any git repo with python in the vcspull
$ vcspull "git+*python*

# any git repo with django in the vcs url
$ vcspull "git+*django*"

# all repositories in your ~/code directory
$ vcspull "$HOME/code/*"

.. image:: https://raw.github.com/vcs-python/vcspull/master/doc/_static/vcspull-demo.gif :scale: 100% :width: 45% :align: center

Donations

Your donations fund development of new features, testing and support. Your money will go directly to maintenance and development of the project. If you are an individual, feel free to give whatever feels right for the value you get out of the project.

See donation options at https://git-pull.com/support.html.

More information

.. _MIT: https://opensource.org/licenses/MIT .. _Documentation: https://vcspull.git-pull.com/ .. _Quickstart: https://vcspull.git-pull.com/quickstart.html .. _pip: http://www.pip-installer.org/ .. _url scheme: http://www.pip-installer.org/logic.html#vcs-support .. _libvcs: https://github.com/vcs-python/libvcs .. _RFC3986: http://tools.ietf.org/html/rfc3986.html .. _.vcspull.yaml: https://github.com/tony/.dot-config/blob/master/.vcspull.yaml .. _examples: https://vcspull.git-pull.com/examples.html .. _fnmatch: http://pubs.opengroup.org/onlinepubs/009695399/functions/fnmatch.html

.. |pypi| image:: https://img.shields.io/pypi/v/vcspull.svg :alt: Python Package :target: http://badge.fury.io/py/vcspull

.. |docs| image:: https://github.com/vcs-python/vcspull/workflows/Publish%20Docs/badge.svg :alt: Docs :target: https://github.com/vcs-python/vcspull/actions?query=workflow%3A"Publish+Docs"

.. |build-status| image:: https://github.com/vcs-python/vcspull/workflows/tests/badge.svg :alt: Build Status :target: https://github.com/vcs-python/vcspull/actions?query=workflow%3A"tests"

.. |coverage| image:: https://codecov.io/gh/vcs-python/vcspull/branch/master/graph/badge.svg :alt: Code Coverage :target: https://codecov.io/gh/vcs-python/vcspull

.. |license| image:: https://img.shields.io/github/license/vcs-python/vcspull.svg :alt: License

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].