Skip to main content

Polyglot Piranha is a library for performing structural find and replace with deep cleanup.

Project description

Piranha

Join the chat at https://gitter.im/uber/piranha

Feature flags are commonly used to enable gradual rollout or experiment with new features. In a few cases, even after the purpose of the flag is accomplished, the code pertaining to the feature flag is not removed. We refer to such flags as stale flags. The presence of code pertaining to stale flags can have the following drawbacks:

  • Unnecessary code clutter increases the overall complexity w.r.t maintenance resulting in reduced developer productivity
  • The flags can interfere with other experimental flags (e.g., due to nesting under a flag that is always false)
  • Presence of unused code in the source as well as the binary
  • Stale flags can also cause bugs

Piranha is a tool to automatically refactor code related to stale flags. At a higher level, the input to the tool is the name of the flag and the expected behavior, after specifying a list of APIs related to flags in a properties file. Piranha will use these inputs to automatically refactor the code according to the expected behavior.

This repository contains four independent versions of Piranha, one for each of the four supported languages: Java, JavaScript, Objective-C and Swift. It also contains a redesigned variant of Piranha (as of May 2022) that is a common refactoring tool to support multiple languages and feature flag APIs. If interested in this polyglot variant, goto Polyglot Piranha.

To use/build each version, look under the corresponding [lang]/ directory and follow instructions in the corresponding [lang]/README.md file. Make sure to cd into that directory to build any related code following the instructions in the README.

A few additional links on Piranha:

  • A technical report detailing our experiences with using Piranha at Uber.
  • A blogpost presenting more information on Piranha.
  • 6 minute video overview of Piranha.

Support

If you have any questions on how to use Piranha, please feel free to reach out to us on the gitter channel. For bugs and enhancement requests, open a GitHub issue.

Contributors

We'd love for you to contribute to Piranha! Please note that once you create a pull request, you will be asked to sign our Uber Contributor License Agreement.

We are also looking for contributions to extend Piranha to other languages (C++, C#, Kotlin).

License

Piranha is licensed under the Apache 2.0 license. See the LICENSE file for more information.

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

polyglot_piranha-0.3.9.tar.gz (137.2 kB view details)

Uploaded Source

Built Distributions

polyglot_piranha-0.3.9-cp38-cp38-manylinux_2_34_x86_64.whl (17.6 MB view details)

Uploaded CPython 3.8 manylinux: glibc 2.34+ x86-64

polyglot_piranha-0.3.9-cp38-cp38-macosx_10_16_x86_64.whl (2.5 MB view details)

Uploaded CPython 3.8 macOS 10.16+ x86-64

polyglot_piranha-0.3.9-cp38-cp38-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl (5.0 MB view details)

Uploaded CPython 3.8 macOS 10.9+ universal2 (ARM64, x86-64) macOS 10.9+ x86-64 macOS 11.0+ ARM64

File details

Details for the file polyglot_piranha-0.3.9.tar.gz.

File metadata

  • Download URL: polyglot_piranha-0.3.9.tar.gz
  • Upload date:
  • Size: 137.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.16

File hashes

Hashes for polyglot_piranha-0.3.9.tar.gz
Algorithm Hash digest
SHA256 49a358711c71f89ea3e1435127aecc88d3393ee2a07b352eeb8a6673bb1b647d
MD5 7757f57380587c0e86be6a9edce27085
BLAKE2b-256 756e90ba6127f6c31ca2ef77a32e0c2df6b19327d446c8485d5c062a2e73284a

See more details on using hashes here.

File details

Details for the file polyglot_piranha-0.3.9-cp38-cp38-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for polyglot_piranha-0.3.9-cp38-cp38-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 950bd330ba08b62f3770a10aa861553000f66994ffa1a98b18ef416c56262e05
MD5 84f9d5ff85efce660c625a8ee80e0ad3
BLAKE2b-256 2a7d891621efc50cb6d87bc6d79ced9e4e98101cf2d23bd280f051580cfe0ec7

See more details on using hashes here.

File details

Details for the file polyglot_piranha-0.3.9-cp38-cp38-macosx_10_16_x86_64.whl.

File metadata

File hashes

Hashes for polyglot_piranha-0.3.9-cp38-cp38-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 72845996ce47e3766ae6ae8b448effed427fb8ca8958c9e338a54d72a9468218
MD5 c8efd04a0f665df2bf114f5baa50a4b9
BLAKE2b-256 9edda23ad08022eb302ac14b6367e418b10c862357e67dc81626b9a66896b68a

See more details on using hashes here.

File details

Details for the file polyglot_piranha-0.3.9-cp38-cp38-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for polyglot_piranha-0.3.9-cp38-cp38-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 453002147ca568cb57bd6e45fe3c0c9c46389fe7200346bbead0968fad73a5f2
MD5 bea973bdfa7f2a98d1198a1b4a12b7a0
BLAKE2b-256 8291a607abba4c45b323cf4547ed00293cbdf8c780ab907bd24c0b9a3a064a1f

See more details on using hashes here.

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