Difference between revisions of "Cogniteam/CodeConvention"
| Line 113: | Line 113: | ||
== C++ class template == | == C++ class template == | ||
| + | |||
| + | === Header file === | ||
<syntaxhighlight lang="C++"> | <syntaxhighlight lang="C++"> | ||
| Line 360: | Line 362: | ||
// new line | // new line | ||
// new line | // new line | ||
| − | } /* namespace | + | } /* namespace project_name */ |
| − | } /* namespace | + | } /* namespace cogniteam */ |
| − | |||
// new line | // new line | ||
// new line | // new line | ||
#endif /* PATH_TO_FILE_AND_FILE_NAME_ */ | #endif /* PATH_TO_FILE_AND_FILE_NAME_ */ | ||
| + | // new line | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | === Source file === | ||
| + | |||
| + | <syntaxhighlight lang="C++"> | ||
| + | /* | ||
| + | * CogniteamClass.cpp | ||
| + | * | ||
| + | * Created on: Jan 1, 2031 | ||
| + | * Author: John Doe <johndoe@cogniteam.com> | ||
| + | * | ||
| + | * | ||
| + | * Cogniteam LTD CONFIDENTIAL | ||
| + | * | ||
| + | * Unpublished Copyright (c) 2010-2020 Cogniteam, All Rights Reserved. | ||
| + | * | ||
| + | * NOTICE: All information contained herein is, and remains the property | ||
| + | * of Cogniteam. The intellectual and technical concepts contained | ||
| + | * herein are proprietary to Cogniteam and may be covered by Israeli and | ||
| + | * Foreign Patents, patents in process, and are protected by trade secret | ||
| + | * or copyright law. Dissemination of this information or reproduction of | ||
| + | * this material is strictly forbidden unless prior written permission is | ||
| + | * obtained from Cogniteam. Access to the source code contained herein | ||
| + | * is hereby forbidden to anyone except current Cogniteam employees, | ||
| + | * managers or contractors who have executed Confidentiality and | ||
| + | * Non-disclosure agreements explicitly covering such access | ||
| + | * | ||
| + | * The copyright notice above does not evidence any actual or intended | ||
| + | * publication or disclosure of this source code, which includes | ||
| + | * information that is confidential and/or proprietary, and is a trade | ||
| + | * secret, of Cogniteam. ANY REPRODUCTION, MODIFICATION, DISTRIBUTION, | ||
| + | * PUBLIC PERFORMANCE, OR PUBLIC DISPLAY OF OR THROUGH USE OF THIS | ||
| + | * SOURCE CODE WITHOUT THE EXPRESS WRITTEN CONSENT OF Cogniteam IS | ||
| + | * STRICTLY PROHIBITED, AND IN VIOLATION OF APPLICABLE LAWS AND INTERNATIONAL | ||
| + | * TREATIES. THE RECEIPT OR POSSESSION OF THIS SOURCE CODE AND/OR RELATED | ||
| + | * INFORMATION DOES NOT CONVEY OR IMPLY ANY RIGHTS TO REPRODUCE, DISCLOSE | ||
| + | * OR DISTRIBUTE ITS CONTENTS, OR TO MANUFACTURE, USE, OR SELL ANYTHING | ||
| + | * THAT IT MAY DESCRIBE, IN WHOLE OR IN PART | ||
| + | * | ||
| + | */ | ||
| + | // Maximum 80 characters per line // new line | ||
| + | // new line | ||
| + | #include <cogniteam/CogniteamClass.h> | ||
| + | // new line | ||
| + | // new line | ||
| + | // | ||
| + | // Always wrap your code with a namespace | ||
| + | // | ||
| + | namespace cogniteam { | ||
| + | namespace project_name { | ||
| + | // new line | ||
| + | // new line | ||
| + | /** | ||
| + | * Construct a new Cogniteam Class object, more deatils about implementation | ||
| + | * can be added here | ||
| + | */ | ||
| + | CogniteamClass::CogniteamClass() | ||
| + | : varToInit_(1), | ||
| + | varToinit2_(2.0) { | ||
| + | // | ||
| + | // Other initialization... | ||
| + | // | ||
| + | } | ||
| + | |||
| + | /** | ||
| + | * Construct a new Cogniteam Class object | ||
| + | * @param obj1 | ||
| + | */ | ||
| + | CogniteamClass::CogniteamClass(const SomeClass& obj1) { | ||
| + | |||
| + | } | ||
| + | |||
| + | /** | ||
| + | * Copy constructor | ||
| + | * @note Don't forget to implement copy constructor & copy assignment operator | ||
| + | * if you have pointers in your class | ||
| + | * @param obj1 | ||
| + | */ | ||
| + | CogniteamClass::CogniteamClass(const CogniteamClass& obj1) { | ||
| + | |||
| + | } | ||
| + | |||
| + | /** | ||
| + | * Destroys the Cogniteam Class object | ||
| + | * @note Always declare virtual desctrutor in your classes | ||
| + | */ | ||
| + | CogniteamClass::~CogniteamClass() { | ||
| + | |||
| + | } | ||
| + | |||
| + | /** | ||
| + | * Describe the implementation | ||
| + | * @param param1 First parameter | ||
| + | * @param param2 Second parameter | ||
| + | * @param param3 Another parameter | ||
| + | * @return true If success | ||
| + | * @return false If failure | ||
| + | */ | ||
| + | bool CogniteamClass::runAlgorithm(double param1, double param2, double param3) { | ||
| + | |||
| + | } | ||
| + | |||
| + | /** | ||
| + | * Describe the implementation | ||
| + | * @param param1 First param for calculationg | ||
| + | * @return double Calculation result | ||
| + | */ | ||
| + | double CogniteamClass::calculateNumber(double param1) const { | ||
| + | |||
| + | } | ||
| + | // new line | ||
| + | // new line | ||
| + | } /* namespace project_name */ | ||
| + | } /* namespace cogniteam */ | ||
// new line | // new line | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Revision as of 14:34, 30 December 2019
Contents
Coding style and naming convention
Conventions names examples
| Upper Camel Case | Lower Camel Case | Upper Snake Case | Lower Snake Case |
|---|---|---|---|
| UpperCamelCase | lowerCamelCase | UPPER_SNAKE_CASE | lower_snake_case |
C++ naming conventions
| Component | Convention | Example |
|---|---|---|
| Variables | Lower camel case | <syntaxhighlight lang="C++">
int state_; MessageType messageType; uint32_t countOfSomething; ros::NodeHandle rosNodeHandle; </syntaxhighlight> |
| Methods | Lower camel case | <syntaxhighlight lang="C++">
void calculate(); int getCount(); int processIncomingMessages(); </syntaxhighlight> |
| Member variables | Add '_' suffix to name, cannot be public | <syntaxhighlight lang="C++">
int memberVariable_; std::string name_; ros::ServiceClient rosServiceClient_; </syntaxhighlight> |
| Class names | Upper camel case | <syntaxhighlight lang="C++">
class Vector3; class AgentController; class MapAligner; </syntaxhighlight> |
| Abstract classes | Upper camel case Prefix 'I' for interfaces - pure abstract classes without any implementations Suffix 'Base' for abstract base classes with some implementations |
<syntaxhighlight lang="C++">
class ITextParser; // Pure abstract class - defines only interfaces without any implementations class IMapFilter; class TaskBase; // Abstract class with some implementations common to all tasks class MappingBase; </syntaxhighlight> |
| Namespaces | Lower camel case | <syntaxhighlight lang="C++">
namespace cognitao_utils { } namespace cogniteam { namespace tools { } /* namespace tools */ } /* namespace cogniteam */ </syntaxhighlight> |
| Enums | Upper camel case Prefer enum class over regular enums |
<syntaxhighlight lang="C++">
enum class MessageTypes { Single = 1, MultiPacket = 2, }; enum class Colors { Red = 0x00, Green = 0x01, Blue = 0x02 }; </syntaxhighlight> |
Files and folders
| Component | Convention | Example |
|---|---|---|
| Class files Header and source file |
Upper camel case | MyClass.h MyClass.cpp AgentRosController.hpp |
| Main File containint main() method, usually ROS node |
Lower snake case | cognitao_runner.cpp my_app.cpp agent_controller_node.cpp |
| Folders | Lower snake case | cognitao_ros include/agent_controller src/map_filters |
DON'T USE MACROS & DEFINES except for header guards
General OOP principles
- Object-oriented programming OOP
- SOLID principles SOLID
- Software design pattern Desigh Patterns
Read more
C++ class template
Header file
<syntaxhighlight lang="C++"> /*
* CogniteamClass.h
*
* Created on: Jan 1, 2031
* Author: John Doe <johndoe@cogniteam.com>
*
*
* Cogniteam LTD CONFIDENTIAL
*
* Unpublished Copyright (c) 2010-2020 Cogniteam, All Rights Reserved.
*
* NOTICE: All information contained herein is, and remains the property
* of Cogniteam. The intellectual and technical concepts contained
* herein are proprietary to Cogniteam and may be covered by Israeli and
* Foreign Patents, patents in process, and are protected by trade secret
* or copyright law. Dissemination of this information or reproduction of
* this material is strictly forbidden unless prior written permission is
* obtained from Cogniteam. Access to the source code contained herein
* is hereby forbidden to anyone except current Cogniteam employees,
* managers or contractors who have executed Confidentiality and
* Non-disclosure agreements explicitly covering such access
*
* The copyright notice above does not evidence any actual or intended
* publication or disclosure of this source code, which includes
* information that is confidential and/or proprietary, and is a trade
* secret, of Cogniteam. ANY REPRODUCTION, MODIFICATION, DISTRIBUTION,
* PUBLIC PERFORMANCE, OR PUBLIC DISPLAY OF OR THROUGH USE OF THIS
* SOURCE CODE WITHOUT THE EXPRESS WRITTEN CONSENT OF Cogniteam IS
* STRICTLY PROHIBITED, AND IN VIOLATION OF APPLICABLE LAWS AND INTERNATIONAL
* TREATIES. THE RECEIPT OR POSSESSION OF THIS SOURCE CODE AND/OR RELATED
* INFORMATION DOES NOT CONVEY OR IMPLY ANY RIGHTS TO REPRODUCE, DISCLOSE
* OR DISTRIBUTE ITS CONTENTS, OR TO MANUFACTURE, USE, OR SELL ANYTHING
* THAT IT MAY DESCRIBE, IN WHOLE OR IN PART
*
*/
// Maximum 80 characters per line // new line
// new line
// // Always use header guards for header files //
- ifndef PATH_TO_FILE_AND_FILE_NAME_
- define PATH_TO_FILE_AND_FILE_NAME_
// new line
// new line
// // Group includes of the same library and separate it using a new line // Order your include files from low level to higher. // 1. libstd C headers: <printf.h>, <file.h>, <math.h> // 2. libstd C++ headers: <fstream>, <thread>, <mutex>, <cmath> // 4. Other 3rd party includes: <boost/mutex.hpp>, <Qt/QtCore>, <ros/ros.h>, // <pcl/pcl.h> // 4. Local includes: <cogniteam/project_name3/SomeClass.h> //
- include <printf.h>
// new line
- include <iostream>
- include <fstream>
- include <mutex>
// new line
- include <boost/bind.hpp>
- include <boost/thread.hpp>
- include <boost/thread/mutex.hpp>
- include <boost/asio.hpp>
- include <boost/asio/serial_port.hpp>
- include <boost/system/error_code.hpp>
// new line
- include <ros/ros.h>
- include <std_msgs/String.h>
- include <ackermann_msgs/AckermannDriveStamped.h>
// new line
- include <cogniteam/AwesomeClass.h>
- include <cogniteam/project_name3/JustSomeClass.h>
// new line
// new line
// // Always wrap your code with a namespace // namespace cogniteam { namespace project_name {
// new line
// new line
// Include other namespaces using namespace std; using namespace cogniteam::project_name2;
// new line
// new line
/**
* Custom color for... */
enum class CogniColor {
Red = 1, Blue = 2, Green
};
// new line
// new line
/**
* High level description of class purposes * @note Comment using Doxygen's 'Javadoc style' format * @url http://www.doxygen.nl/manual/docblocks.html */
class CogniteamClass : public CogniteamBaseClass {
// Use separate public block for constructors and descructor
public:
/**
* Construct a new Cogniteam Class object
*/
CogniteamClass();
/**
* Construct a new Cogniteam Class object
* @param obj1
*/
CogniteamClass(const SomeClass& obj1);
/**
* Copy constructor
* @note Don't forget to implement copy constructor & copy assignment operator
* if you have pointers in your class
* @param obj1
*/
CogniteamClass(const CogniteamClass& obj1);
/**
* Destroys the Cogniteam Class object
* @note Always declare virtual desctrutor in your classes
*/
virtual ~CogniteamClass();
public:
/**
* Public type alias for convenient
*/
using Ptr = shared_ptr<CogniteamClass>;
using ConstPtr = shared_ptr<CogniteamClass const>;
public:
// // Public member methods // NO PUBLIC VARIABLE ALLOWED - USE GETTERS AND SETTERS // // Getter & Setter example for member variable object_: //
/**
* Set the Var object
* @note inline setters & getters
* @note Use const methods for getters
* @note Setters and getters must be as short as possible, ideally,
* one copy assignment and one return:
* @param var
* @return int
*/
inline void setObject(Object& object) {
object_ = object;
}
/**
* Gets the Object object
* @return Object
*/
inline Object getObject() const {
return object_;
}
/**
* Use prefix T for template parameters (MessageT, ServiceT, PacketT...)
* @tparam ObjectT
* @param object
*/
template <typename ObjectT>
void templateMethod(const ObjectT& object) {
// ...
}
protected:
// // Protected member methods //
/**
* Protected method, visible by this and derived classes
* @return int
*/
int protectedMethod();
protected:
// // Protected member variables //
/**
* Protected member variable, visible by this and derived classes
*/
int protectedMemberVariable_ = 0;
private:
// // Private member methods //
/**
* Runs my algorithm
* @param param1 First parameter
* @param param2 Second parameter
* @param param3 Another parameter
* @return true If success
* @return false If failure
*/
bool runAlgorithm(double param1, double param2, double param3);
/**
* Calculates a number such that...
* @param param1 First param for calculationg
* @return double Calculation result
*/
double calculateNumber(double param1) const;
private:
// // Private member methods //
/**
* Const member example, upper case with underscore, place const's first
*/
const string CONST_MEMBER_STRING = "monitor_red";
/**
* Private variable, visible by this class only
*/
Object object_;
};
// new line
// new line
} /* namespace project_name */ } /* namespace cogniteam */
// new line
// new line
- endif /* PATH_TO_FILE_AND_FILE_NAME_ */
// new line
</syntaxhighlight>
Source file
<syntaxhighlight lang="C++"> /*
* CogniteamClass.cpp
*
* Created on: Jan 1, 2031
* Author: John Doe <johndoe@cogniteam.com>
*
*
* Cogniteam LTD CONFIDENTIAL
*
* Unpublished Copyright (c) 2010-2020 Cogniteam, All Rights Reserved.
*
* NOTICE: All information contained herein is, and remains the property
* of Cogniteam. The intellectual and technical concepts contained
* herein are proprietary to Cogniteam and may be covered by Israeli and
* Foreign Patents, patents in process, and are protected by trade secret
* or copyright law. Dissemination of this information or reproduction of
* this material is strictly forbidden unless prior written permission is
* obtained from Cogniteam. Access to the source code contained herein
* is hereby forbidden to anyone except current Cogniteam employees,
* managers or contractors who have executed Confidentiality and
* Non-disclosure agreements explicitly covering such access
*
* The copyright notice above does not evidence any actual or intended
* publication or disclosure of this source code, which includes
* information that is confidential and/or proprietary, and is a trade
* secret, of Cogniteam. ANY REPRODUCTION, MODIFICATION, DISTRIBUTION,
* PUBLIC PERFORMANCE, OR PUBLIC DISPLAY OF OR THROUGH USE OF THIS
* SOURCE CODE WITHOUT THE EXPRESS WRITTEN CONSENT OF Cogniteam IS
* STRICTLY PROHIBITED, AND IN VIOLATION OF APPLICABLE LAWS AND INTERNATIONAL
* TREATIES. THE RECEIPT OR POSSESSION OF THIS SOURCE CODE AND/OR RELATED
* INFORMATION DOES NOT CONVEY OR IMPLY ANY RIGHTS TO REPRODUCE, DISCLOSE
* OR DISTRIBUTE ITS CONTENTS, OR TO MANUFACTURE, USE, OR SELL ANYTHING
* THAT IT MAY DESCRIBE, IN WHOLE OR IN PART
*
*/
// Maximum 80 characters per line // new line
// new line
- include <cogniteam/CogniteamClass.h>
// new line
// new line
// // Always wrap your code with a namespace // namespace cogniteam { namespace project_name {
// new line
// new line
/**
* Construct a new Cogniteam Class object, more deatils about implementation * can be added here */
CogniteamClass::CogniteamClass()
: varToInit_(1),
varToinit2_(2.0) {
//
// Other initialization...
//
}
/**
* Construct a new Cogniteam Class object * @param obj1 */
CogniteamClass::CogniteamClass(const SomeClass& obj1) {
}
/**
* Copy constructor * @note Don't forget to implement copy constructor & copy assignment operator * if you have pointers in your class * @param obj1 */
CogniteamClass::CogniteamClass(const CogniteamClass& obj1) {
}
/**
* Destroys the Cogniteam Class object * @note Always declare virtual desctrutor in your classes */
CogniteamClass::~CogniteamClass() {
}
/**
* Describe the implementation * @param param1 First parameter * @param param2 Second parameter * @param param3 Another parameter * @return true If success * @return false If failure */
bool CogniteamClass::runAlgorithm(double param1, double param2, double param3) {
}
/**
* Describe the implementation * @param param1 First param for calculationg * @return double Calculation result */
double CogniteamClass::calculateNumber(double param1) const {
}
// new line
// new line
} /* namespace project_name */ } /* namespace cogniteam */
// new line
</syntaxhighlight>