# Electron에 기여하기

:+1::tada: 먼저, 이 프로젝트에 기여해주셔서 감사합니다! :tada::+1:

이 프로젝트는 기여자 규약 [행동강령](CODE_OF_CONDUCT.md)을 준수합니다. 따라서 이
프로젝트의 개발에 참여하려면 이 규약을 지켜야 합니다. 받아들일 수 없는 행위를 발견했을
경우 atom@github.com로 보고 하십시오.

다음 항목들은 Electron에 기여하는 가이드라인을 제시합니다.
참고로 이 항목들은 그저 가이드라인에 불과하며 규칙이 아닙니다. 따라서 스스로의 적절한
판단에 따라 이 문서의 변경을 제안할 수 있으며 변경시 pull request를 넣으면 됩니다.

## 이슈 제출

* [여기](https://github.com/atom/electron/issues/new)에서 새로운 이슈를 만들 수
있습니다. 하지만 이슈를 작성하기 전에 아래의 항목들을 숙지하고 가능한한 이슈 보고에
대해 최대한 많은 정보와 자세한 설명을 포함해야 합니다. 가능하다면 다음 항목을 포함해야
합니다:
  * 사용하고 있는 Electron의 버전
  * 현재 사용중인 운영체제
  * 가능하다면 무엇을 하려고 했고, 어떤 결과를 예측했으며, 어떤 것이 예측된대로
  작동하지 않았는지에 대해 서술해야 합니다.
* 추가로 다음 사항을 준수하면 이슈를 해결하는데 큰 도움이 됩니다:
  * 스크린샷 또는 GIF 애니메이션 이미지들
  * 터미널에 출력된 에러의 내용 또는 개발자 도구, 알림창에 뜬 내용
  * [Cursory search](https://github.com/atom/electron/issues?utf8=✓&q=is%3Aissue+)를
  통해 이미 비슷한 내용의 이슈가 등록되어있는지 확인

## Pull Request 하기

* 가능한한 스크린샷과 GIF 애니메이션 이미지를 pull request에 추가
* CoffeeScript, JavaScript, C++과 Python등
[참조문서에 정의된 코딩스타일](/docs-translations/ko-KR/development/coding-style.md)을
준수
* [문서 스타일 가이드](/docs-translations/ko-KR/styleguide.md)에 따라 문서를
[Markdown](https://daringfireball.net/projects/markdown) 형식으로 작성.
* 짧은, 현재 시제 커밋 메시지 사용. [커밋 메시지 스타일 가이드](#Git-커밋-메시지)를
참고하세요

## 스타일 가이드

### 공통 코드

* 파일 마지막에 공백 라인(newline) 추가
* 다음 순서에 맞춰서 require 코드 작성:
  * Node 빌트인 모듈 (`path` 같은)
  * Electron 모듈 (`ipc`, `app` 같은)
  * 로컬 모듈 (상대 경로상에 있는)
* 다음 순서에 맞춰서 클래스 속성 지정:
  * 클래스 메서드와 속성 (메서드는 `@`로 시작)
  * 인스턴스 메서드와 속성
* 플랫폼 종속적인 코드 자제:
  * 파일 이름 결합시 `path.join()`을 사용.
  * 임시 디렉터리가 필요할 땐 `/tmp` 대신 `os.tmpdir()`을 통해 접근.
* 명시적인 함수 종료가 필요할 땐 `return` 만 사용.
  * `return null`, `return undefined`, `null`, 또는 `undefined` 사용 X

### Git 커밋 메시지

* 현재 시제 사용 ("Added feature" 대신 "Add feature" 사용)
* 필수적 분위기(imperative mood) 사용 ("Moves cursor to..." 대신 "Move cursor to..." 사용)
* 첫 줄은 72자에 맞추거나 그 보다 적게 제한
* 자유롭게 필요에 따라 이슈나 PR링크를 참조
* 단순한 문서 변경일 경우 `[ci skip]`을 커밋 메시지에 추가
* 커밋 메시지의 도입부에 의미있는 이모티콘 사용:
  * :art: `:art:` 코드의 포맷이나 구조를 개선(추가)했을 때
  * :racehorse: `:racehorse:` 성능을 개선했을 때
  * :non-potable_water: `:non-potable_water:` 메모리 누수를 연결했을 때
  * :memo: `:memo:` 문서를 작성했을 때
  * :penguin: `:penguin:` Linux에 대한 패치를 했을 때
  * :apple: `:apple:` Mac OS에 대한 패치를 했을 때
  * :checkered_flag: `:checkered_flag:` Windows에 대한 패치를 했을 때
  * :bug: `:bug:` 버그를 고쳤을 때
  * :fire: `:fire:` 코드 또는 파일을 삭제했을 때
  * :green_heart: `:green_heart:` CI 빌드를 고쳤을 때
  * :white_check_mark: `:white_check_mark:` 테스트를 추가했을 때
  * :lock: `:lock:` 보안 문제를 해결했을 때
  * :arrow_up: `:arrow_up:` 종속성 라이브러리를 업데이트 했을 때
  * :arrow_down: `:arrow_down:` 종속성 라이브러리를 다운그레이드 했을 때
  * :shirt: `:shirt:` linter(코드 검사기)의 경고를 제거했을 때