디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 79 추천 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/08/25 - -
2882130 해산물로 2틀 채웟으니 애널은 육고기❤+ ♥냥덩이♥갤로그로 이동합니다. 08.17 57 0
2882129 점심 발명도둑잡기갤로그로 이동합니다. 08.17 53 0
2882128 헬마 씹새끼야 [2] 아스카영원히사랑해갤로그로 이동합니다. 08.17 105 1
2882127 아 돈 벌어서 미국 나가서 살고 싶다- 프갤러(121.172) 08.17 56 0
2882126 아침 롤빵 발명도둑잡기갤로그로 이동합니다. 08.17 47 0
2882125 분산도 좋지만 가끔은 몰빵도 끌리는 법 ♥냥덩이♥갤로그로 이동합니다. 08.17 59 0
2882124 일본 속 깊숙이 스며있는 백제의 흔적 발명도둑잡기갤로그로 이동합니다. 08.17 54 0
2882123 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 08.17 57 0
2882122 오늘 점심.jpg [1] 야옹아저씨갤로그로 이동합니다. 08.17 77 0
2882121 시월은되야 시원해질듯 ♥냥덩이♥갤로그로 이동합니다. 08.17 68 0
2882118 국민임명식 x 왕따인증식 O ♥냥덩이♥갤로그로 이동합니다. 08.17 66 0
2882116 퐁퐁 받으러 간다. 넥도리아(223.38) 08.17 48 0
2882115 짱깨와 장애아로 채워지는 한국상황 ㄹㅇ;; ♥냥덩이♥갤로그로 이동합니다. 08.17 77 0
2882113 아직도 일욜이니 좋지아니한가 ♥냥덩이♥갤로그로 이동합니다. 08.17 51 0
2882112 틱톡이 유일하게 유튭에 비빌만하지 ㅇㅅㅇ ♥냥덩이♥갤로그로 이동합니다. 08.17 49 0
2882111 와 시발 vpn이 https 범용버전이였음??? ㅇㅇ(211.210) 08.17 76 0
2882110 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 08.17 63 0
2882109 내일부터 운동 다시 들어가자 프갤러(61.79) 08.17 47 0
2882108 요즘 아침조차 뛰뛰하기엔 넘 더움 ♥냥덩이♥갤로그로 이동합니다. 08.17 56 0
2882107 집으로.. ♥냥덩이♥갤로그로 이동합니다. 08.17 51 0
2882106 내 글 왜 실베감??? [4] 아스카영원히사랑해갤로그로 이동합니다. 08.17 103 0
2882105 왕따 소녀를 지켜준 훈남의 정체 <보디가드의 비밀 계약> 발명도둑잡기갤로그로 이동합니다. 08.17 51 0
2882104 난 더 진화한건가... 프갤러(61.79) 08.17 44 0
2882103 특이점 온다 노동해방시대 기본소득제도시대가 온다 ㅇㅇ 뒷통수한방(1.213) 08.17 45 0
2882097 배급견 이재명을 예언한 삼성 이건희 회장 ♥냥덩이♥갤로그로 이동합니다. 08.17 132 0
2882095 왼똥오밥 ㅋㅅㅋ 종니 웃기넹 ♥냥덩이♥갤로그로 이동합니다. 08.17 59 0
2882091 좇센 채용시장 ) 응 외노자쓰면돼~~응 ai쓰면돼~~ 뒷통수한방(1.213) 08.17 57 0
2882090 이재명이 윤미향을 사면남용한 이유 ♥냥덩이♥갤로그로 이동합니다. 08.17 63 0
2882089 M6 까지 존버 m4 m5 맥사면 ㅂㅅ [4] ♥냥덩이♥갤로그로 이동합니다. 08.17 87 0
2882088 고양이 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.17 50 0
2882087 러시아 푸틴 “우편투표는 부정조작선거다“ ♥냥덩이♥갤로그로 이동합니다. 08.17 64 0
2882086 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.17 54 0
2882085 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.17 62 0
2882083 나는 리뷰이벤트 없으면 절대 5점 안줌 야옹아저씨갤로그로 이동합니다. 08.17 60 1
2882075 5년뒤 - 옛날에는 프로그래머라는 일도 있었단다 프갤러(183.101) 08.17 66 0
2882073 한 줄 잘못 쓴거 고치겠다고 ㅇㅇ(106.241) 08.17 81 0
2882072 시청역 돌진사건은 무려 9킬인데 금고5년인데 ㅇㅇ(118.235) 08.17 68 0
2882071 비전공자인데 궁금한거 있음 [1] ㅇㅇ갤로그로 이동합니다. 08.17 150 0
2882041 조직스토킹 마인드컨트롤 뇌파공격 피해자 사이트 만드는중 [2] 어린이노무현갤로그로 이동합니다. 08.17 115 0
2882040 두들겨 맞다가 막판 역전 KO 프갤러(61.79) 08.17 66 0
2882038 dev c++ 안됨 프갤러(219.241) 08.17 94 0
2882035 경력 이직도 포폴 필요하냐 [4] 프갤러(1.255) 08.17 154 0
2882034 C / C++ 꼭 알아야 하냐? 요즘에? [6] 루도그담당(58.239) 08.16 189 0
2882033 현금 10억 vs 빌게이츠 두뇌 프갤러(121.139) 08.16 88 0
2882032 ` 주님께서 곧 오십니다 -(180.64) 08.16 79 0
2882031 IoC와 DI 완벽 정리 프갤러(121.133) 08.16 84 0
2882030 아스카는 과로에 몸져누울 것 같다 [3] 아스카영원히사랑해갤로그로 이동합니다. 08.16 102 0
2882023 김성수 장대호는 전생에 살해당해서 좇센에서 태어난거임 프갤러(1.213) 08.16 72 0
2882022 이거 드랍 테이블 로직에 bias 보정을 안한거 같은데 해명하십시오 헬님 [2] ㅆㅇㅆ(124.216) 08.16 105 0
2882021 헬마님 카드뽑기에 헬마와 멍유 테이블을 만진것 같은데 맞습니까..? ㅆㅇㅆ(124.216) 08.16 79 0
뉴스 Mnet '보이즈 2 플래닛' 글로벌 팬덤 화력 폭발! 엠넷플러스 누적 투표수 230만 돌파! 디시트렌드 08.25
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2