Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samuelcolvin/grablib
Static asset management in python
https://github.com/samuelcolvin/grablib
asset-builder asset-pipeline bower grablib javascript python sass
Last synced: 3 months ago
JSON representation
Static asset management in python
- Host: GitHub
- URL: https://github.com/samuelcolvin/grablib
- Owner: samuelcolvin
- License: mit
- Created: 2014-03-31T15:11:25.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2023-07-20T13:10:45.000Z (over 1 year ago)
- Last Synced: 2024-11-01T15:44:10.910Z (3 months ago)
- Topics: asset-builder, asset-pipeline, bower, grablib, javascript, python, sass
- Language: Python
- Homepage: https://pypi.org/project/grablib/
- Size: 253 KB
- Stars: 20
- Watchers: 4
- Forks: 3
- Open Issues: 5
-
Metadata Files:
- Readme: README.rst
- Changelog: HISTORY.rst
- License: LICENSE
Awesome Lists containing this project
README
grablib
=======|Build Status| |codecov.io| |PyPI Status| |license|
Copyright (C) 2013-2020 Samuel Colvin
Kind of like bower, but in Python, and simpler, and with some more features.
**grablib** can:
* download files from urls, including extracting selectively from zip files.
* create ``.grablib.lock`` which retains hashes of all downloaded files meaning assets can't change unexpectedly.
* compile sass/scss/css using `libsass`_.
* concatenate and minify javascript using `jsmin`_.Definition files can either be JSON or YAML (see `examples`_).
Installation
------------grablib requires **python 3.6+**.
.. code::
pip install grablib[build]
(You can also use simply ``pip install grablib`` to install without build requirements,
this is useful when you're not using grablib for building as it avoids installing
``jsmin`` and ``libsass`` which can be slow.)CLI Usage
---------Define your static files thus: (``grablib.yml``)
.. code:: yaml
download_root: 'static/libs'
download:
'http://code.jquery.com/jquery-1.11.3.js': 'js/jquery.js'
'https://github.com/twbs/bootstrap-sass/archive/v3.3.6.zip':
'bootstrap-sass-3.3.6/assets/(.+)$': 'bootstrap-sass/''GITHUB/codemirror/CodeMirror/5.8.0/lib/codemirror.js': 'codemirror/'
# simple scss file to import and compile bootstrap from above,
# generally this would be in your code
# this file just reads "@import 'bootstrap-sass/stylesheets/bootstrap';"
'https://git.io/v1Z5J': 'build_bootstrap.scss'debug: true
build_root: 'static/prod'
build:
# delete the entire static/prod directory before building, this is required for sass,
# and generally safer
wipe: '.*'
cat:
# concatenate jquery and codemirror into "libraries.js"
# it won't get minified as debug is true, but without that it would
'libraries.js':
- 'DL/js/jquery.js'
- 'DL/codemirror/codemirror.js'
sass:
# compile all css, scss and sass files which don't start with _ from the "download_root"
# into the "css" directory, here that will just be build_bootstrap.scss which will
# build the whole of bootstrap.
# debug: true means you'll get map files and a copy of sass files so maps work properly.
'css': 'DL/'Then download and build you static files with just:
.. code::
grablib
Library Usage
-------------You can also call grablib from python:
.. code:: python
from grablib import Grab
grab = Grab('path/to/definitions.json|yml')
grab.download()
grab.build().. |Build Status| image:: https://github.com/samuelcolvin/grablib/workflows/CI/badge.svg
:target: https://github.com/samuelcolvin/grablib/actions?query=workflow%3ACI
.. |codecov.io| image:: http://codecov.io/github/samuelcolvin/grablib/coverage.svg?branch=master
:target: http://codecov.io/github/samuelcolvin/grablib?branch=master
.. |PyPI Status| image:: https://img.shields.io/pypi/v/grablib.svg?style=flat
:target: https://pypi.python.org/pypi/grablib
.. |license| image:: https://img.shields.io/pypi/l/grablib.svg
:target: https://github.com/samuelcolvin/grablib
.. _libsass: https://pypi.python.org/pypi/libsass/0.11.2
.. _jsmin: https://github.com/tikitu/jsmin
.. _examples: examples