Skip to content

Latest commit

 

History

History
90 lines (61 loc) · 6.29 KB

code.md

File metadata and controls

90 lines (61 loc) · 6.29 KB

소스 코드 관리

브랜치 정책

PX4 프로젝트는 분기를 셋으로 나누는 git Branch를 만듭니다.

  • master는 기본 브랜치이며, 비교적 불안정하고 빠른 개발 속도를 보여줍니다.
  • beta는 철저하게 시험한 코드의 브랜치입니다. 비행체를 실험하시는 분들이 사용하도록 만들었습니다.
  • stable은 최신 릴리스를 가리킵니다.

리베이스를 통한 기록을 유지하며 Github 흐름을 배제합니다. 그러나, 전세계의 역동적인 개발팀과 수시로 병합 작업을 진행합니다.

새 기능을 추가하려면, Github에 가입하고, 저장소를 포킹한 후, 새 브랜치를 만들어, 코드를 바꾸어넣은 다음, 마지막으로 Pull 요청을 보냅니다. 지속적인 통합 작업 테스트를 통과하고 나면, 변경된 코드를 병합할 예정입니다.

모든 코드의 기여는 BSD 3-clause 라이선스 하에 진행하며, 모든 코드에 대해 더 이상의 사용시의 제약 사항을 강요해서는 안됩니다.

코드 형식 정리

PX4는 astyle 방식으로 코드 형식을 정리합니다. 유효 버전은 다음과 같습니다:

설치하고 나면 ./Tools/astyle/check_code_style_all.sh 명령으로 코드 형식을 점검할 수 있습니다. 정리한 master 브랜치에서의 출력은 Format checks passed로 나와야 합니다. 이 결과가 나왔다면, 나중에 모든 파일의 코드 형식을 검사할 때 make format 명령을 활용할 수 있습니다.

소스 코드 내부 문서 정리

PX4 개발자는 소스코드 내부 문서 정리를 권장합니다.

  • C++ source files should be named in CamelCase and match the class name. E.g. A C++ file containing a class named FooThing should be named FooThing.cpp.

  • C++ header files should be named the same as source files except have the suffix .hpp.

  • C++ header files that are required to be C compatible, should have the suffix .h.

  • Folder names are snake_case for the first level inside modules/drivers/systemcmds/etc. but should be named CamelCase when more deeply nested to match the source and header files.

  • Test files must have a Test suffix as shown: FooThingTest.cpp.

  • One exception to the rules above are the MAVLink streams in src/modules/mavlink/streams which are ALL_UPPERCASE.hpp matching the MAVLink message name.

코드 제출과 메시지

PX4 developers are encouraged to create appropriate in-source documentation.

:::note Source-code documentation standards are not enforced, and the code is currently inconsistently documented. We'd like to do better! :::

Currently we have two types of source-based documentation:

  • We encourage other in-source documentation where it adds value/is not redundant.

:::tip Developers should name C++ entities (classes, functions, variables etc.) such that their purpose can be inferred - reducing the need for explicit documentation. :::

  • Do not add documentation that can trivially be assumed from C++ entity names.
  • Commonly you may want to add information about corner cases and error handling.
  • Doxgyen tags should be used if documentation is needed: @class, @file, @param, @return, @brief, @var, @see, @note. A good example of usage is src/modules/events/send_event.h.

Commits and Commit Messages

Please use descriptive, multi-paragraph commit messages for all non-trivial changes. Structure them well so they make sense in the one-line summary but also provide full detail.

컴포넌트: 변경 사항을 한 문장으로 설명하십시오. Fixes #1234

Prepend the software component to the start of the summary
line, either by the module name or a description of it.
(e.g. "mc_att_ctrl" or "multicopter attitude controller").

If the issue number is appended as <Fixes #1234>, Github
will automatically close the issue when the commit is
merged to the master branch.

The body of the message can contain several paragraphs.
Describe in detail what you changed. Link issues and flight
logs either related to this fix or to the testing results
of this commit.

Describe the change and why you changed it, avoid to
paraphrase the code change (Good: "Adds an additional
safety check for vehicles with low quality GPS reception".
Bad: "Add gps_reception_check() function").

Reported-by: Name <[email protected]>

이 제출 안내서 내용은 리누스 토발즈가 관리하는 리눅스 커널과 기타 프로젝트에서 나온 우수 사례를 참고로 작성하였습니다.

This commit guide is based on best practices for the Linux Kernel and other projects maintained by Linus Torvalds.