Skip to content
Snippets Groups Projects
Select Git revision
  • 994fdbdf649accd18033f6669e0744fa2d8bca2b
  • master default
  • notifications_test_ndf
  • main_ud_local_ndf
  • crust-integration
  • new-client
  • internal_build
  • FE-1054_test_net_ndf
  • FE-1053_change_retry_behavior
  • app_modularization_refactor
  • FE_1020_remove_version_check
  • FE-992_android_migration
  • XX-4094_add_fact_panic
  • FE-990_retry_reset_request
  • development
  • 2.92
  • 2.9
  • 2.8
  • 2.7
  • 2.5
  • 2.3
  • 2.2
  • 2.1
  • 2.04
  • 2.03
  • 2.02
26 results

code-standards.md

Blame
  • Kamal Bramwell's avatar
    Kamal Bramwell authored
    8068d692
    History
    code-standards.md 22.92 KiB

    The Official XX Network Kotlin Style Guide (in progress)

    Goals

    Use of this style guide ensures:

    • Maintainability
    • Conciseness
    • Readability
    • Simplicity

    Inspiration

    Most of this guide statements are drawn or adapted from one of the following sources:

    Google Java Style Guide - Old school can still be contemporary

    Android Kotlin Style Guide - Official Android style guide

    Kotlin Coding Conventions - Official Kotlin guidelines for coding

    Android Contributors Style Guide - Contribution insights on open sourcing

    Google Swift Guide - General Formatting and Rules that can be applied to Kotlin, as they share many syntax similarities

    Table of Contents

    Click to expand

    Naming

    Kotlin is a JVM-compatible language like Java, and naming should follow Kotlin standards.

    Packages

    • Package names are all lower-case
    • Multiple words are discouraged
    • If multiple words are needed, they can be used concatenated together, without hyphens or underscores

    BAD :

    io.Elixxir.some_widget

    GOOD :

    io.elixxir.somewidget

    Classes, Objects & Interfaces

    • Written in UpperCamelCase

    BAD :

    open class myExampleClass { /*...*/ }
    object emptyObject : myExampleClass() { /*...*/ }
    interface myInterface { /*...*/}

    GOOD :

    open class MyExampleClass { /*...*/ }
    object EmptyExampleClass : MyExampleClass() { /*...*/ }
    interface MyInterface { /*...*/}

    Methods

    • Written in lowerCamelCase, without hyphens or underscores

    BAD :