{ "info": { "author": "Peter Salnikov", "author_email": "opensource@exrny.com", "bugtrack_url": null, "classifiers": [ "Development Status :: 4 - Beta", "Environment :: Console", "Intended Audience :: Developers", "Intended Audience :: System Administrators", "License :: OSI Approved :: MIT License", "Programming Language :: Python :: 2", "Programming Language :: Python :: 3", "Topic :: Software Development :: Build Tools" ], "description": "|Build Status|\n\nVulcan Builder\n==============\n\nThis project is a fork of Pynt by `Raghunandan\nRao `__. We will contribute changes to the\noriginal rags/pynt repo.\n\nVulcan Builder supports EXR\u2019s applications via a lightweight, concise\nPython DevOps tool. We will develop our own improvements on the initial\nrags/pynt repo here and publish improvements to the original repo.\n\nThis is an EXR Open Source project.\n\nA pynt of Python build.\n=======================\n\nFeatures\n--------\n\n- Easy to learn.\n- Build tasks are just python funtions.\n- Manages dependencies between tasks.\n- Automatically generates a command line interface.\n- Rake style param passing to tasks\n- Supports python 2.7 and python 3.x\n- Async tasks\n\nTodo Features\n-------------\n\n- Additional tasks timing reporting\n- Debug mode\n\nInstallation\n------------\n\nYou can install vulcan-builder from the Python Package Index (PyPI) or\nfrom source.\n\nUsing pip\n\n.. code:: bash\n\n $ pip install vulcan-builder\n\nUsing easy_install\n\n.. code:: bash\n\n $ easy_install vulcan-builder\n\nExample\n-------\n\nThe build script is written in pure Python and vulcan-builder takes care\nof managing any dependencies between tasks and generating a command line\ninterface.\n\nWriting build tasks is really simple, all you need to know is the @task\ndecorator. Tasks are just regular Python functions marked with the\n``@task()`` decorator. Dependencies are specified with ``@task()`` too.\nTasks can be ignored with the ``@task(ignore=True)``. Disabling a task\nis an useful feature to have in situations where you have one task that\na lot of other tasks depend on and you want to quickly remove it from\nthe dependency chains of all the dependent tasks.\n\n**build.py**\n------------\n\n.. code:: python\n\n\n #!/usr/bin/python\n\n import sys\n from vulcan.builder import task\n\n @task()\n def clean():\n '''Clean build directory.'''\n print 'Cleaning build directory...'\n\n @task(clean)\n def html(target='.'):\n '''Generate HTML.'''\n print 'Generating HTML in directory \"%s\"' % target\n\n @task(clean, ignore=True)\n def images():\n '''Prepare images.'''\n print 'Preparing images...'\n\n @task(html,images)\n def start_server(server='localhost', port = '80'):\n '''Start the server'''\n print 'Starting server at %s:%s' % (server, port)\n\n @task(start_server) #Depends on task with all optional params\n def stop_server():\n print 'Stopping server....'\n\n @task()\n def copy_file(src, dest):\n print 'Copying from %s to %s' % (src, dest)\n\n @task()\n def echo(*args,**kwargs):\n print args\n print kwargs\n \n # Default task (if specified) is run when no task is specified in the command line\n # make sure you define the variable __DEFAULT__ after the task is defined\n # A good convention is to define it at the end of the module\n # __DEFAULT__ is an optional member\n\n __DEFAULT__=start_server\n\n**Running vulcan-builder tasks**\n--------------------------------\n\nThe command line interface and help is automatically generated. Task\ndescriptions are extracted from function docstrings.\n\n.. code:: bash\n\n $ vb -h\n usage: vb [-h] [-l] [-v] [-f file] [task [task ...]]\n\n positional arguments:\n task perform specified task and all its dependencies\n\n optional arguments:\n -h, --help show this help message and exit\n -l, --list-tasks List the tasks\n -v, --version Display the version information\n -f file, --file file Build file to read the tasks from. Default is\n 'build.py'\n\n.. code:: bash\n\n $ vb -l\n Tasks in build file ./build.py:\n clean Clean build directory.\n copy_file \n echo \n html Generate HTML.\n images [Ignored] Prepare images.\n start_server [Default] Start the server\n stop_server \n\n Powered by vulcan-builder - A Lightweight Python Build Tool.\n\nvulcan-builder takes care of dependencies between tasks. In the\nfollowing case start_server depends on clean, html and image generation\n(image task is ignored).\n\n.. code:: bash\n\n $ vb #Runs the default task start_server. It does exactly what \"vb start_server\" would do.\n [ example.py - Starting task \"clean\" ]\n Cleaning build directory...\n [ example.py - Completed task \"clean\" ]\n [ example.py - Starting task \"html\" ]\n Generating HTML in directory \".\"\n [ example.py - Completed task \"html\" ]\n [ example.py - Ignoring task \"images\" ]\n [ example.py - Starting task \"start_server\" ]\n Starting server at localhost:80\n [ example.py - Completed task \"start_server\" ]\n\nThe first few characters of the task name is enough to execute the task,\nas long as the partial name is unambigious. You can specify multiple\ntasks to run in the commandline. Again the dependencies are taken taken\ncare of.\n\n.. code:: bash\n\n $ vb cle ht cl\n [ example.py - Starting task \"clean\" ]\n Cleaning build directory...\n [ example.py - Completed task \"clean\" ]\n [ example.py - Starting task \"html\" ]\n Generating HTML in directory \".\"\n [ example.py - Completed task \"html\" ]\n [ example.py - Starting task \"clean\" ]\n Cleaning build directory...\n [ example.py - Completed task \"clean\" ]\n\nThe \u2018html\u2019 task dependency \u2018clean\u2019 is run only once. But clean can be\nexplicitly run again later.\n\nvb tasks can accept parameters from commandline.\n\n.. code:: bash\n\n $ vb \"copy_file[/path/to/foo, path_to_bar]\"\n [ example.py - Starting task \"clean\" ]\n Cleaning build directory...\n [ example.py - Completed task \"clean\" ]\n [ example.py - Starting task \"copy_file\" ]\n Copying from /path/to/foo to path_to_bar\n [ example.py - Completed task \"copy_file\" ]\n\nvb can also accept keyword arguments.\n\n.. code:: bash\n\n $ vb start[port=8888]\n [ example.py - Starting task \"clean\" ]\n Cleaning build directory...\n [ example.py - Completed task \"clean\" ]\n [ example.py - Starting task \"html\" ]\n Generating HTML in directory \".\"\n [ example.py - Completed task \"html\" ]\n [ example.py - Ignoring task \"images\" ]\n [ example.py - Starting task \"start_server\" ]\n Starting server at localhost:8888\n [ example.py - Completed task \"start_server\" ]\n \n $ vb echo[hello,world,foo=bar,blah=123]\n [ example.py - Starting task \"echo\" ]\n ('hello', 'world')\n {'blah': '123', 'foo': 'bar'}\n [ example.py - Completed task \"echo\" ]\n\n**Organizing build scripts**\n----------------------------\n\nYou can break up your build files into modules and simple import them\ninto your main build file.\n\n.. code:: python\n\n from deploy_tasks import *\n from test_tasks import functional_tests, report_coverage\n\nContributors/Contributing\n-------------------------\n\n- Raghunandan Rao - vulcan-builder is preceded by and forked from\n `pynt `__, which was created by\n `Raghunandan Rao `__.\n- Calum J. Eadie - pynt is preceded by and forked from\n `microbuild `__, which was\n created by `Calum J. Eadie `__.\n\nIf you want to make changes the repo is at\nhttps://github.com/exrny/vulcan-builder. You will need\n`pytest `__ to run the tests\n\n.. code:: bash\n\n $ ./vb t\n\nIt will be great if you can raise a `pull\nrequest `__ once\nyou are done.\n\nIf you find any bugs or need new features please raise a ticket in the\n`issues section `__ of\nthe github repo.\n\nLicense\n-------\n\nvulcan-builder is licensed under a `MIT\nlicense `__\n\n.. |Build Status| image:: https://travis-ci.org/exrny/vulcan-builder.png?branch=master\n :target: https://travis-ci.org/exrny/vulcan-builder\n\nChanges\n=======\n\n0.1.0 - 04/02/2018\n------------------\n\n- Initial commit", "description_content_type": "", "docs_url": null, "download_url": "", "downloads": { "last_day": -1, "last_month": -1, "last_week": -1 }, "home_page": "https://code.exrny.com/opensource/vulcan-builder/", "keywords": "devops,build tool", "license": "MIT License", "maintainer": "", "maintainer_email": "", "name": "vulcan-builder", "package_url": "https://pypi.org/project/vulcan-builder/", "platform": "", "project_url": "https://pypi.org/project/vulcan-builder/", "project_urls": { "Homepage": "https://code.exrny.com/opensource/vulcan-builder/" }, "release_url": "https://pypi.org/project/vulcan-builder/0.2.2/", "requires_dist": null, "requires_python": "", "summary": "Lightweight Python Build Tool.", "version": "0.2.2" }, "last_serial": 4188026, "releases": { "0.2.1": [ { "comment_text": "", "digests": { "md5": "dbb6c047a422ddf364198f9f4bbe7128", "sha256": "eb12cbe8bd3f29e308d7a83023ceb1951710c0c90dee5a8ec7084a08eb5df1ca" }, "downloads": -1, "filename": "vulcan-builder-0.2.1.tar.gz", "has_sig": false, "md5_digest": "dbb6c047a422ddf364198f9f4bbe7128", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 9606, "upload_time": "2018-07-27T17:25:07", "url": "https://files.pythonhosted.org/packages/b6/fb/b2c27a08e95ebe55404c34692801b7ff8bfe6ff050211882ae2f1b57f8d0/vulcan-builder-0.2.1.tar.gz" } ], "0.2.2": [ { "comment_text": "", "digests": { "md5": "c6ffc0a048a76277972ae59fefddae1d", "sha256": "7060fb6162ef0ee631fd17b1c460ee26380ca0c8abc455b7dc36585917bf4d00" }, "downloads": -1, "filename": "vulcan-builder-0.2.2.tar.gz", "has_sig": false, "md5_digest": "c6ffc0a048a76277972ae59fefddae1d", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 9658, "upload_time": "2018-08-20T11:28:28", "url": "https://files.pythonhosted.org/packages/b5/72/fe4e06f3501c26215a9575c3a51a17c062f23b195ac3f9543306bcb2a8c5/vulcan-builder-0.2.2.tar.gz" } ] }, "urls": [ { "comment_text": "", "digests": { "md5": "c6ffc0a048a76277972ae59fefddae1d", "sha256": "7060fb6162ef0ee631fd17b1c460ee26380ca0c8abc455b7dc36585917bf4d00" }, "downloads": -1, "filename": "vulcan-builder-0.2.2.tar.gz", "has_sig": false, "md5_digest": "c6ffc0a048a76277972ae59fefddae1d", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 9658, "upload_time": "2018-08-20T11:28:28", "url": "https://files.pythonhosted.org/packages/b5/72/fe4e06f3501c26215a9575c3a51a17c062f23b195ac3f9543306bcb2a8c5/vulcan-builder-0.2.2.tar.gz" } ] }