디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 92 추천 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 - -
2883867 AtHeart 앳하트 'Plot Twist' 발명도둑잡기갤로그로 이동합니다. 08.23 74 0
2883866 머쉬베놈 (MUSHVENOM) - 돌림판 (feat. 신빠람 이박사) 발명도둑잡기갤로그로 이동합니다. 08.23 64 0
2883865 나님 왤케 특별한걸깡? ♥지나가던냥덩이♥갤로그로 이동합니다. 08.23 60 0
2883864 유아(YooA) - 자각몽 (Abracadabra) 발명도둑잡기갤로그로 이동합니다. 08.23 63 0
2883863 류수정-New Car [1] 발명도둑잡기갤로그로 이동합니다. 08.23 84 0
2883861 오늘의 작사 실마리: 히키코모리 10년만의 외출 발명도둑잡기갤로그로 이동합니다. 08.23 69 0
2883857 진로조언좀 제발 [2] ㅇㅇ(118.235) 08.23 133 0
2883856 넘나 낭만적이쟈낭..❤+ ㅠㅅ ㅠ ♥지나가던냥덩이♥갤로그로 이동합니다. 08.23 64 0
2883854 M83 'Midnight City' 발명도둑잡기갤로그로 이동합니다. 08.23 62 0
2883852 나님은 유행을 타지 않는당 By 나님 [1] ♥지나가던냥덩이♥갤로그로 이동합니다. 08.23 73 0
2883851 죽엇! 주억!! 주거..어엇!!!!! ♥냥덩코패쓰♥갤로그로 이동합니다. 08.23 78 0
2883850 나님 주무십니당⭐+ ♥냥덩코패쓰♥갤로그로 이동합니다. 08.23 76 0
2883849 회사 생활이 너무 재미가 없다. ㅇㅇ갤로그로 이동합니다. 08.23 90 0
2883847 사수랑 30만원 내기했는데 누구 말이 맞는지 봐주라 ㅇㅇ(211.234) 08.23 80 2
2883846 아아.. 애널 Night는 滿月 인건강..⭐ ♥냥덩코패쓰♥갤로그로 이동합니다. 08.23 100 0
2883845 [ 부산 ] 지하철 2호선 51편성 5호차 안에서 발명도둑잡기갤로그로 이동합니다. 08.23 92 0
2883844 냥덩이 집에 귀뚜라미 있대서 생각나는 신고산 타령 - 바리톤 최현수 발명도둑잡기갤로그로 이동합니다. 08.23 65 0
2883843 냥덩 만화상 이 만화가 대단하당⭐ 15회 수상작 [2] ♥냥덩코패쓰♥갤로그로 이동합니다. 08.23 69 0
2883842 타인을 인신공격한다고 하여 러스트 결점은 나르시갤로그로 이동합니다. 08.23 70 0
2883841 빌림 검사기 에러, 컴파일 시간 몰입 방해, 생산성 저하 나르시갤로그로 이동합니다. 08.23 72 0
2883840 러스트 빌림 검사기 문제는 악명 높습니다. 나르시갤로그로 이동합니다. 08.23 75 0
2883839 집값, 물가 아무리 비싸도 서울에 살 수밖에 없는 이유(유현준 교수) 발명도둑잡기갤로그로 이동합니다. 08.23 101 0
2883838 월급이 올라도 2030이 점점 빚더미에 앉는 진짜 이유 (박종훈 기자) 발명도둑잡기갤로그로 이동합니다. 08.23 78 0
2883836 "이러다 다 망한다니까!"…인스타에 미친 한국 사회 발명도둑잡기갤로그로 이동합니다. 08.23 64 0
2883834 임재범-이 밤이 지나면 표절이었구나 발명도둑잡기갤로그로 이동합니다. 08.23 111 0
2883833 신승훈-소녀에게 (Hey Girl) 발명도둑잡기갤로그로 이동합니다. 08.23 69 0
2883832 나님 디진다돈가스 후기 ♥냥덩코패쓰♥갤로그로 이동합니다. 08.23 68 0
2883831 오늘 작은 동생이 MBA 졸업했다 발명도둑잡기갤로그로 이동합니다. 08.23 73 0
2883830 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩코패쓰♥갤로그로 이동합니다. 08.23 57 0
2883828 나님 누엇어양⭐+ ♥냥덩Art♥갤로그로 이동합니다. 08.23 68 0
2883827 세상에서 한 커플만 연애한다면? "세계 유일의 연인" 발명도둑잡기갤로그로 이동합니다. 08.23 62 0
2883825 카카오톡이나 당근같은 메신저앱 만들기쉽냐 ㅇㅇ(61.39) 08.23 82 0
2883823 주변 사람들 다 이민 갔거나 최소 준비중임 [1] ♥냥덩Art♥갤로그로 이동합니다. 08.23 87 0
2883822 '러스트 빌림 검사기가 에러를 뿜어서 방해된다.' 수준미달이군요. [2] 프갤러(211.235) 08.23 93 0
2883821 인생설계끝 그래봤자방통대인생(118.235) 08.23 77 0
2883818 온라인서 금사도되냐 김지용(222.100) 08.23 66 0
2883816 온라인에서 없어진 캐논 광고 발명도둑잡기갤로그로 이동합니다. 08.23 70 0
2883813 정의의 캐산(신조인간 캐산) 한국판 OP 주제가 발명도둑잡기갤로그로 이동합니다. 08.23 53 0
2883811 똘이와 제타로보트 발명도둑잡기갤로그로 이동합니다. 08.23 64 0
2883809 시스템 엔지니어 취업했다 조언좀. [1] 프갤러(49.109) 08.23 181 0
2883808 미군 NSA가 만든 ghidra 이름이 기드라인 이유 발명도둑잡기갤로그로 이동합니다. 08.23 77 0
2883803 케이블은 여러개 있는데 기기락이 있다. 넥도리아(223.38) 08.23 71 0
2883801 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩Art♥갤로그로 이동합니다. 08.23 67 0
2883799 애널 꿀잠느낌 ♥냥덩Art♥갤로그로 이동합니다. 08.23 83 0
2883798 러스트 사용하면 왜 인성이 망가질까 나르시갤로그로 이동합니다. 08.23 78 0
2883797 Sony 케이블 고장나서 DIY할 수 있을까... [3] 넥도리아(223.38) 08.23 96 0
2883796 취업하고 십따 무관갤로그로 이동합니다. 08.23 70 0
2883795 애니로 언제나오려낭.. ♥냥덩Art♥갤로그로 이동합니다. 08.23 62 0
2883794 시노자키 아이와 섹스 100회 vs 머기업 취업 [3] 아스카영원히사랑해갤로그로 이동합니다. 08.23 196 0
2883793 러스트는 패러다임이 문제인게 맞습니다 나르시갤로그로 이동합니다. 08.23 70 0
뉴스 싱어송라이터 권진아, 가을 밤 감미로운 노래 감성 자극 ~ (가을달빛스타디움) 디시트렌드 09.06
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2