Home Applications cos-guidelines

cos-guidelines

by 
This application is not supported by InterSystems Corporation. Please be notified that you use it at your own risk.
4
1 reviews
0
Awards
135
Views
0
IPM installs
0
0
Details
Releases
Reviews  (1)
Issues
Articles  (1)
COS contibutors guidelines

What's new in this version

Initial Release

Caché ObjectScript Code Guidelines

This is the first approximation of Caché ObjectScript guidelines we use for github.com/intersystems-ru projects. There are mandatory and recommended parts.

We do not plan to be very restrictive, but want be rather flexible enough and allow any reasonable style.
Here is the general advice: use common sense and try to be consistent wherever you write code.
If there is some style already established in the class or utility being modified then we recommend
to continue use that same style, than introducing yet another one, which may be more recommended
but which will be introducing some unnecessary inconsistency.

Quick Reference Guide

For Caché ObjectScript quick reference guide see here.

Mandatory Part

  • Only “modern” syntax permitted, dotted syntax is not generally allowed (with few exceptions);
  • No short name for statements keywords or built-in functions allowed - use fully expanded names;
  • Comment your code appropriately, use English in comments to make your code easy to understand by your international colleagues. Same English-based rule applies to global, local, and type names.

Recommended Part

  • We recommend to use fully expanded keyword or function name in lower case or capitalized. Whatever you’ll select should be consistent across class or utility, i.e.
If (expression) {
  Do ##class(Sample).%New(initexpresion)
  For i=1:1:10 {
    Write something, $ZVersion, !
  }
}

or

 if (expression) {
   do ##class(Sample).%New(initexpresion)
   for i=1:1:10 {
     write something, $zversion, !
   }
 }
  • We recommend to use fully qualified package name of a class (except %Library package)
Set obj = ##class(Sample.Person).%New(initexpresion)

instead of

Set obj = ##class(Person).%New(initexpresion)
  • In general, use the reasonable name convention consistently across whole hierarchy. We recommend to use CamelCase for classes, methods and properties (e.g. Sample.Person, OpenFile, LastIndex, etc.), but smallCamelCase for local variables (e.g. startDate, endDate), but please be consistent and use local schema if it’s different than current recommendation.
  • We recommend to use #dim statement for declaration of local variables types, e.g.
  #dim array as %ArrayOfDataTypes = ##class(%ArrayOfDataTypes).%New()
  do array.SetAt(id, "id")
  #dim status As %Status = $$$OK

This will help editor to provide better auto-complete, and eventually will be used by static checker for type information extraction.

  • Please indent blocks reasonably. We recommend to use 8, 4 or 2 spaces indentations. Pick your level, and apply consistently.
    if (expression) {
        do ..Method(args...)
        set i = j + 1
    } else {
        while (condition) {
            write arg1, arg2, !
        }
    }
  • For better readability please insert spaces after comma in functions/methods argument list, i.e.
  Write 1, 2, 3
  Do ..Method(arg1, arg2, argN)

For obvious reasons this recommendation not applies to arguments in $$$macro-call, where such extra spaces will break final result.

  • For better readability please insert spaces around assignment. You may align several neighbour assignments according to your tastes, i.e.
  #dim index As %Integer = 0
  #dim countOfItems As %Integer = ..Count()
  set j  = k + 1
  set iN = jN \ l

Related discussion

Standards document for Objectscript developers

Version
1.21.301 Jun, 2018
Category
Developer Environment
Works with
CachéEnsemble
First published
01 Jun, 2018
Last checked by moderator
27 Jun, 2023Works