디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 72 추천 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 - -
공지 이미지 댓글 기능 안내 운영자 25/08/20 - -
AD 전자제품 세일쇼! 운영자 25/08/19 - -
2882354 흠 나는 로컬통신 네임드파이프+메시지팩으로하는데 네오커헠(1.237) 08.18 65 0
2882353 Jvm 분석해보는데 신기하네 루도그담당(118.235) 08.18 55 0
2882352 날씨 이재명 같네 씨발 [2] ♥냥덩이♥갤로그로 이동합니다. 08.18 55 1
2882351 살금살금 ♥냥덩이♥갤로그로 이동합니다. 08.18 27 0
2882350 하루에 오조오억줄 감사의 코딩 공기역학갤로그로 이동합니다. 08.18 50 0
2882349 차근차근 ♥냥덩이♥갤로그로 이동합니다. 08.18 27 0
2882348 고물들 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 08.18 33 0
2882347 코딩 입문 질문드립니다...(간단한 웹사이트 만드는 정도) [3] 프갤러(110.11) 08.18 57 0
2882346 이재명 “퇴직금 없에버리겟다” ♥냥덩이♥갤로그로 이동합니다. 08.18 58 0
2882345 이재명 지지율 30%대로 폭락 기정사실화 ㅋㅅㅋ ♥냥덩이♥갤로그로 이동합니다. 08.18 45 0
2882344 태연 ㅇㅅㅇ [2] 헤르 미온느갤로그로 이동합니다. 08.18 38 0
2882343 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.18 29 0
2882342 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 08.18 28 0
2882341 저 졸업작픔 주제 추천좀 [7] 공기역학갤로그로 이동합니다. 08.18 70 0
2882340 자격증은 따볼까 생각중이다. 근데 3개월전 검색했던 자격증이 뭔지 몰라요 넥도리아(14.35) 08.18 28 0
2882339 여행은 시원할때만 가는게 맞당 ♥냥덩이♥갤로그로 이동합니다. 08.18 30 0
2882336 c#이 c++++이었음? [2] 뉴진파갤로그로 이동합니다. 08.18 68 0
2882335 다시 맑아졌다. 넥도리아(14.35) 08.18 24 0
2882333 짱깨들 코딩 개잘하노 [2] 뉴진파갤로그로 이동합니다. 08.18 81 0
2882332 sql 파일 포맷인거 처음암 뉴진파갤로그로 이동합니다. 08.18 42 0
2882331 러스트 빠돌이들 눈돌아갈 Ada의 주요 특징 ㅋㅋ 나르시갤로그로 이동합니다. 08.18 31 0
2882330 당월 익월 이런 용어는 왜쓰는거냐? [7] 헬마스터갤로그로 이동합니다. 08.18 66 0
2882329 빌게이츠 한국오노 ㅇ.ㅇ(59.151) 08.18 38 0
2882328 전략은 분석선행 필수 ♥냥덩이♥갤로그로 이동합니다. 08.18 29 0
2882327 나의 웹앱땔깜개발자들과의 싸움 이렇게 쉽게 이기면 안되는데 [1] 네오커헠(1.237) 08.18 133 0
2882326 숨고 코딩 강사들 보면 [1] 루도그담당(118.235) 08.18 68 0
2882325 4050 썩은물로 부패하는 한국 ♥냥덩이♥갤로그로 이동합니다. 08.18 70 0
2882320 인지과학조져라 [4] 손발이시립디다갤로그로 이동합니다. 08.18 74 0
2882319 자바 문법 GR 같아서 못 해 먹겠네 증말. [4] 프갤러(59.16) 08.18 72 0
2882317 나님 왤케 특별하실깡? ♥냥덩이♥갤로그로 이동합니다. 08.18 51 0
2882316 나님 끙야즁❤+ ♥냥덩이♥갤로그로 이동합니다. 08.18 29 0
2882315 토요코키즈 ♥냥덩이♥갤로그로 이동합니다. 08.18 33 0
2882314 요새 집필 중인 1.2 Ada의 주요 특징 나르시갤로그로 이동합니다. 08.18 38 0
2882313 러스트 팬들이 놀랄 만한 Ada의 특징들 나르시갤로그로 이동합니다. 08.18 46 0
2882311 일본인을 한국의 기준으로 판단이 힘든 이유 프로외노자갤로그로 이동합니다. 08.18 65 0
2882310 동일노동 동일임금이 잘 되려면 노동강도 조사가 잘 되야 발명도둑잡기갤로그로 이동합니다. 08.18 50 0
2882309 건설업종 안전관리자가 직업에 회의감 발명도둑잡기갤로그로 이동합니다. 08.18 51 0
2882308 2030 줄고 4050 고인물천국된 판교 - 뉴스 ㅇㅇ(183.101) 08.18 77 0
2882307 이번달은 안정권이다 씨발ㅋㅋㅋ 저번달 통수만 안당했어도 ㅆㅇㅆ(124.216) 08.18 68 0
2882306 쿠팡 개발자는 노동자 죽이는 앱 개발 하다가 [6] 발명도둑잡기갤로그로 이동합니다. 08.18 103 0
2882305 오늘도 외주하나 깔쌈하게 끝냈다 [1] ㅆㅇㅆ찡갤로그로 이동합니다. 08.18 89 0
2882304 쿠팡 노조 가입 희망자 발명도둑잡기갤로그로 이동합니다. 08.18 50 0
2882303 음기 충전 발명도둑잡기갤로그로 이동합니다. 08.18 66 0
2882302 AI 는 패턴매칭 맞지만, 알려지지않은 패턴도 거의없잖아? 피치(183.101) 08.18 53 0
2882301 ㄹㅇ 아빠회사가 최고다 [1] 프갤러(1.226) 08.18 80 0
2882299 이불 안에서 태블릿 하는 보니 발명도둑잡기갤로그로 이동합니다. 08.18 40 0
2882297 영화 <숟가락 살인자> 있대서 생각나는 것 발명도둑잡기갤로그로 이동합니다. 08.18 53 0
2882295 참 살기좋은 아름다운 나라여 ㅋㅋ 뒷통수한방(1.213) 08.18 43 0
2882294 <토이 스토리4> 예고편 보고 생각나는 것 발명도둑잡기갤로그로 이동합니다. 08.18 135 0
2882292 C로 이것저것 만들다보면 어디라도 취직은 할까? [4] 프갤러(59.24) 08.18 114 0
뉴스 [광복 80주년 KBS 대기획] '이 순간을 영원히-조용필', ‘조용필의 새로운 도전’ 담은 ‘3차 티저 예고’ 공개! 디시트렌드 08.19
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2