디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 43 추천 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/11 - -
AD 가전디지털, 휴대폰 액세서리 SALE 운영자 25/08/08 - -
2880266 냥덩이 유동 또 무슨 일있었다고 저지랄하네 [2] ㅆㅇㅆ(124.216) 08.10 55 0
2880265 나님 잔당⭐+ ♥냥덩이♥갤로그로 이동합니다. 08.10 52 0
2880256 “교제살인 피해자들, 한국 아니었다면 살았을 것 [1] 발명도둑잡기갤로그로 이동합니다. 08.10 50 0
2880254 저 악질 성희롱 스토커 [7] ♥냥덩이♥갤로그로 이동합니다. 08.10 95 0
2880251 calmeanarie.co.in 유명한 바이러스 악성코드 로 치료하자 [1] 도리스아넥도리아(220.74) 08.10 69 0
2880248 조경태, 김문수 향해 “문해력 떨어지시는지 모르겠다” [현장영상] 발명도둑잡기갤로그로 이동합니다. 08.10 34 0
2880244 나님.. 어른으로 가는 계단을 오르기 시작했달깡? [2] ♥냥덩이♥갤로그로 이동합니다. 08.10 56 0
2880243 귀염❤+ ♥냥덩이♥갤로그로 이동합니다. 08.10 40 0
2880241 회사 가까워지면 자동으로 폰배경을 바꿔주는 기능 발명도둑잡기갤로그로 이동합니다. 08.10 84 0
2880240 나님 생명의 가치에 대해 칼럼 하나 써야하눈데 [1] ♥냥덩이♥갤로그로 이동합니다. 08.10 57 0
2880239 윈도우 볼륨바 못끔? 프갤러(115.23) 08.10 40 0
2880238 일제가 숨통 끊으려 했던 우리말…이제 옥스퍼드 사전에도 실린다 발명도둑잡기갤로그로 이동합니다. 08.10 37 0
2880237 국가가 딸배에 세금폭탄투하중 [4] 개멍청한유라갤로그로 이동합니다. 08.10 72 0
2880236 청춘이란 뭘깡..? [1] ♥냥덩이♥갤로그로 이동합니다. 08.10 70 0
2880235 프로그래밍하면서 느끼는데 와 LLM 없이는 어떻게 다 했을까 [2] ㅆㅇㅆ(124.216) 08.10 100 0
2880234 아 개씨바 날벌레? 모기? [1] ♥냥덩이♥갤로그로 이동합니다. 08.10 42 0
2880231 입사했더니 딴소리…직장인 3명 중 1명 "채용사기 당했다" 발명도둑잡기갤로그로 이동합니다. 08.10 63 0
2880227 상생 배달? 자율에 맡겼더니 역주행 [1] 발명도둑잡기갤로그로 이동합니다. 08.10 56 0
2880224 스토킹 가해자 평균 44세…중년男, 관계성 범죄 가해자 다수 차지 발명도둑잡기갤로그로 이동합니다. 08.10 30 0
2880223 또 '혼자' 일하다, 또 '끼여' 죽었다 [1] 발명도둑잡기갤로그로 이동합니다. 08.10 65 0
2880222 애널의달성 5// [1] ♥냥덩이♥갤로그로 이동합니다. 08.10 53 0
2880221 핸드폰 사진만 10만 장... 기록에 미친 엄마, 닮아가는 딸 [1] 발명도둑잡기갤로그로 이동합니다. 08.10 41 0
2880219 요즘 귀에 문제 생긴 사람들 왤케 많냐? 백신부작용인가? ♥냥덩이♥갤로그로 이동합니다. 08.10 45 0
2880216 C#의 장점은 정적 언어치고 생산성이 존나 높다는게 장점임 [1] ㅆㅇㅆ(124.216) 08.10 85 0
2880214 C#에서 좀 어려운 개념은 span<T>지 ㅆㅇㅆ(124.216) 08.10 77 0
2880212 파이썬 입문에 부정적인건 파이썬 생태계 자체가 언어보다 패키지임 ㅆㅇㅆ(124.216) 08.10 55 0
2880211 C#이 나는 입문 언어로 제일 괜찮다 생각함. [2] ㅆㅇㅆ(124.216) 08.10 78 0
2880209 C# 커리큘럼 다시 보니까 [5] 루도그담당(58.239) 08.10 99 0
2880207 나는 노드.js가 여태까지는 생태계가 C#처럼 생각했음 [1] ㅆㅇㅆ(124.216) 08.10 56 0
2880205 크으~!~!~!~!~!~!!~~~!~! 열혈 ㄱㅆㅅㅌㅊ !!! ♥냥덩이♥갤로그로 이동합니다. 08.10 53 0
2880204 러스트 빠돌이들이 제일 두려워하는 글 전격 공개 나르시갤로그로 이동합니다. 08.10 32 0
2880200 레전드 갱신ㅋㅋㅋㅋㅋㅋ 프갤러(122.199) 08.10 43 0
2880199 러스토커가 나한테 열라 까이더니 철들었나보네 ㅎ [3] 나르시갤로그로 이동합니다. 08.10 50 0
2880198 노드 js 패키지 생태계 드디어 얼추 이해가 간다 ㅆㅇㅆ찡갤로그로 이동합니다. 08.10 51 1
2880194 프갤 차단한거랑 안한거랑 확 차이가 나구나 [2] 루도그담당(58.239) 08.10 65 0
2880174 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 08.10 42 0
2880172 개발실력못지않게사회경험도중요한듯 [1] 현무E공인(58.225) 08.10 74 0
2880171 ‘좀비 같은 마약 중독자’ 美 명품 쇼핑가 등장 발명도둑잡기갤로그로 이동합니다. 08.10 45 0
2880168 무너지는 소프트파워, 헛심 쓰며 저무는 미국의 시대 발명도둑잡기갤로그로 이동합니다. 08.10 57 0
2880165 “명령도 안했는데” 멋대로 톱스타 상반신 노출 영상 만든 머스크의 AI 발명도둑잡기갤로그로 이동합니다. 08.10 46 0
2880164 흠..어느덧경력6년차연봉3500이되었군 [1] 현무E공인(58.225) 08.10 83 2
2880159 “동네친구 아쉬워 간 배드민턴장, 건강과 남편 다 찾았죠” 발명도둑잡기갤로그로 이동합니다. 08.10 43 0
2880155 폭도로 변하는 시민들... 심상치않은 유럽 발명도둑잡기갤로그로 이동합니다. 08.10 58 0
2880152 한여름밤 오싹 호러페스티벌 29일 청주서 개막 발명도둑잡기갤로그로 이동합니다. 08.10 25 0
2880149 ‘해커 놀이터’ 처지로 전락한 한국…다른 나라는 잘 막는다는데 발명도둑잡기갤로그로 이동합니다. 08.10 36 0
2880147 제조업 강국…학습할 데이터 넘친다 발명도둑잡기갤로그로 이동합니다. 08.10 49 0
2880143 FTA 체결국에도 관세… “미국, 무역상대국으로 신뢰 잃어” 발명도둑잡기갤로그로 이동합니다. 08.10 33 0
2880141 40대에 좆소 사장을 목표로 프갤러(61.79) 08.10 46 0
2880140 AI 인재 유출 막는다…정부 '탑티어 전략' 가동 발명도둑잡기갤로그로 이동합니다. 08.10 47 0
2880139 국산 딥엑스 AI칩, 중국 바이두 로봇 두뇌 된다 발명도둑잡기갤로그로 이동합니다. 08.10 39 0
뉴스 ‘백번의 추억’ 김다미X신예은, 두 눈으로 확인한 ‘베프’ 케미에 시선 집중! 1차 티저 영상 공개 디시트렌드 08.12
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2