Skip to main content

Abstraction on top of baron, a FST for python to make writing refactoring code a realistic task

Project description

Introduction

Build Status Latest Version Supported Python versions Development Status Wheel Status Download format License

RedBaron is a python library and tool powerful enough to be used into IPython solely that intent to make the process of writing code that modify source code as easy and as simple as possible. That include writing custom refactoring, generic refactoring, tools, IDE or directly modifying you source code into IPython with an higher and more powerful abstraction than the advanced texts modification tools that you find in advanced text editors and IDE.

RedBaron guaranteed you that it will only modify your code where you ask him to. To achieve this, it is based on Baron a lossless AST for Python that guarantees the operation ast_to_code(code_to_ast(source_code)) == source_code. (Baron’s AST is called a FST, a Full Syntax Tree).

RedBaron API and feel is heavily inspired by BeautifulSoup. It tries to be simple and intuitive and that once you’ve get the basics principles, you are good without reading the doc for 80% of your operations.

For now, RedBaron can be considered in alpha, the core is quite stable but it is not battle tested yet and is still a bit rough. Feedback and contribution are very welcome.

The public documented API on the other side is guaranteed to be retro-compatible and won’t break until 2.0 (if breaking is needed at that point). There might be the only exception that if you directly call specific nodes constructors with FST that this API change, but this is not documented and simply horribly unpracticable, so I’m expecting no one to do that.

Disclamer: RedBaron (and baron) is working with python3 but it NOT fully parsing it yet.

Installation

pip install redbaron[pygments]

Or if you don’t want to have syntax highlight in your shell or don’t need it:

pip install redbaron

Running tests

pip install pytest
py.test tests

Changelog

0.6 (unreleased)

This release is guaranteed to have a retro-compatible public documented API from now on until maybe 2.0. There might be the only exception that if you directly call specific nodes constructors with FST that this API change, but this is not documented and simply horribly unpracticable, so I’m expecting no one to do that.

From now on the focus will be on moving to a stable 1.0 meaning: bugs fixes and API additions for missing needed features and no more big modifications, this will be for other releases, the workload is already big enough.

  • BIG improvement on the proxy list merging algorithm, it is not perfect yet (comments aren’t handled yet) but it’s really a big move forward

  • possible retrocompatibility breaking change: from now on the node.find(“name”) to node.name shortcut ONLY works with possible nodes identifiers. For example node.i_dont_exist_as_an_identifier will raise AttributeError

  • new helper method .to_python that wrap ast.literal_eval on compatibile nodes https://redbaron.readthedocs.org/en/latest/other.html#to-python

  • breaking: IntNode no longer return an int on .value but a .string instead, use .to_python to have an evaluated version

  • fix node.decrease_indentation (that was simply not working)

  • fix code_block_node.value was broken on node with no parent

  • add string representation for Path object

  • now redbaron Path() class can be compared directly to baron paths without using to_baron_path() helper.

  • fix by novocaine: ‘function’ was used as a function type detector instead of ‘def’

  • add getitem() method with same api on NodeList and ProxyList

  • fix: inconsistencies when inserting lines around code blocks

  • inserting a blank lines inserts effectively a n in a LineProxyList

  • new helper methods: .next_recursive and .previous_recursive https://redbaron.readthedocs.org/en/latest/other.html

  • fix: doc is tested in CI now, it shouldn’t break anymore

  • more rendering test for python3, it shouldn’t break anymore

  • pygments is now an optional dependancy, “pip install redbaron” won’t install it, “pip install redbaron[pygments”] will

  • new node.next_intuitive and node.previous_intuitive methods for situations where .next/previous doesn’t behave the way the user expect it http://redbaron.readthedocs.org/en/latest/other.html#next-intuitive-previous-intuitive

0.5.1 (2015-03-11)

  • fix whitespace duplication when using .insert()

  • DecoratorProxyList of the last method of a function wasn’t handling correctly the indentation of its last endl token

0.5 (2015-01-31)

0.4 (2014-12-11)

  • compatibility with baron upstream (removal of def_argument_node and uniformisation of def_arguments structure)

  • fix: long wasn’t supported in redbaron (due to a bug in baron)

0.3 (2014-11-12)

  • proxy lists, major improvement in the management of list of things

  • .append_value is no more since it is useless now due to proxy lists

  • .index has been renamed to .index_on_parent to be more coherent

0.2 (2014-09-23)

0.1 (2014-06-13)

  • First release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

redbaron-0.6.tar.gz (5.9 kB view hashes)

Uploaded Source

Built Distributions

redbaron-0.6-py2.py3-none-any.whl (9.3 kB view hashes)

Uploaded Python 2 Python 3

redbaron-0.6-py2.7.egg (4.9 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page