디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 35 추천 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 - -
2880412 애초에 마소는 이미 자기네들 홈페이지 완성 예시 다 올려뒀잖아 [3] ㅆㅇㅆ(124.216) 08.11 55 0
2880410 "소고기 사먹을 줄 알았더니"…소비쿠폰 풀리자 대박 난 '이곳' 발명도둑잡기갤로그로 이동합니다. 08.11 27 0
2880409 마소가 만들어논거보면 좋은 점이 [1] 루도그담당(118.235) 08.11 36 0
2880408 특이점 온다 노동해방시대 온다 ㅇㅇ 뒷통수한방(1.213) 08.11 15 0
2880407 Asp.net core 이거 존나 좋은데 [2] 루도그담당(118.235) 08.11 36 0
2880405 내가 프갤에 있는 이유)여기 조차도 안가면 이야기할 곳이 없다 [2] ㅆㅇㅆ(124.216) 08.11 42 0
2880403 적어도 프로그래밍 업종은 중국애들이 시민의식이 더 높음. [2] ㅆㅇㅆ(124.216) 08.11 40 0
2880402 유독 프로그래밍 업계라는 애들이 톡시하지 않냐? [2] ㅆㅇㅆ(124.216) 08.11 52 2
2880401 40대부터는 사업을 하고 싶다 프갤러(61.79) 08.11 28 0
2880400 번식한새끼들은 대우해주는거 아무리봐도 이해 좇나 안가네 뒷통수한방(1.213) 08.11 26 0
2880399 Asp.net core는 왜 안 쓰는거냐 루도그담당(118.235) 08.11 37 0
2880398 gpt5.0때문에 오늘 두시간 날렸네 프갤러(175.210) 08.11 34 0
2880397 댓글 이쁘게 발명도둑잡기갤로그로 이동합니다. 08.11 21 0
2880396 이기적인 놈 응용 좆되노 이기 [1] 슈퍼막코더(126.194) 08.11 54 0
2880395 2찢명 운지 스타또⭐+ ♥냥덩이♥갤로그로 이동합니다. 08.11 26 0
2880394 개발자 목메지마라 ♥냥덩이♥갤로그로 이동합니다. 08.11 29 0
2880393 아이 구해주는 코끼리 발명도둑잡기갤로그로 이동합니다. 08.11 16 0
2880392 챗지피티같은 이미지 생성기 만드는거 어려움? ㅇㅇ(106.102) 08.11 28 0
2880391 한국인이 시골에 친척끼리 같이 살던 문화라 남과 비슷해지려 발명도둑잡기갤로그로 이동합니다. 08.11 23 0
2880390 특이점 온다 노동해방시대 온다 ㅇㅇ 뒷통수한방(1.213) 08.11 19 0
2880389 이젠 챗봇에 질문하는걸 프롬프트 엔지니어링 ㅋㅋ [5] 헬마스터갤로그로 이동합니다. 08.11 47 0
2880388 개발자 목 매는게 별 거 있나 재밌으니까 하는거지 [1] ㅆㅇㅆ(124.216) 08.11 35 0
2880387 개발자 목매는이유가 뭐임? [2] 프갤러(221.143) 08.11 55 0
2880386 친자식이 아니랍니다 발명도둑잡기갤로그로 이동합니다. 08.11 18 0
2880385 흠.. 함 운덩하면 이틀은 봐야하는건강? ♥냥덩이♥갤로그로 이동합니다. 08.11 20 0
2880384 찢재앙 국가수지 개박살 ♥냥덩이♥갤로그로 이동합니다. 08.11 30 1
2880383 아스카느님 상하이 여행을 고려 중이시다 [14] 아스카영원히사랑해갤로그로 이동합니다. 08.11 56 0
2880382 체력이란 무엇인강? [2] ♥냥덩이♥갤로그로 이동합니다. 08.11 34 1
2880381 노동해방시대 오면 좋은점 ㅋ 뒷통수한방(1.213) 08.11 17 0
2880380 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 08.11 15 0
2880379 벌떡벌떡 ♥냥덩이♥갤로그로 이동합니다. 08.11 64 1
2880378 빌게이츠 AI 시대 노동해방 발명도둑잡기갤로그로 이동합니다. 08.11 19 0
2880377 애널 좀 축축하넹 ♥냥덩이♥갤로그로 이동합니다. 08.11 18 0
2880376 노동해방시대 오면 좋은점 ㅋ 뒷통수한방(1.213) 08.11 15 0
2880375 금융권 가고싶은데 어떤거 준비해야돼? [2] 프갤러(220.88) 08.11 60 0
2880374 냥덩이 제조법❤+ ♥냥덩이♥갤로그로 이동합니다. 08.11 22 0
2880373 논란중인 일본 숏폼 드라마 발명도둑잡기갤로그로 이동합니다. 08.11 24 0
2880372 출산드라 발명도둑잡기갤로그로 이동합니다. 08.11 19 0
2880371 몸에 힘이.. 빠진다냥.. ♥냥덩이♥갤로그로 이동합니다. 08.11 24 0
2880370 일이 없다. 최근 nest.js쪽은 실력부족으로 그만뒀고 [4] ㅆㅇㅆ찡갤로그로 이동합니다. 08.11 66 0
2880369 훨씬 일찍 알아차려야 했습니다. 프갤러(220.84) 08.11 37 0
2880368 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ ♥냥덩이♥갤로그로 이동합니다. 08.11 24 0
2880367 혹시 악성코드 분석하는사람 있음? [10] ㅇㅇ(112.186) 08.11 89 0
2880366 말씀이란표현 재밋지않냐? [7] 헬마스터갤로그로 이동합니다. 08.11 68 0
2880365 아직 여름이로당 ♥냥덩이♥갤로그로 이동합니다. 08.11 23 0
2880364 대기업들 미국으로 전부 이전하든 니들이 앰생인건 똑같잖아 ㅋㅋㅋ 뒷통수한방(1.213) 08.11 24 0
2880363 비전공 국비 후기 [4] BABIBU갤로그로 이동합니다. 08.11 101 0
2880361 ❤✨☀⭐⚡☘⛩나님 시작합니당⛩☘⚡⭐☀✨❤ [1] ♥냥덩이♥갤로그로 이동합니다. 08.11 29 0
2880360 주한미군 철수보다 타국 군대 철수가 더 낫다 발명도둑잡기갤로그로 이동합니다. 08.11 24 0
2880358 안녕하세요? 안녕하세요?(116.124) 08.11 25 0
뉴스 '크레이지 코리안' 장한나, 세계 1위 오케스트라와 암스테르담 찢었다! 기립박수에 '전율' 디시트렌드 08.11
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2