Respectful code

Inclusivity is central to V8’s culture, and our values include treating each other with dignity. As such, it’s important that everyone can contribute without facing the harmful effects of bias and discrimination. However, terms in our codebase, UIs, and documentation can perpetuate that discrimination. This document sets forth guidance which aims to address disrespectful terminology in code and documentation.

Policy #

Terminology that is derogatory, hurtful, or perpetuates discrimination, either directly or indirectly, should be avoided.

What is in scope for this policy? #

Anything that a contributor would read while working on V8, including:

Principles #

How do I know if particular terminology is OK or not? #

Apply the principles above. If you have any questions, you can reach out to v8-dev@googlegroups.com.

What are examples of terminology to be avoided? #

This list is NOT meant to be comprehensive. It contains a few examples that people have run into frequently.

TermSuggested alternatives
masterprimary, controller, leader, host
slavereplica, subordinate, secondary, follower, device, peripheral
whitelistallowlist, exception list, inclusion list
blacklistdenylist, blocklist, exclusion list
insaneunexpected, catastrophic, incoherent
saneexpected, appropriate, sensible, valid
crazyunexpected, catastrophic, incoherent
redlinepriority line, limit, soft limit

What if I am interfacing with something that violates this policy? #

This circumstance has come up a few times, particularly for code implementing specifications. In these circumstances, differing from the language in the specification may interfere with the ability to understand the implementation. For these circumstances, we suggest one of the following, in order of decreasing preference:

  1. If using alternate terminology doesn’t interfere with understanding, use alternate terminology.
  2. Failing that, do not propagate the terminology beyond the layer of code that is performing the interfacing. Where necessary, use alternative terminology at the API boundaries.