디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

Ada 프로그래밍: 부록: Clair 코딩 스타일 가이드

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 91 추천 0 댓글 0

부록: Clair 코딩 스타일 가이드


들여쓰기: 탭 대신 2개의 공백을 사용하여 들여쓰기를 합니다.

  • 예약어 및 애스펙트: snake_case (전체 소문자)를 사용합니다.
    • 근거: 언어 키워드 및 애스펙트를 사용자가 정의한 식별자와 구별하기 위함입니다.
    • 예시: package, is, begin, end, if, procedure, with, pre, post

프라그마: 프라그마 이름과 해당 컨벤션 식별자에 snake_case (전체 소문자)를 사용합니다.

  • 근거: 다른 언어 키워드 및 속성과의 일관성을 위함입니다. 이는 프라그마 자체(예: import)와 표준 컨벤션 식별자(예: c, intrinsic) 모두에 적용됩니다.
  • 예시: pragma import (c, my_c_func, "my_c_func"), pragma convention (c, My_Data_Type)

공백:

  • 서브프로그램 호출 및 선언: 서브프로그램 이름과 여는 괄호 ( 사이에 단일 공백을 사용합니다.
    • 근거: 서브프로그램 이름을 타입 변환이나 괄호를 사용하는 다른 언어 구조와 시각적으로 구별하여 전체적인 코드 명확성을 향상시키기 위함입니다.
    • 예시 (호출): Clair.Error.get_error_message (errno_code);
    • 예시 (선언): procedure exit_process (status : Integer := EXIT_SUCCESS);
  • 범위 연산자 (..): 범위 연산자의 양쪽에 단일 공백을 사용합니다.
    • 근거: 연산자를 범위 경계와 시각적으로 분리하여 혼동을 방지하고, 특히 부동 소수점 또는 고정 소수점 리터럴과 함께 사용할 때 가독성을 향상시키기 위함입니다.
    • 예시 (타입 선언): range 0.0 .. 100.0
    • 예시 (루프): for i in 1 .. 10 loop

변수, 서브프로그램 및 엔트리: snake_case (밑줄이 있는 전체 소문자)를 사용합니다.

  • 근거: 모든 사용자가 정의한 실행 가능하거나 데이터를 보유하는 식별자에 대해 일관되고 읽기 쉬운 스타일을 유지하기 위함입니다.
  • 예시 (변수 및 서브프로그램): my_variable, get_pid
  • 예시 (엔트리): get_item, put_message ada protected body Buffer is entry get_item (item : out Data) when not is_empty is -- ... end get_item; end Buffer;
  • 반환값 변수: 서브프로그램의 반환값, 특히 상태 코드(예: 0, -1)를 담는 변수에는 retval 사용을 선호합니다.
    • 근거: 이는 result 식별자와의 잠재적 충돌을 피하는 널리 알려진 관례입니다. 특정 데이터를 나타내는 반환값의 경우 bytes_written, new_fd와 같이 더 설명적인 이름을 사용합니다.
    • 예시: retval := dlfcn_h.dlclose (self.handle);

속성: snake_case (전체 소문자)를 사용합니다.

  • 근거: 언어에서 정의한 속성을 사용자가 정의한 타입 및 서브프로그램과 구별하기 위함입니다.
  • 예시: errmsg'length, c_path'address

타입, 서브타입, 예외 및 보호 객체:

  • 단일 단어 식별자에는 Pascal_Case를 사용합니다.
    • 근거: File과 같은 패키지 내에서 Descriptor와 같은 이름은 File.Descriptor로 사용될 때 자명합니다. File.File_Descriptor와 같이 불필요한 접두사를 추가하면 가독성을 해칠 수 있습니다.
    • 예시: Descriptor, Flags, Object
  • 여러 단어로 된 식별자에는 Pascal_Case_With_Underscores를 사용합니다.
    • 근거: 여러 단어로 된 타입 이름 내의 단어들을 명확하게 구별하여 가독성을 향상시키기 위함입니다.
    • 예시: Library_Load_Error, Symbol_Lookup_Error

상수:

  • 컴파일 타임 상수: UPPER_CASE_WITH_UNDERSCORES를 사용합니다. 이 규칙은 표준 라이브러리의 상수를 포함한 모든 정적 상수에 적용됩니다.
    • 근거: 정적인 고정 값을 다른 모든 식별자와 명확하게 구별하기 위함입니다.
    • 프로젝트 정의 예시: EXIT_SUCCESS, MAX_BUFFER_SIZE
    • 표준 라이브러리 예시: System.NULL_ADDRESS, Interfaces.C.NUL, Interfaces.C.Strings.NULL_PTR
  • 런타임 상수: snake_case (변수처럼)를 사용합니다.
    • 근거: 서브프로그램 내에서 동적 값(예: 매개변수)으로 초기화되는 상수에 사용됩니다. 이를 '읽기 전용 변수'로 취급합니다.
    • 예시: final_message : constant String := "Error: " & message;

패키지: Pascal_Case를 사용합니다.

  • 예시: Clair.Process
  • 예외: 두 글자로 구성된 Dl의 경우 DL로 표기합니다. (예: Clair.DL, Clair.Dl Clair.D1처럼 보일 수 있음).

표준 라이브러리 명명 규칙:

  • Interfaces.C: Interfaces.C 패키지 및 그 하위 패키지의 타입과 서브프로그램은 C 표준 라이브러리의 명명 규칙과 일치하도록 snake_case를 사용해야 합니다. 이 패키지의 상수는 컴파일 타임 상수에 대한 전역 UPPER_CASE 규칙을 따릅니다.
    • 근거: Ada와 C 간의 명확하고 일관된 정신적 매핑을 유지하면서 프로젝트의 모든 상수가 균일한 모양을 갖도록 보장하기 위함입니다.
    • 예시 (타입/서브프로그램): Interfaces.C.int, Interfaces.C.char_array, Interfaces.C.Strings.chars_ptr
    • 예시 (상수): Interfaces.C.NUL, Interfaces.C.Strings.NULL_PTR


추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 순간의 말실수로 이미지 타격이 큰 것 같은 스타는? 운영자 25/09/01 - -
AD 신학기 레벨업~!! 운영자 25/09/05 - -
2885293 허수들은 윈도우임베가 '대체하는쪽' 이라는사실을모르나봄 [1] 네오커헠(61.253) 08.29 134 0
2885292 나 약속있어서 11시에 깨서 준비하고 12시에 나가야 돼..ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 08.29 68 0
2885291 애플 이벤트 D - 12 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.29 64 0
2885290 발 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.29 66 0
2885289 태연 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 08.29 67 0
2885288 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.29 73 0
2885287 애플은 진짜 볼때마다 느끼지만 가장 '중국'같은 기업임 [1] ㅆㅇㅆ(124.216) 08.29 107 0
2885286 내 기억으로는 옛날에 맥북 쓰는 이유는 프론트랑 서버때문 [2] ㅆㅇㅆ(124.216) 08.29 128 0
2885285 프리랜서로 자리 잡으면 고정 고객이 있단건데 타인 밑에 안드가지. ㅆㅇㅆ(124.216) 08.29 88 0
2885284 개발자는 맥북 쓴다는 말이 어쩌다 생긴 걸까 [3] ㅇㅇ갤로그로 이동합니다. 08.29 117 0
2885282 러스트에 GC가 없는 이유 나르시갤로그로 이동합니다. 08.29 105 0
2885281 러스트 cargo가 좋다는 진짜 의미 나르시갤로그로 이동합니다. 08.29 92 0
2885280 Ada에서 객체 지향 프로그래밍(OOP) 나르시갤로그로 이동합니다. 08.29 79 0
2885277 생각보다 1인개발자로 밥벌어먹는 사람이 없나보네? [3] ㅂㅂ(112.164) 08.29 143 0
2885275 Ada의 모듈성과 데이터 추상화 나르시갤로그로 이동합니다. 08.29 67 0
2885274 Ada의 동시성 나르시갤로그로 이동합니다. 08.29 80 0
2885271 유튜브에 기술의발전은 이제 끝났다고 기술이 발전할수 없다는데 뒷통수한방(1.213) 08.29 91 0
2885266 1년 내내 러스트로 짠게 헬로월드7 이런 거?? 나르시갤로그로 이동합니다. 08.29 82 0
2885265 러빨러 프갤 유입 연도가 언제야? 나르시갤로그로 이동합니다. 08.29 77 0
2885263 러스트가 덜 떨어진 언어인 이유 나르시갤로그로 이동합니다. 08.29 84 0
2885262 러스트는 저전력 언어가 아닙니다. ㅎㅎ 나르시갤로그로 이동합니다. 08.29 77 0
2885258 ai 소설 ㅈㅈ 친다 뉴진파갤로그로 이동합니다. 08.29 98 0
2885257 내가 오래 디시 하면서 느낀 몇가지 루도그담당(58.239) 08.29 110 0
2885250 왜 중국인 무비자 입국을 두려워함? [5] 야옹아저씨갤로그로 이동합니다. 08.28 294 5
2885249 re100 달성하려면 러스트 써야합니다. 프갤러(110.8) 08.28 78 0
2885248 기안84 수상한 건 프갤러(211.210) 08.28 104 0
2885232 수능 2등급으로 인서울 컴공했는데 c언어 몰라도 졸업장딸수있지?? 뒷통수한방(1.213) 08.28 133 0
2885230 [잡정보] 모든 프로그래밍 언어를 마스터하는 것은 어려울까?.. [5] +abcd3421갤로그로 이동합니다. 08.28 118 0
2885218 메이플<<이새끼가 진짜 존나 귀찮음 ㅇㅅㅇ ㅇㅇ(223.38) 08.28 66 0
2885217 메이플<<이새끼가 진짜 존나 귀찮음 ㅇㅅㅇ ㅇㅇ(223.38) 08.28 55 0
2885216 코랩 나만 정지 먹음? 프갤러(121.130) 08.28 68 0
2885204 뉴프로 시크릿 산타 기능 추가 안내 헬마스터갤로그로 이동합니다. 08.28 75 0
2885202 술 끊는게 인지능력, 생활습관, 체력 개선에 지대한 영향을 끼치냐?? [1] ㅇㅇ(223.38) 08.28 93 0
2885197 [1인 1개] 배달의 민족 3 만원 짜리 쓸사람 써! [1] ㅇㅇ(223.39) 08.28 78 0
2885195 오피 갔다온 썰 함 풀어봄ㅋ ㅋㅋ ㅇㅇ(118.235) 08.28 128 0
2885194 ai로 다 대체 되니까 프갤 망했냐? [1] 프갤러(59.11) 08.28 130 0
2885193 파이썬 초초보 질문 [1] 프갤러(59.11) 08.28 88 0
2885191 윈도우임베 미래없다는말이 젤 개소리인게 [3] 네오커헠(211.234) 08.28 162 0
2885190 자꾸 기술스택 처바꿔대서 짜증난다. [1] 프갤러(211.234) 08.28 110 0
2885183 세상엔 좆병신이 많은 것 같다 [3] 아스카영원히사랑해갤로그로 이동합니다. 08.28 119 0
2885181 또 하나 더... 넥도리아(220.74) 08.28 81 0
2885180 통수조심해라 [1] 프갤러(211.170) 08.28 104 2
2885178 부침개 먹는다. [1] 넥도리아(220.74) 08.28 96 0
2885177 아 존나 배고파 루도그담당(118.235) 08.28 75 0
2885176 저는 가짜 개발자입니다 ㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠㅠ [2] 공기역학갤로그로 이동합니다. 08.28 141 3
2885174 요즘은 마크개발자놀이역할 로블록스가 한다고 들은거같음 공기역학갤로그로 이동합니다. 08.28 83 0
2885173 님들, 딥시크 모델 무료/무제한으로 풀림 ㄷㄷ (정보 공유) 무한루프갤로그로 이동합니다. 08.28 85 0
2885170 님들 컴공 졸업할때 cpa 응시자격같은거 채웠음? [3] 공기역학갤로그로 이동합니다. 08.28 129 0
2885168 저도 웹개발 하다가 적성에 안맞아요 프갤러(118.235) 08.28 99 0
2885166 sql 연습 이런 사이트 없나 [1] 프갤러(118.235) 08.28 86 0
뉴스 코치, 2025 가을 캠페인 ‘Revive Your Courage’ 공개 디시트렌드 09.06
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2