디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 69 추천 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/18 - -
AD 가전디지털, 휴대폰 액세서리 SALE 운영자 25/08/08 - -
2880942 네이버 토스 종결 프갤러(121.139) 08.12 115 1
2880937 집에 5공화국 쉴드치는 돼지가 살아요. 넥도리아(223.38) 08.12 52 0
2880935 클리우드 엔지니어쪽 생각하고 있는데 프갤러(211.235) 08.12 68 0
2880931 대규모시스템설계기초책 재밌네 [1] 밀우갤로그로 이동합니다. 08.12 59 0
2880929 찐윤이랑 윤석열이 국민 삶 의료질 다 망쳐나서.. [1] 넥도리아(223.38) 08.12 78 0
2880927 아는 형님이 크롤링 만들어달래서 루도그담당(58.239) 08.12 82 1
2880926 영어 좆도 모르면 프로그래밍 못 할 정도임? [15] 냥이펀치갤로그로 이동합니다. 08.12 137 0
2880917 이거 ODD 수리 하는게 좋을까요. 어떻게 살릴까요? [1] 넥도리아(223.38) 08.12 67 0
2880915 야옹아저씨 글 자체가 적페 넥도리아(223.38) 08.12 63 0
2880914 기호식품이 담배, 술 지원금으로 사는인간들 적페 넥도리아(223.38) 08.12 59 0
2880909 조직스토킹 전파무기 벽투시기 방사성물질테러로부터 안전할권리를 만듭시다 손발이시립디다갤로그로 이동합니다. 08.12 62 0
2880905 권리를 쟁취하자 손발이시립디다갤로그로 이동합니다. 08.12 52 0
2880904 스카이넷좌를 석방하라 조직스토킹으로부터 안전할권리 손발이시립디다갤로그로 이동합니다. 08.12 44 0
2880903 조직스토킹으로부터 안전할권리 스카이넷좌와 함께합니다 손발이시립디다갤로그로 이동합니다. 08.12 46 0
2880902 7 만언 ! 받는법 정리~~~ ! ㅇㅇ(106.101) 08.12 47 0
2880899 파이썬 계 김영한 없냐? [2] 프갤러(121.137) 08.12 341 0
2880897 니들 정치인하고싶냐? [3] 헬마스터갤로그로 이동합니다. 08.12 87 1
2880896 PM님이 사무실에서 일본어 공부하는 저를 발견하셨어요 [2] 아스카영원히사랑해갤로그로 이동합니다. 08.12 103 1
2880891 그냥 어느 레이어에 따라서 필요한 멘탈 모델이 달라진다는게 핵심이지 ㅆㅇㅆ(124.216) 08.12 41 0
2880889 애초에 프로그래밍은 유일한 절대적 최적해가 아닌 ㅆㅇㅆ(124.216) 08.12 63 0
2880888 한국에서는 논리적 사고를 수학적 사고랑 동치화해서 그래 ㅆㅇㅆ(124.216) 08.12 50 0
2880887 수학적 사고력이라는게 뭘까 [1] 프갤러(211.186) 08.12 54 0
2880886 토스는 개발자의 회사보다는 기획자의 회사가 더 맞지 않나 싶은데 난 [2] ㅆㅇㅆ(124.216) 08.12 115 0
2880883 토스 다크패턴은 진짜 UI/UX 설계중에서도 악질중에 악질임 [3] ㅆㅇㅆ(124.216) 08.12 118 0
2880881 토스부러윤이유 [2] 밀우갤로그로 이동합니다. 08.12 85 0
2880880 토스 다크패턴 느낀게 [2] 루도그담당(211.184) 08.12 95 0
2880874 네이버나 이런 애들은 뭔가 그래도 오픈소스로 혁신기술 만들어팔잖아 [4] ㅆㅇㅆ(124.216) 08.12 99 0
2880872 토스의 서사라는게 그건 10년대 초반이나 통했지 지금은 20년대 중반인데 ㅆㅇㅆ(124.216) 08.12 67 0
2880871 내가 느끼는 것은 구직 시장에서 서사를 어떻게 파느냐가 중요한듯 ㅆㅇㅆ(124.216) 08.12 64 0
2880868 왜 애들은 토스를 가고 싶어할까. [4] ㅆㅇㅆ(124.216) 08.12 134 0
2880864 구강. 편광. 표리의 틈새. 까마귀와 성명 공기역학갤로그로 이동합니다. 08.12 42 0
2880862 토뱅은 또갑자기 집중채용이네 [3] 밀우갤로그로 이동합니다. 08.12 135 0
2880856 ㅆㅇㅆ 게이 요즘 cs 위주 글 안 써줘서 ㅁㅈㅎ [2] 루도그담당(211.184) 08.12 83 0
2880854 너는 따땃한 회사의 응딩이에 붙어있지만 나는 고객한테 구걸해야한다 [4] ㅆㅇㅆ(124.216) 08.12 77 0
2880853 몇 년만에 왔는데 멍유 아직도 살아있었네 [1] ㅇㅇ(211.185) 08.12 57 0
2880852 구직단념자가 왜 되는지 알것같다 [3] ㅇㅇ(223.38) 08.12 96 0
2880851 당연히 명세랑 구조는 내가 직접짜지 게이야 [2] ㅆㅇㅆ(124.216) 08.12 55 0
2880850 나는 현존하는 모든 LLM아레나에 있는 모든 모델 다쓰고 있는데 [2] ㅆㅇㅆ(124.216) 08.12 76 0
2880848 걍 질문을 존나 상세하게 해야하는게 귀찮음 [2] 루도그담당(211.184) 08.12 75 0
2880846 운동 다시 시작해야 하는데 좆됐노 프갤러(61.79) 08.12 46 0
2880845 나는 api 쓰면 비용 너무 많이 나와서 에이전트도 꺼둔 사람임 ㅆㅇㅆ(124.216) 08.12 71 0
2880842 GPT 질문을 제대로 하기위해서 질문을 래퍼하고 있는 이게 맞는거냐? [2] ㅆㅇㅆ(124.216) 08.12 62 0
2880840 일단 GPT 5용 시스템 카드 읽고 질문 프롬프트 템플릿 만듬 ㅆㅇㅆ(124.216) 08.12 39 0
2880839 지피티 이거 처음 나왔을땐 충격이였는데 [1] 루도그담당(211.184) 08.12 78 0
2880836 GPT 5 시스템 카드 읽어보고 어떻게 최고수준의 질문할지 생각해봄 [2] ㅆㅇㅆ(124.216) 08.12 83 1
2880833 GPT 5 이거 라우팅 모델이라는게 결국 질문을 잘해야 좋은 모델 쓰게 [2] ㅆㅇㅆ(124.216) 08.12 71 0
2880830 아 공부 며칠간 쉴까 [3] 루도그담당(211.184) 08.12 58 0
2880829 상사가 그냥이란건 없다. 모든 것엔 이유가 있어야 된다길래 [3] 프갤러(211.36) 08.12 78 0
2880828 나는 좀 궁금한게 통진당 해산이 됐으면 당연히 국힘도 해산되야하지 않나. [5] ㅆㅇㅆ(124.216) 08.12 71 0
2880825 집에 가고싶다 루도그담당(211.184) 08.12 47 0
뉴스 문원, ♥신지와 결혼 앞두고…기나긴 고민 끝에 ‘중대 발표’ 디시트렌드 08.16
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2