/* Copyright (c) 2017, 2024, Oracle and/or its affiliates. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License, version 2.0, as published by the Free Software Foundation. This program is designed to work with certain software (including but not limited to OpenSSL) that is licensed under separate terms, as designated in a particular file or component or in included license documentation. The authors of MySQL hereby grant you an additional permission to link the program and your derivative works with the separately licensed software that they have either included with the program or referenced in the documentation. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License, version 2.0, for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ /** @page GENERAL_DEVELOPMENT_GUIDELINES General Development Guidelines We use Git for source management. You should use the TRUNK source tree (currently called "mysql-trunk") for all new development. To download and set up the public development branch, use these commands: ~~~~~~~~~~~~~~~~ shell> git clone https://github.com/mysql/mysql-server.git mysql-trunk shell> cd mysql-trunk shell> git branch mysql-trunk ~~~~~~~~~~~~~~~~ Before making big design decisions, please begin by posting a summary of what you want to do, why you want to do it, and how you plan to do it. This way we can easily provide you with feedback and also discuss it thoroughly. Perhaps another developer can assist you. - @subpage CODING_GUIDELINES_OF_SERVER - @subpage NAMING_CONVENTION - @subpage COMMENTING_CODE - @subpage HEADER_FILE - @subpage EXAMPLE_SETUP_FOR_CTAGS */ /** @page CODING_GUIDELINES_OF_SERVER Legacy C++ Coding Guidelines of MySQL Server This section covers guidelines for C++ code for the MySQL server, old code only. (New code should follow Google C++ coding style.) The guidelines do not necessarily apply for other projects such as MySQL Connector/J or Connector/ODBC. */ /** @page NAMING_CONVENTION Legacy Naming Conventions - For identifiers formed from multiple words, separate each component with underscore rather than capitalization. Thus, use my_var instead of myVar or MyVar. - Avoid capitalization except for class names; class names should begin with a capital letter. This exception from Google coding guidelines exists because the server has a history of using My_class. It will be confusing to mix the two (from a code-review perspective). ~~~~~~~~~~~~~~~~ class Item; class Query_arena; class Log_event; ~~~~~~~~~~~~~~~~ - Avoid function names, structure elements, or variables that begin or end with '_'. - Use long function and variable names in English. This makes your code easier to read for all developers. - We used to have the rule: "Structure types are typedef'ed to an all-upper-case identifier." That rule has been deprecated for C++ code. Do not add typedefs for structs/classes in C++. - All \#define declarations should be in upper case. ~~~~~~~~~~~~~~~~ #define MY_CONSTANT 15 ~~~~~~~~~~~~~~~~ - Enumeration names should begin with enum_. - Function declarations (forward declarations) have parameter names in addition to parameter types. */ /** @page COMMENTING_CODE Legacy Commenting Style - Comment your code when you do something that someone else may think is not trivial. - Comments for pure virtual functions, documentation for API usage should precede (member, or non-member) function declarations. Descriptions of implementation details, algorithms, anything that does not impact usage, should precede the implementation. Please try to not duplicate information. Make a reference to the declaration from the implementation if necessary. If the implementation and usage are too interleaved, put a reference from the interface to the implementation, and keep the entire comment in a single place. - Class comments should precede the class declaration. - When writing multi-line comments please put the '*' and '*/' on their own lines, put the '*/' below the '/*', put a line break and a two-space indent after the '/*', do not use additional asterisks on the left of the comment.
  /*
    This is how a multi-line comment in the middle of code
    should look.  Note it is not Doxygen-style if it is not at the
    beginning of a code enclosure (function or class).
  */

  /* *********This comment is bad. It's indented incorrectly, it has
  *            additional asterisks. Don't write this way.
  *  **********/
- When writing single-line comments, the '/*' and '*/' are on the same line. For example:
/* We must check if stack_size = Solaris 2.9 can return 0 here. */
- Single-line comments like this are okay in C++.
// We must check if stack_size = Solaris 2.9 can return 0 here.
- For a short comment at the end of a line, you may use either /* ... */ or a // double slash. In C files or in header files used by C files, avoid // comments. - Align short side // or /* ... */ comments by 48th column (start the comment in column 49).
{ qc*= 2; /* double the estimation */ }
- All comments should be in English. - Each standalone comment must start with a Capital letter. - There is a '.' at the end of each statement in a comment paragraph, including the last one.
  /*
    This is a standalone comment. The comment is aligned to fit 79
    characters per line. There is a period at the end of each sentence.
    Including the last one.
  */
- Every structure, class, method or function should have a description unless it is very short and its purpose is obvious. - Use the following example as a template for function or method comments. + Please refer to the Doxygen Manual (http://www.stack.nl/~dimitri/doxygen/manual.html) for additional information. + Note the IN and OUT parameters. IN is implicit, and can (but usually should not) be specified with the \@param[in] tag. For OUT and INOUT parameters you should use \@param[out] and \@param[in,out] tags, respectively. + Parameter specifications in \@param section start with lowercase and are not terminated with a full stop/period. + Section headers are aligned at two spaces. This must be a sentence with a full stop/period at the end. If the sentence must express a subject that contains a full stop such that Doxygen would be fooled into stopping early, then use \@brief and \@details to explicitly mark them. + Align \@retval specifications at four spaces if they follow a \@return description. Else, align at two spaces. + Separate sections with an empty line.
+ All function comments should be no longer than 79 characters per line. + Put two line breaks (one empty line) between a function comment and its description.
+ Doxygen comments: Use /** ... */ syntax and not /// + Doxygen command: Use '@' and not '\' for doxygen commands.
/**
    Initialize SHA1Context.

    Set initial values in preparation for computing a new SHA1 message digest.

    \@param[in,out]  context  the context to reset

    \@return Operation status
      \@retval SHA_SUCCESS      OK
      \@retval != SHA_SUCCESS   sha error Code
  */

  int sha1_reset(SHA1_CONTEXT *context)
  {
    ...
*/ /** @page HEADER_FILE Header Files - Use header guards. Put the header guard in the first line of the header, before the copyright. Use an all-uppercase name for the header guard. Derive the header guard name from the file base name, and append _INCLUDED to create a macro name. Example: sql_show.h -> SQL_SHOW_INCLUDED. - Include directives shall be first in the file. In a class implementation, include the header file containing the class declaration before all other header files, to ensure that the header is self-sufficient. - Every header file should be self-sufficient in the sense that for a header file my_header.h, the following should compile without errors: ~~~~~~~~~~~~~~~~ #include "my_header.h" ~~~~~~~~~~~~~~~~ An exception is made for generated files; for example, those generated by Yacc and Lex, because it is not possible to rewrite the generators to produce "correct" files. */ /** @page EXAMPLE_SETUP_FOR_CTAGS Example Setup for ctags Put this configuration into your ~/.ctags file: @verbatim --c++-kinds=+p --fields=+iaS --extra=+q --langdef=errmsg --regex-errmsg=/^(ER_[A-Z0-9_]+)/\1/ --langmap=errmsg:(errmsg*.txt),c:+.ic,yacc:+.yy @endverbatim */ /** @page DBUG_TAGS DBUG Tags

The full documentation of the DBUG library is in files dbug/user.* in the MySQL source tree. Here are some of the DBUG tags we now use:

- enter Arguments to the function. - exit Results from the function. - info Something that may be interesting. - warning When something does not go the usual route or may be wrong. - error When something went wrong. - loop Write in a loop, that is probably only useful when debugging the loop. These should normally be deleted when you are satisfied with the code and it has been in real use for a while.
Some tags specific to mysqld, because we want to watch these carefully: - trans Starting/stopping transactions. - quit info when mysqld is preparing to die. - query Print query. */