디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 94 추천 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/08 - -
AD 신학기 레벨업~!! 운영자 25/09/05 - -
2885096 나도 러스트 접기로 했다 나르시갤로그로 이동합니다. 08.28 73 0
2885095 나님 등장 프갤러(49.174) 08.28 60 0
2885094 나도 .. 하기로 했다..ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.28 64 0
2885093 그냥월급쟁이계속할라면 FA윈폼질이 제일인듯 네오커헠(121.157) 08.28 107 0
2885092 c# 을 써야한다 [3] ㅇㅇ(211.193) 08.28 123 0
2885091 나도 러스트 접기로했다 [5] 헬마스터갤로그로 이동합니다. 08.28 121 0
2885090 애플 이벤트 D - 13 헤르 미온느갤로그로 이동합니다. 08.28 68 0
2885088 태연 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 08.28 72 0
2885087 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.28 84 0
2885086 나 대기업 프리 4년차인데. [1] 찍먹갤로그로 이동합니다. 08.28 123 0
2885085 프갤러들 중에서 키 180 넘는 [10] 루도그담당(58.239) 08.28 120 0
2885084 러스트 지금 생각해보면 게거품인거 같음 프갤러(223.57) 08.28 84 0
2885056 개발 블로그 같은거 쓰는거 생각해보니 좀 대단한데 프갤러(106.241) 08.28 102 0
2885055 헌혈 하면 안되는 이유.jpg [5] 야옹아저씨갤로그로 이동합니다. 08.28 148 5
2885037 12시 이후엔 위워크에 사람이 없어서 [1] 꼬치의달인갤로그로 이동합니다. 08.28 128 0
2885032 몸살 한번 걸리고나니, 너무 건강하고 싶은데 어떻게 하면 되냐?? ㅇㅇ(125.136) 08.28 100 0
2885031 머기업 서류 통과하고 과제 합격했음 [3] 꼬치의달인갤로그로 이동합니다. 08.27 185 0
2885029 커널 조작해서 [4] 루도그담당(58.239) 08.27 122 0
2885028 냥뎡이 너 오늘 뉴스에 나왔더라? [1] ㅇㅇ(223.38) 08.27 119 0
2885022 러스트 60년 갈아넣으면 삼라만상을 깨우치고 신선이 될 수 있다. 프갤러(110.8) 08.27 103 0
2885015 술, 담배를 안하는게 생각보다 인생에 중요하다고 생각한다. [1] ㅇㅇ(221.155) 08.27 131 0
2885013 러스트 인생 40 년 갈아 넣었습니다. 프갤러(59.16) 08.27 94 0
2885003 Hex Editor만 가지고 바이너리 분석하는 방법 정리해봄 [13] Butter(1.235) 08.27 162 1
2884997 아스카의 1억 모으기 프로젝트는 계속 진행됩니다 [2] 아스카영원히사랑해갤로그로 이동합니다. 08.27 97 0
2884990 폰노의만의 저주 [2] ㅇㅇ(125.179) 08.27 120 1
2884988 언어별 철학.txt [3] 프갤러(106.101) 08.27 190 1
2884985 바이브코딩한거 결국 유지보수가 안되는데 riir하고 싶다. 프갤러(27.163) 08.27 93 0
2884984 형들 C언어 배울려고 학원 가는거 에바인가요? [6] ㅇㅇ(211.235) 08.27 149 0
2884983 샤워하기 싫다. 발뒤꿈치가 아프다. 넥도리아(220.74) 08.27 73 0
2884982 마트에 냥덩이 떴다고 한다. [4] 헬마스터갤로그로 이동합니다. 08.27 173 3
2884981 웹사이트 만들기 개재밌당 ㅆㅇㅆ(124.216) 08.27 84 0
2884980 아니지. 러스트가 아니라 보석새끼가 갤 씹창내고 있는거겠지. [1] 프갤러(223.63) 08.27 94 0
2884978 아패 26 절대 업뎃 하지마라 개쓰레기 ♥냥덩사제단♥갤로그로 이동합니다. 08.27 114 0
2884976 [대한민국] 트럼프와 이재명 만남 분석 프갤러(121.172) 08.27 92 0
2884975 나님 친중매국 쥐찢명 퇴마즁⭐+ ♥냥덩사제단♥갤로그로 이동합니다. 08.27 99 0
2884971 테스트 데이터 못 기다리고 [9] 아스카영원히사랑해갤로그로 이동합니다. 08.27 121 0
2884970 장난안까고 아프다. [1] 브레이버갤로그로 이동합니다. 08.27 96 0
2884967 노랑봉투법은 유럽의 법을 따온거고 유럽법을 살펴보자 프갤러(211.193) 08.27 90 0
2884966 웹개발이라 해야하나 개발자모드 도움좀 줄사람 있음? [1] 프갤러(121.154) 08.27 105 0
2884965 애널의달성 1.//2 ♥냥덩사제단♥갤로그로 이동합니다. 08.27 91 0
2884964 일본의 실전 교통 교육 프갤러(211.193) 08.27 76 0
2884963 애플 이벤트 D - 14 ㅇㅅㅇ ㅇㅅㅇ(211.36) 08.27 67 0
2884962 냉정하게 23살먹고 공부해보겠다는건 아집이고 객기일까요?? [3] ㅇㅇ(59.8) 08.27 156 0
2884961 백엔드로 러스트라니.. Elixir 가 대세 ㅇㅇ [1] 중생들아갤로그로 이동합니다. 08.27 110 0
2884960 이재명 셀프 리스크 감추기 위해 국고 1000조 유출 ㄷㅅㄷ ♥냥덩사제단♥갤로그로 이동합니다. 08.27 89 0
2884959 이재명 또 거짓말 관세 25% 유지 한국경제 몰락중 ♥냥덩사제단♥갤로그로 이동합니다. 08.27 104 0
2884958 가진것도, 아는것도 없는 23살의 인생이 두렵고 막막합니다. ㅇㅇ(221.153) 08.27 84 0
2884957 ㄱㅏ장 좋은 기술은 사용자가 인식하지 못하고 사용하는 ♥냥덩사제단♥갤로그로 이동합니다. 08.27 104 0
2884956 C#엔 가비지 컬렉터가 없음 [2] 루도그담당(118.235) 08.27 158 0
2884955 핑모너무조아❤ ♥냥덩사제단♥갤로그로 이동합니다. 08.27 85 0
뉴스 ‘열린음악회’ 김민희, 무대 위에서 펼친 정열의 축제…주말 끝 시원한 ‘흥’ 선사 디시트렌드 09.08
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2