PHP 코딩 가이드라인
{tip} 사내 혹은 그룹에서 개발할 때 지켜야 하는 가이드라인을 설명합니다.
일반적인 PHP 룰
PHP의 코딩에 있어서 PSR-1, PSR-2, PSR-12는 반드시 지켜져야 합니다.
{tip} 사내 혹은 그룹의 공식 사용 버전은 PHP 7.3.x 이며, DB 서버를 제외하고 상시 버전업 됩니다.
컨벤션
Classes
PascalCase
StartupClass
Methods
camelCase
startupMethod
Properties
camelCase
startupProperty
Constant
UPPER_CASE_SNAKE_CASE
STARTUP_CONSTANT
폴더 규칙
폴더 규칙은 pds/skeleton를 지켜야 합니다.
Sources
src/
src/StartupClass.php
Test Sources
tests/
tests/StartupClassTest.php
Configure
config/
config/config.php
Resource Files
resources/
resources/app.css
Execute Files
bin/
bin/process_join_user_count
Documents
docs/
docs/how-to-build.md
이미 예약된 파일 이름
Information
README.md
Composer 네임스페이스
모든 라이브러리는 Composer
규격에 맞는 네임스페이스를 지켜야 합니다.
타입과 주석
PHP 7부터는 리턴타입을 지원하기 때문에 메쏘드나 함수의 리턴타입을 주석으로 표기하지 않습니다.
모든 주석은 phpdoc.org의 최신판에서 제공하는 규격을 정확히 따라야 합니다.
특히 인라인 태그 레퍼런스와 태그 레퍼런스의 의미에 맞는 태그를 사용하세요.
인라인 태그 레퍼런스 :
@example
@example example1.php Counting in action.
@internal
@internal
@inheritdoc
@inheritdoc
@link
@link (Domain) Documentation of Foo.
@see
@see (Domain) Documentation of Foo. / @see MyClass::$items For the property whose items are counted.
태그 레퍼런스 :
주석의 타입에서 mixed는 2019년 2월 7일 PHP RFC를 통해서 명확히 정의가 되었으므로, 다른 의미로 절대 사용하지 않습니다.
mixed 타입에 void는 포함되지 않음을 유의하세요.
삼항 연산자(Ternary operators)와 복수 파라미터
삼항 연산자와 복수 파라미터의 표기는 다음에 나오는 것이 필수인지 아닌지로 구분합니다.
예를 들어서 삼항 연산자나 compact
함수와 같이 필수일 경우 컴마를 앞에 붙입니다.
반면 배열과 같이 필수가 아닐 경우 뒤에 붙입니다.
이 경우에는 마지막 컴마를 삭제하지 않음을 유의하세요.
에디터 설정
스타일 픽서
VSCode에서는 php_cs_fixer를 설치하며, 아래와 같은 설정을 이용합니다.
VSCode Setting Example
Last updated