디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 85 추천 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/08/29 - -
2884366 난 무섭다 권력자가... 혐오범죄는 갤애들이 하면서 넥도리아(223.38) 08.25 58 0
2884365 김유식 대표하고 10년이나 띠개수 12개 만큼 차이 안날텐데 넥도리아(223.38) 08.25 56 0
2884364 박민준 너가 그럴 자격 있어? 넥도리아(223.38) 08.25 55 0
2884363 바빠서 러스트 전도사인 저는 가봐야겠군요. 알아서 반성하십시오. 프갤러(218.154) 08.25 61 1
2884362 작고 소중행..❤+ ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 70 0
2884361 보석이 저능함에 저능함을 더해가는군요. c로 oop할 수 있으면 프갤러(218.154) 08.25 60 0
2884360 예전엔 뭘 단체로 잘못 알고 있으면 어떤 씹새가 약을 잘못팔았나 싶었는데 ㅇㅇ갤로그로 이동합니다. 08.25 64 0
2884359 러스트는 현존하는 프로그래밍 언어 중 가장 진보된 언어입니다. 프갤러(218.154) 08.25 65 0
2884358 러빨러는 제 글을 보고도 허위사실을 유포하는군요 나르시갤로그로 이동합니다. 08.25 53 0
2884357 와우 보석이 계속 저능해지는군요. c도 oop 할 수 있습니다. 프갤러(218.154) 08.25 62 0
2884356 러빨러의 진정한 스코틀랜드 논리적 오류 나르시갤로그로 이동합니다. 08.25 71 0
2884355 러스트는 oop 언어가 아닌게 맞습니다. ㅎㅎ 나르시갤로그로 이동합니다. 08.25 58 0
2884354 러스트 배우면 ecs 아키텍처의 게임을 만들 수 있어요. [2] 프갤러(218.154) 08.25 70 0
2884353 깃갤에 올라온 러빨러의 헬로 월드 수준 나르시갤로그로 이동합니다. 08.25 63 0
2884352 국내에서 c# 백엔드 잘 안쓰는 이유가 머임? [6] 뉴진파갤로그로 이동합니다. 08.25 120 0
2884351 '러스트는 oop가 안된다' 저능함의 극치. 프갤러(218.154) 08.25 60 0
2884350 아이폴더폰에 펜 지원 안하면 사줄 이유가 없음 ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 68 0
2884349 나 보여주면 광고 발명도둑잡기갤로그로 이동합니다. 08.25 57 0
2884348 [대한민국] 김문수 - X를 자산으로 보는 그 눈깔 - 프갤러(121.172) 08.25 61 0
2884347 케데헌 삭제 장면 발명도둑잡기갤로그로 이동합니다. 08.25 67 0
2884346 러스트 배워서 어따씀 [1] 뉴진파갤로그로 이동합니다. 08.25 80 0
2884345 M7때 기본형에 36,48긱 옵션 가능할듯 ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 65 0
2884344 프레임워크별 강함 순위 프갤러(106.101) 08.25 92 0
2884343 ai api 찐빠나는거 감당이 어렵네 시발 [1] 뉴진파갤로그로 이동합니다. 08.25 71 0
2884342 쿠쿠a.s 넥도리아(223.38) 08.25 51 0
2884341 이곳은 디시의 변방 와일드웨스트다 [1] 아스카영원히사랑해갤로그로 이동합니다. 08.25 85 0
2884339 프로그래밍 언어의 다양성 장단 발명도둑잡기갤로그로 이동합니다. 08.25 74 0
2884338 (부탁)만 3년차 개발자 이직 관련 [1] 프갤러(211.214) 08.25 119 0
2884337 네덕으로 가야할 디시에서 파딱 주딱 찾는 새끼들 ㅈ극혐 ㅇㅇ(39.7) 08.25 59 0
2884336 '살 파먹는 구더기' 인체감염 중남미 거쳐 미국서 발견 발명도둑잡기갤로그로 이동합니다. 08.25 55 0
2884335 루비씨가 재밋는건 가짜러스트충 잘패기 때문임 [2] 헬마스터갤로그로 이동합니다. 08.25 93 3
2884334 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 53 0
2884333 여기 갤은 파딱이랑 주딱 없음? [2] 우거지상갤로그로 이동합니다. 08.25 85 0
2884332 싸이버펑크 이미지 발명도둑잡기갤로그로 이동합니다. 08.25 61 0
2884331 집에 가고싶어서 거리뷰로 퇴근하는 중 발명도둑잡기갤로그로 이동합니다. 08.25 71 0
2884330 루비가 불쾌한건 AI 글을 그냥 도배하기때문임 ㅆㅇㅆ(124.216) 08.25 65 0
2884329 제일 이해가 안가는게 그거임 걍 러빠야 뭐 컨셉 놀이하는거야 둘째치고 ㅆㅇㅆ(124.216) 08.25 68 0
2884328 근데 안머그면 오후 컨디션 ㅆㅎㅌㅊ ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 61 0
2884327 러빨러는 반박 불가 러스트 좋같음에 빤스런 하실 예정 나르시갤로그로 이동합니다. 08.25 78 0
2884326 맘마먹기 존나 귀찮당 ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 53 0
2884325 머먹고살지 ㅅㅂ ㅇㅇ(58.229) 08.25 64 0
2884324 루비점마는 갤에서 꺼질 생각 없냐? 진짜 걍 잘 모르는 애새끼가 [3] ㅆㅇㅆ(124.216) 08.25 80 0
2884323 러스트는 oop도 지원 못하는 개븅신 언어입니다 나르시갤로그로 이동합니다. 08.25 61 1
2884322 "과거사 문제 빠진 발표문... 무엇을 위한 한일 정상회담인가" 발명도둑잡기갤로그로 이동합니다. 08.25 57 0
2884320 러스트 어려워서 포기하고 빤스런헤서 다른 언어 빨아봤자 똑같습니다. [1] 프갤러(218.154) 08.25 65 0
2884319 결국 드러난 러뻘러 수준 ㅋㅋ 나르시갤로그로 이동합니다. 08.25 51 0
2884318 체력이 회복안되면 양치기에 급급해서 디테일이 떨어짐 ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 53 0
2884317 열정이 올 때 ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 51 0
2884316 해외로 탈영한 애들 이유 ♥지나가던냥덩이♥갤로그로 이동합니다. 08.25 58 0
2884315 피에로배르뎅씨가 벌써 2연속 간식타가셧습니다 [2] 헬마스터갤로그로 이동합니다. 08.25 74 0
뉴스 황가람, 자연의 도시 아산 '제6회 달그락 페스티벌' 무대에 서다 디시트렌드 08.30
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2