IvorySQL Community Contribution Guide

1. Summary

1.1. Illustration

IvorySQL is maintained by a core development team, which has commit access to the main repository of IvorySQL on GitHub.Meanwhile,we are eager to get contributions from members of the wider IvorySQL community. If you want to see your changes to code or documents added to IvorySQL and appear in future versions, you need to know the content of this section.

​IvorySQL community welcomes and appreciates all types of contributions, looking forward to your participation!

1.2. Principles of Conduct

For each member, contributor and leader, everyone should read our principles of conduct . We promise that everyone can participate in community and pay equal attention to everyone, no matter who.

We are committed to acting and interacting in a way that contributes to the establishment of an open, enthusiastic, diverse, inclusive and healthy community.

1.3. Description of Community Governance

Our team is a continuously open team, focusing on a part of the IvorySQL.In our team, there are reviewers, submitters and maintainers, and we have one or more repositories. The decision of the team is made by the maintainer. The typical promotion path for IvorySQL developers is from user to reviewer, then submitter and maintainer. But getting more roles doesn’t mean you have any privileges to other community members. Everyone in the IvorySQL community is equal and has the responsibility to cooperate constructively with other contributors to build a friendly community. These roles are natural rewards for your significant contributions to the development of IvorySQL, and provide you with more rights in the development workflow to improve your efficiency. At the same time,this requires you to undertake some additional duty:

​Team honor: now you are already one of the team reviewers/submitters/maintainers, it means that you represent the project and your team members. So, please be Mr.Nice Guy to defend the reputation of the team.

​Responsibility: submitters/maintainers have the right to merge pull requests, therefore, they take additional responsibility to deal with the consequences of accepting changes to the code base or documents. When a bug occurs, they should fix it. If they can not solve it, they should roll back the project. Also, they need to help the release manager solve any problems found in the test cycle.

2. Contributor’s Guide

Before contributing, we need to know the current version of IvorySQL and the version of the document.At present, we maintain versions after version 1.3. Our version follows the updata pace of PG. Please update to the latest version before contributing. After that, we need to read the format requirements carefully and be familiar with code format, code comment format, issue format, pull PR title format, document contribution format, and article contribution format. These can help you become a contributor of IvorySQL as soon as possible.

2.1. Preparation before Contribution

2.1.1. Getting started

IvorySQL is developed on GtiHub. Anyone who wishes to contribute to it must have a Github account and be familiar with Git tools and workflow. It is also recommended that you follow the developer’s mailing list since some of the contributions may generate more detailed discussions there.

Once you have your GitHub account, fork this repository so that you can have your private copy to start hacking on and to use as a source of pull requests.

2.1.2. Licensing of IvorySQL contributions

If the contribution you’re submitting is original work, you can assume that IvorySQL will release it as part of an overall IvorySQL release available to the downstream consumers under the Apache License, Version 2.0.

If the contribution you’re submitting is NOT original work you have to indicate the name of the license and also make sure that it is similar in terms to the Apache License 2.0. Apache Software Foundation maintains a list of these licenses under Category A. In addition to that, you may be required to make proper attributions.

Finally, keep in mind that it is NEVER a good idea to remove licensing headers from the work that is not your original one. Even if you are using parts of the file that originally had a licensing header at the top you should err on the side of preserving it. As always, if you are not quite sure about the licensing implications of your contributions, feel free to reach out to us on the developer mailing list.

2.2. What Contribution can You Make

2.2.1. Code Contribution

You can upload your modified bugs, new functions and other codes to your personal warehouse, and finally submit PR requests to merge them on the official website: https://github.com/IvorySQL/IvorySQL.

2.2.2. Document Contribution(https://www.ivorysql.org/zh-CN/docs/intro)

The IvorySQL community provides Chinese and English documents. English documents are saved in …​ document repository, Chinese documents are saved in i18n document repository. You can contribute to one of them or both.

2.2.3. Test IvorySQL and Report Bugs

Gitee:https://gitee.com/IvorySQL/

2.2.4. Participate in the Construction of IvorySQL Website

IvorySQL official website:https://github.com/IvorySQL/Ivory-www

2.2.5. Answer Questions on the Mailing List

Mailing List website:https://lists.ivorysql.org/

2.2.6. Contribute Article

You can submit your article to the blog in the IvorySQL-WWW code warehouse, or send it to the mailbox renjiao@highgo.com.

2.3. How to Contribute

2.3.1. Coding Guidelines

Your chances of getting feedback and seeing your code merged into the project greatly depend on how granular your changes are. If you happen to have a bigger change in mind, we highly recommend engaging on the developer’s mailing list first and sharing your proposal with us before you spend a lot of time writing code. Even when your proposal gets validated by the community, we still recommend doing the actual work as a series of small, self-contained commits. This makes the reviewer’s job much easier and increases the timeliness of feedback.

When it comes to C and C++ parts of IvorySQL, we try to follow PostgreSQL Coding Conventions. In addition to that:

For C and Perl code, please run pgindent if necessary. We recommend using git diff --color when reviewing your changes so that you don’t have any spurious whitespace issues in the code that you submit.

All new functionality that is contributed to IvorySQL should be covered by regression tests that are contributed alongside it. If you are uncertain about how to test or document your work, please raise the question on the ivorysql-hackers mailing list and the developer community will do its best to help you.

At the very minimum, you should always be running make installcheck-world to make sure that you’re not breaking anything.

2.3.2. Changes applicable to upstream PostgreSQL

If the change you’re working on touches functionality that is common between PostgreSQL and IvorySQL, you may be asked to forward-port it to PostgreSQL. This is not only so that we keep reducing the delta between the two projects, but also so that any change that is relevant to PostgreSQL can benefit from a much broader review of the upstream PostgreSQL community. In general, it is a good idea to keep both codebases handy so you can be sure whether your changes may need to be forward-ported.

2.3.3. Patch submission

Once you are ready to share your work with the IvorySQL core team and the rest of the IvorySQL community, you should push all the commits to a branch in your own repository forked from the official IvorySQL and send us a pull request.

2.3.4. Patch review

A submitted pull request with passing validation checks is assumed to be available for peer review. Peer review is the process that ensures that contributions to IvorySQL are of high quality and align well with the road map and community expectations. Every member of the IvorySQL community is encouraged to review pull requests and provide feedback. Since you don’t have to be a core team member to be able to do that, we recommend following a stream of pull reviews to anybody who’s interested in becoming a long-term contributor to IvorySQL.

One outcome of the peer review could be a consensus that you need to modify your pull request in certain ways. GitHub allows you to push additional commits into a branch from which a pull request was sent. Those additional commits will be then visible to all of the reviewers.

A peer review converges when it receives at least one +1 and no -1s votes from the participants. At that point, you should expect one of the core team members to pull your changes into the project.

At any time during the patch review, you may experience delays based on the availability of reviewers and core team members. Please be patient. That being said, don’t get discouraged either. If you’re not getting expected feedback for a few days add a comment asking for updates on the pull request itself or send an email to the mailing list.

2.3.5. Direct commits to the repository

On occasion, you will see core team members committing directly to the repository without going through the pull request workflow. This is reserved for small changes only and the rule of thumb we use is this: if the change touches any functionality that may result in a test failure, then it has to go through a pull request workflow. If, on the other hand, the change is in the non-functional part of the codebase (such as fixing a typo inside of a comment block) core team members can decide to just commit to the repository directly.

3. Submit Issue

3.1. First: Get into New issue page:

1 Enter IvorySQL official website:https://github.com/IvorySQL/IvorySQL

2 Click New issue

p3

3.1.1. Second:Select the issue type

1 bug report

Title:
asciidoc
## Bug Report
Describe the bug


\### IvorySQL Version
The version of IvorySQL you are using

\### OS Version (uname -a)
Operating system version(uname -a)

\### Configuration options  ( config.status --config )


\### Current Behavior


\### Expected behavior/code


\### Step to reproduce


\### Additional context that can be helpful for identifying the problem
asciidoc

2 Enhancement

Title:
asciidoc
## Enhancement
Describe the functions that you expect to be strengthened
asciidoc

3 Feature Request

Title:
asciidoc
## Feature Request
Describe the feature that you expect to be real
asciidoc

3.1.2. Third: Submit

Click submit new issue button. WELL DONE!

4. Contribute Code

4.1. First: Fork ivorysql.org warehouse

1 Open the ivorysql warehouse: https://github.com/IvorySQL/IvorySQL

2 Click the fork button in the upper right corner, Wait for the fork to finish

4.2. Second: Clone the warehouse to local

cd $working_dir #  $working_dir can be replaced by the directory where you want to place repo. For example, `cd ~/Documents/GitHub`

git clone git@github.com:$user/IvorySQL.git # `$user` can be replaced by your GitHub ID.
asciidoc

4.3. Third: Create a new Branch

cd $working_dir/IvorySQL

git checkout -b new-branch-name
asciidoc

4.4. Fourth: Edit Document or Modify Code

You can modify the code in new-branch-name.

4.5. Fifth: Generate commit

Git add <file>

Git commit -m “commit-message”
asciidoc

4.6. Sixth: Push the modification to the remote end

Git push -u origin new-branch-name
asciidoc

4.7. Seventh: Create a Pull Request

1 Open your warehouse: https://github.com/$user/IvorySQL ($user is your GitHub ID) .

2 Click Compare & pull request button and create a PR.

5. Submit PR

A PR submission should contain only one function or one bug. Prohibit submitting multiple functions at one time.

5.1. First:Create a Pull Request

1 Open your warehouse: https://github.com/$user/IvorySQL ($user is your GitHub ID) 。

2 Click Compare & pull request button.

5.2. Second:Fill in PR information

Fix test
Describe the function
asciidoc
leave a comment
Give a detailed description of the submission function
asciidoc

5.3. Third:Submit PR

Click Create pull request button. WELL DONE!

6. Edit Documents

6.1. Preparation

(1) Download Markdown or Typora document editor.

(2) Check whether the source warehouse has updates. If there are updates, please update and synchronize to your own warehouse first. Refer to the following steps to update to the latest version:

git remote

git fetch upstream

git merge upstream/main

git push
asciidoc

(3) Familiar with format [_pecification].

6.2. Where to Contribute

The IvorySQL community provides Chinese and English documents. English documents are saved in IvorySQL document repository, Chinese documents are saved in i18n document repository. You can contribute to one of them or both.

You can start from any of following to help improve the IvorySQL documents on the IvorySQL website:

​ (1) Prepare complete documents.

​ (2) Fix incorrect spelling and formatting (Punctuation, space, indentation, code block, etc) .

​ (3) Improper or outdated instructions corrected or updated.

​ (4) Add missing content (sentences, paragraphs, or new documents) .

​ (5) Translate document from English to Chinese, or from Chinese to English.

​ (6) Submit, reply and resolve document issues or document-i18n issues.

​ (7) (Advanced) View pull requests created by others.

6.3. Specification

The IvorySQL document is written in 'markdown'. To ensure the quality and consistency of the format, certain Markdown rules should be followed when modifying and updating the document.

Markdown Specification

​ 1 Titles are used incrementally from the first level, and skipping is prohibited. For example: The third level title cannot be used directly under the first level title; The fourth level title cannot be used directly under the second level title.

​ 2 The title must use the ATX style uniformly. Indicate the title level by adding # before the title.

​ 3 The leading symbol # of the title must be followed by a blank space.

​ 4 The leading symbol "#" of the title can only be followed by one blank space and then the title content. There can be no more than one space.

​ 5 The title must appear at the beginning of a line, there must be no space before the # sign of the title.

​ 6 Only Chinese and English question marks, back quotes, Chinese and English single and double quotes and other symbols can appear at the end of the title. Other symbols such as colon, comma, period and exclamation point cannot be used at the end of the title.

​ 7 One line must be empty above the title.

​ 8 The same title cannot appear continuously in the document. If the first level title is # TiDB architecture, the next level title cannot be # # TiDB architecture. If it is not a continuous title, the title content can be repeated.

​ 9 Only one first level title in document.

​ 10 In general, except for TOC.md files, which can be indented by two spaces, other .md files must be indented by four spaces by default foe each level of indentation.

​ 11 Tab is not allowed in documents(including code blocks) . If indentation is required, spaces must be uniformly used instead.

​ 12 Continuous blank lines are prohibited.

​ 13 Multiple spaces are not allowed after the block reference symbol > . Only one space can be used, followed by the reference content.

​ 14 When using a ordered list, it must start from 1 and increase in order.

​ 15 When using a list, the identifier (+, -, * or number) of each list item can only be left blank, followed by the list content.

​ 16 The list (includeing ordered and unordered lists) must be empty before and after each line.

​ 17 There must be one blank line before and after the code block.

​ 18 Exposed URLs are prohibited in documents. If you want users to click and open the URL directly, wrap the URL with a pair of angle brackets (<URL>) . If the exposed URL must be used due to special circumstances, and the user does not need to open it by clicking, a pair of back quatation marks (URL) will be used to wrap the URL.

​ 19 When using bold, italic and other emphasis effects, redundant spaces are prohibited in the emphasis identifier, such as text .

​ 20 No extra space is allowed in the code block wrapped by a single backquote, such as ` text `.

​ 21 No extra spaces are allowed on both sides of the link text, such as [ Link ](https://www.example.com/)

​ 22 The link must have a link path. [Empty link]() and [empty link](#) are not allowed.

6.4. Example

1 Titles are used incrementally from the first level, and skipping is prohibited.

# Heading 1
### Heading 3

We skipped out a 2nd level heading in this document
asciidoc

2 The title must use the ATX style uniformly. Indicate the title level by adding # before the title.

# Heading 1
## Heading 2
### Heading 3
#### Heading 4
## Another Heading 2
### Another Heading 3
asciidoc

3 The leading symbol # of the title must be followed by a blank space. Multiple spaces after # are prohibited, and spaces before # are prohibited.

Incorrect Example:

# Heading 1
## Heading 2
asciidoc

Correct Example:

# Heading 1
## Heading 2
asciidoc

4 Only Chinese and English question marks, back quotes, Chinese and English single and double quotes and other symbols can appear at the end of the title.

Incorrect Example:

# This is a heading.
asciidoc

Correct Example:

# This is a heading
asciidoc

5 One line must be empty above the title.

Incorrect Example:

# Heading 1
Some text
Some more text## Heading 2
asciidoc

Correct Example:

# Heading 1
Some text
Some more text

## Heading 2
asciidoc

6 he same title cannot appear continuously in the document. If the first level title is # TiDB architecture, the next level title cannot be ## TiDB architecture. If it is not a continuous title, the title content can be repeated.

Incorrect Example:

# Some text

## Some text
asciidoc

Correct Example:

# Some text

## Some more text
asciidoc

7 Only one first level title in document.

Incorrect Example:

# Top level heading

# Another top-level heading
asciidoc

Correct Example:

# Title

## Heading

## Another heading
asciidoc

8 In general, except for TOC.md files, which can be indented by two spaces, other .md files must be indented by four spaces by default foe each level of indentation.

Incorrect Example:

* List item
  * Nested list item indented by 3 spaces
asciidoc

Correct Example:

* List item
    * Nested list item indented by 4 spaces
asciidoc

9 Tab is not allowed in documents(including code blocks) . If indentation is required, spaces must be uniformly used instead.

Incorrect Example:

Some text
	* hard tab character used to indent the list item
asciidoc

Correct Example:

Some text
  * Spaces used to indent the list item instead
asciidoc

10 Continuous blank lines are prohibited.

Incorrect Example:

Some text here


Some more text here
asciidoc

Correct Example:

Some text here

Some more text here
asciidoc

11 Multiple spaces are not allowed after the block reference symbol > . Only one space can be used, followed by the reference content.

Incorrect Example:

>  This is a blockquote with bad indentation>  there should only be one.
asciidoc

Correct Example:

> This is a blockquote with correct> indentation.
asciidoc

12 When using a ordered list, it must start from 1 and increase in order.

Incorrect Example:

1. Do this.
1. Do that.
1. Done.
asciidoc
0. Do this.
1. Do that.
2. Done.
asciidoc
Correct Example:
1. Do this.
2. Do that.
3. Done.
asciidoc

13 When using a list, the identifier (+, -, * or number) of each list item can only be left blank, followed by the list content.

Correct Example:

* Foo
* Bar
* Baz

1. Foo
  * Bar
1. Baz
asciidoc

14 The list (includeing ordered and unordered lists) must be empty before and after each line.

Incorrect Example:

Some text* Some* List

1. Some2. List

Some text
asciidoc

Correct Example:

Some text

* Some
* List

1. Some
2. List

Some text
asciidoc

15 There must be one blank line before and after the code block.

Incorrect Example:

Some text
​```
Code block
​``````
Another code block
​```
Some more text
asciidoc

Correct Example:

Some text

​```
Code block
​``````
Another code block
​```

Some more text
asciidoc

16 Exposed URLs are prohibited in documents. If you want users to click and open the URL directly, wrap the URL with a pair of angle brackets (<URL>) . If the exposed URL must be used due to special circumstances, and the user does not need to open it by clicking, a pair of back quatation marks (URL) will be used to wrap the URL.

Incorrect Example:

For more information, see https://www.example.com/.
asciidoc

Correct Example:

For more information, see <https://www.example.com/>.
asciidoc

17 When using bold, italic and other emphasis effects, redundant spaces are prohibited in the emphasis identifier, such as text .

Incorrect Example:

Here is some ** bold ** text.

Here is some * italic * text.

Here is some more __ bold __ text.

Here is some more _ italic _ text.
asciidoc

Correct Example:

Here is some **bold** text.

Here is some *italic* text.

Here is some more __bold__ text.

Here is some more _italic_ text.
asciidoc

18 No extra space is allowed in the code block wrapped by a single backquote, such as ` text `.

Incorrect Example:

some text
 some text
asciidoc

Correct Example:

some text
asciidoc

19 No extra spaces are allowed on both sides of the link text, such as [ Link ](https://www.example.com/) . Incorrect Example:

[ a link ](https://www.example.com/)
asciidoc

Correct Example:

[a link](https://www.example.com/)
asciidoc

20 The link must have a link path. [Empty link]() and [empty link](#) are not allowed.

Incorrect Example:

[an empty link]()

[an empty fragment](#)
asciidoc

Correct Example:

[a valid link](https://example.com/)

[a valid fragment](#fragment)
asciidoc

21 Code blocks in the document are wrapped with three backquote, and the use of indented four-space code blocks is prohibited.

Incorrect Example:

Some text.

  # Indented code

More text.
asciidoc

Correct Example:

```ruby
# Fenced code
​```

More text.
asciidoc

7. Submit Blog

7.1. Preparation

1 Download Markdown or Typora .

2 Check whether the source warehouse (https://github.com/IvorySQL/Ivory-www) has updates. If there are updates, please update and synchronize to your own warehouse first. Refer to the following steps to update to the latest version:

# Download source code
git clone https://github.com/IvorySQL/Ivory-www.git
# Synchronize updates warehouse
git pull
bash

3 Familiar with format ([_specification_2])

7.2. Where to Congtribute

The IvorySQL community provides Chinese and English documents. English documents are saved in IvorySQL document repository, Chinese documents are saved in i18n document repository. You can contribute to one of them or both.

7.3. How to Contribute

Let’s take a quick look at the information about the maintenance of the IvorySQL blog before contributing. It is helpful for you to submit blog and to be a contributor.

(1) Clone code to local warehouse

git clone https://github.com/IvorySQL/Ivory-www.git
bash

(2) Create a branch

git checkout -b <branch-name>
bash

(3) Create a directory of your own articles in the blog directory, and please name your own directory according to the ([Specification](#7.4 Specification) ) .

# Make English blog directory and files
cd Ivory-www/blog
mkdir <YEAR-MONTH-DAY-title>
cd <YEAR-MONTH-DAY-title>
touch index.md
# Make Chinese blog directory and files
cd Ivory-www/i18n/zh-CN/docusaurus-plugin-content-blog
mkdir <YEAR-MONTH-DAY-title>
cd <YEAR-MONTH-DAY-title>
touch index.md
bash

(4) Write the blog to publish in index.md, put the required pictures in the blog in the same directory as index.md.

(5) Submit Blog

git add <file-path>
git commit -m "<message>"
git push origin <branch-name>:<branch-name>
bash

7.4. Specification

7.4.1. Submit specifications

(1) Format of folder naming: year-month-day-foldername

Example: 2022-1-28-ivorysql-arrived

(2) File property is index.md

(3) Picture property is .png, and put the pictures to be uploaded into the folder to be submitted in advance.

Notice:The name of every picture is unique and cannot be repeated.

Example: po-one.png

7.4.2. Write blog

Blogs are written in markdown or Typora, you can understand the design of blog by reading Blog | Docusaurus.

(1) The header of blog includes the following information:

---
slug: IvorySQL
title: Welcome to IvorySQL community
authors: [official]
authorTwitter: IvorySql
tags: [IvorySQL, Welcome, Database, Join Us]
---
vim

Prompt:You can copy the above template to your file and edit it.

Notice:1) Add one space after slug, title, authors, tags.

2) The name of every slug is unique, the Chinese and English versions of the same blog can be the same.

(2) Text format

The text paragraph title is h2/"Second level title";

The body uses the default font size.

(3) Naming format of inserted pictures

[Hello](Hello-banner.png)

(4) Naming format of inserted hyperlink

[name](link)

Github page Download source code and published packages.