Coding Standards

From ParaQ Wiki
Jump to navigationJump to search

Style

All code will follow the VTK coding standards, with the following exceptions:

  • ParaQ classes (and thus, ParaQ files) will begin with "pq" instead of "vtk".
  • ParaQ classes that derive from Qt classes will follow the Qt style for member functions only: use camel-case with the first character lower-case. Examples: value(), mySignal(), myLittleSlot(). Rationale: mixing the Qt and VTK styles was judged ugly and confusing by developers.
  • All other style decisions (such as naming member variables) will follow VTK.

Source Documentation

  • Use Doxygen style tags to comment source code.
  • At a minimum, each class should have a description that includes its place within the overall design and its relationships (if any) with other classes.
  • At a minimum, all public members of a class should be documented with Doxygen "brief" descriptions.
  • Feel free to provide additional documentation beyond the minimums - there are many useful tags available, see the Doxygen Manual. A couple of favorites are "\todo" and "\deprecated", which can help considerably in eliminating orphaned code.

Sample Class

/// Widget that paints a property
class pqMyWidget : public QWidget
{
  Q_OBJECT
  Q_PROPERTY(QString property READ property WRITE setProperty)
  
public:
  pqMyWidget(QWidget* parent);
  ~pqMyWidget();

  /// overloaded paint event to paint property
  virtual bool paintEvent(QPaintEvent* e);

  /// get property
  QString property() const;
  /// set property
  void setProperty(QString s);

protected:
  QString Property;
};

Testing

  • Qt Widgets should have a name assigned whenever possible. Although names are no longer strictly required for the test framework to function, assigning explicit names will improve the longetivity of a recorded test. This is because the algorithm that assigns unique names is more likely to be affected by code changes than an explicit name.

Qt Designer

When creating forms using Qt Designer, ensure that you set the following fields for all (applicable) widgets:

  • objectName - Setting a logical, descriptive name here will ensure that recorded regression tests continue to play-back correctly as new widgets are added to the form.
  • toolTip - Set a short (a few words) human-readable description of what the widget does. Since widgets are usually labelled, make sure you aren't just repeating the label - provide additional information and tell what the widget does, not what it is.
  • statusTip - Describe what the widget does in more detail, using one-or-two sentences with correct punctuation.

Other Useful Tidbits

  • Avoid multiple inheritance of Qt & VTK classes. Style in such classes would be mixed. Besides, object management is not compatible (VTK's A::New, a->Delete vs. Qt's new A(), nothing).
  • Turn on CMake option VTK_DEBUG_LEAKS.
  • Whenever a Qt class has a member variable that is a VTK object, the member must be a smart pointer. eg:
 class pqMyQtClass : public QObject
   {
   ....
   vtkSmartPointer<vtkSMProxy> Member;   // correct.
   vtkSMProxy* WrongMember;            // Incorrect, unless exra care is taken to update the reference count.
   };
  • The one who creates, is the one who destroys: That the same class that call a vtkClassName::New() should be the one to call vtkClassName::Delete() unless it clearly states so, eg vtkSMProxyManager::NewProxy.