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.8.tar.gz (136.4 kB view details)

Uploaded Source

Built Distributions

polyglot_piranha-0.3.8-cp310-cp310-macosx_11_0_arm64.whl (2.5 MB view details)

Uploaded CPython 3.10 macOS 11.0+ ARM64

polyglot_piranha-0.3.8-cp39-cp39-manylinux_2_28_x86_64.whl (17.7 MB view details)

Uploaded CPython 3.9 manylinux: glibc 2.28+ x86-64

polyglot_piranha-0.3.8-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.8-cp38-cp38-macosx_10_16_x86_64.whl (2.5 MB view details)

Uploaded CPython 3.8 macOS 10.16+ x86-64

File details

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

File metadata

  • Download URL: polyglot_piranha-0.3.8.tar.gz
  • Upload date:
  • Size: 136.4 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.8.tar.gz
Algorithm Hash digest
SHA256 e2b45512f5e71cfbc5ce269d93e158f1223d396602d0a8e6e6770e0f5bd4b25f
MD5 38f1425c0a675ac5b8baaa366c222dae
BLAKE2b-256 20daf257797e7b4108d4239f402645943c4f168f88b46eeebaf31a08482e0a55

See more details on using hashes here.

File details

Details for the file polyglot_piranha-0.3.8-cp310-cp310-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for polyglot_piranha-0.3.8-cp310-cp310-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 97affe8a673bc23a410d93a8de383f4ecff9df1567d85744f8e94e37a857d3e6
MD5 ebdfd7a277b82dcd6a3fb764e0a287c5
BLAKE2b-256 827c5ab2db7af8cdc2a19b9ead2b05d00050fbbb7496abb8fe42e4b04f0dfcc0

See more details on using hashes here.

File details

Details for the file polyglot_piranha-0.3.8-cp39-cp39-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for polyglot_piranha-0.3.8-cp39-cp39-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 3d4a84f4ddc4b8355375180af865f665eea344f8066f91beb5c1db53bf1b2361
MD5 7d4f872992b353dfb73ad47a777fba42
BLAKE2b-256 495952090b12f09dca97808331d3d99ea823b70270b3866d44bb089b6fcebb84

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for polyglot_piranha-0.3.8-cp38-cp38-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 e48ee08f5118c98684aa64c0b48249f297ad9f2bceeaf440f353bf2f0cfdd17f
MD5 fa81f83cfe6f5770277a2fa2b359e462
BLAKE2b-256 c25cb24a0a831dd2f38fce176e13d3f8fba9ea7f4d6df7218852e566d2212df0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for polyglot_piranha-0.3.8-cp38-cp38-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 fa5100aaa00ec6cc56de525bd480445fa7c86e2dc9b31b38befc6a0df30224fb
MD5 be49dda00064b3dc519c07506b05826b
BLAKE2b-256 0ba5fb0cd9abb9eb382c04727b09464e348bd4d6256de91561aa577244fd7496

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