Skip to content

Latest commit

 

History

History
71 lines (57 loc) · 1.88 KB

conventions.md

File metadata and controls

71 lines (57 loc) · 1.88 KB

Conventions

Coding conventions

  • encoding: utf-8
  • linux line breaking
  • indent: 4 spaces
  • comment language: English
  • shebang: #!/usr/bin/env python

Module imports

Avoid any import with * except for PyQt5:

from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

Group and order imports

Three groups for line imports are separated by an empty line:

  1. internal Python imports
  2. imports from PyTelTools
  3. relative imports (within a PyTelTools module)

Imports are sorted by alphabetic order.

Example:

import sys
from time import time

from pyteltools.conf import settings
from pyteltools.slf import Serafin

from .Node import Box, Link, Port
from .util import logger

Common abbreviations

Some common import renamings:

import numpy as np
import pyteltools.slf.misc as operations

Naming conventions

  • variables, functions, methods: lowercase_with_underscores
  • class: CapWords

Common custom methods for PyQt5

  • _initWidgets(): fix element sizes, tooltips, ...
  • _setLayout(): add widgets, items and finally calls setLayouts()
  • _bindEvents(): bind events with methods

Logging

Use with following logging levels (with corresponding numeric value) :

  • CRITICAL (40)
  • WARNING (30)
  • INFO (20)
  • DEBUG (10)

CLI exiting code

  • 0 = successful termination
  • 1 = different kind of errors/inconsistencies: in input/output, error during computation, ...
  • 2 = error or inconsistencies with command-line arguments
  • 3 = file error (parser, writer)

Code documentation

Developer documentation is generated with doyxgen and provided on https://cnr-engineering.github.io/PyTelTools.

Doxygen will extract preformatted comments following some conventions.