Skip to content

Latest commit

 

History

History
55 lines (44 loc) · 4.24 KB

CONTRIBUTING.md

File metadata and controls

55 lines (44 loc) · 4.24 KB

Tempy | Contibution program and guidelines

Guidelines

Any contribution is welcome. The TODO list below is a general plan of what I (we!) intend to do next. You can find the actual planned activities looking in the Issues of this repo.

If you want to propose (or ask for) a new feature, if you want to propose a refactoring of some part of the code, or if you find a bug, please open a new issue with your idea.

Every contribution should have its tests and will have to pass already written tests. Tests are important, and no merge will be made without some test coverage. If you don't know how to write/run tests just AMA on our Slack channel. Tempy tests are written with Unittest, every PR you make will be analysed by Travis CI.

Contact me if you want to help maintaining this project or if you are willing to suggest ideas. We have a Slack for TemPy dev discussions (ask for an invitation to federicocerchiari @ gmail . com).

Code Style

This project does not have a coding style guideline (except PEP8 and PEP20 of course) , just code as you like to code!

Workflow

Every development is tracked using Issues. If you want to work on a specific issue, ask for assignement. And if you don't find an issue for what you want to work on, open a new issue with your proposed development.

Small (2/3 commits, 1 contributor) contributions should follow this simple workflow:

  • Ask to be assigned to the issue
  • Fork this repo: GitHub guide on forking
  • Do the coding on the forked repo in the master branch
  • Make a Pull Request: GitHub guide on making a PR Some CI and code quality services will be triggered and 5/10 mins after your PR you'll see in the PR page if your contribution is breaking some tests, if it contain some code that can be made better and if it have a good test coverage. I'll check the PR and merge, or review your code if I have suggestions on something you wrote.

Bigger developments (i.e: a new widget, a new complex feature, a deep refactor, more than one person working on the feature) etc..) will follow a different workflow:

  • Discuss the development strategy on the Issue
  • Discuss particular problems in the Slack channel
  • I'll make a new branch dedicated to this feature with no CI
  • When the feature is ready I'll perform the merge into the master branch

TODO plan:

Planned evolution of this project:

  • stable concept refactor... there should be a better way!
  • New class: CssManager (or something like that) that extracts common style properties from a formed DOM, creates the Css instance and adds it in the <head>. Extra feature: dumps the css to a versioned file in the static folder and adds a link to this file in the page.
  • Better exception handling.
  • Manage Tempy object subclassing to use a custom object as a renderable for business logic item (i.e: SQLAlchemy's declarative with a Tempy template in it that can be rendered at ease)
  • TemPy widgets, see the widget branch.
  • Better pretty formatting.
  • Writing more tests.

See open issues for a complete list of contribution opportunities.

Ideas I'm thinking about:

  • Html to TemPy command line converter tool, accepts plain html and makes a .py tempy module.
  • Python 2 compatibility (maybe?).
  • Performance: always needed, maybe a _partial_render method that traverses the html tree in a depth-first reverse order and "stabilizes" all the leafs? Is this useful?
  • Adding .find method to the T object use with css-like selectors (i.e: Html().find('#myid'))?
  • Adding a jQuery-ish god object T to use as a find method inside a DOMElement sublass (i.e: T('#myid').some_tempy_method())?
  • Cache for css builder module in a separate script (i.e: shell >>> tempy -build_css my_template.py outputs a css in the static folder and the CssManager search for that version in the statics before doing any work)?
  • Any suggestions?