디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 58 추천 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 - -
2881471 패배자처럼 살기 싫으면 뭘 어떻게 해야하는걸까... [1] ㅇㅇ(223.39) 08.14 40 0
2881470 애널의달성 2.1/1/3 ♥냥덩이♥갤로그로 이동합니다. 08.14 39 0
2881469 커뮤에서 비전 있는 종목과 돈버는 방법을 알려주면 ㅇㅇ갤로그로 이동합니다. 08.14 38 0
2881468 형들 이거 왜이래..? [2] 프갤러(211.192) 08.14 45 0
2881467 전한길 심리분석 발명도둑잡기갤로그로 이동합니다. 08.14 37 0
2881466 좇센에서 태어나서 러스트??ㅋㅋ그새끼가 비정상적인거아님??? 뒷통수한방(1.213) 08.14 24 0
2881464 러스트 까는 친구들 보면 좀 안타깝다. [1] 프갤러(218.154) 08.14 57 0
2881463 비전이 확실하지만 무보수인 기획, 개발자분들 의견이 궁금합니다 [15] 프갤러(1.242) 08.14 134 0
2881462 디시에서 조언은 99% 잘못된 조언이다. [2] ㅆㅇㅆ(124.216) 08.14 76 0
2881461 비전공 국비 자바 취업했다. [3] 프갤러(220.117) 08.14 126 0
2881460 나만 프갤에서 프로그래밍 어떻게할까요 묻는거 미련해보이냐 [3] ㅆㅇㅆ(124.216) 08.14 73 0
2881458 너네왜 개발자망했다함 [1] 프갤러(211.107) 08.14 81 1
2881457 인생을 살면서 창업 해야만한다는 뭔가 그런시기가 있지 않냐 [3] ㅆㅇㅆ(124.216) 08.14 49 0
2881454 ai가 4차산업혁명인데 어째 점점 하향곡선타는것같누 뒷통수한방(1.213) 08.14 35 0
2881453 나는 노가다 상하차부터 시작해서 이것저것 안 한일이 없는데 [3] ㅆㅇㅆ(124.216) 08.14 72 0
2881452 왜 3시 3분 넥도리아(223.38) 08.14 20 0
2881451 비전공 2년 경력... 면접보기 빡시네ㅜㅜ [1] 프갤러(211.234) 08.14 64 0
2881450 윤석열이랑 김건희 위치 넥도리아(223.38) 08.14 39 0
2881448 면접 보고 왔는데 면접이 걍 의식의 흐름이네 ㅇㅇ갤로그로 이동합니다. 08.14 38 0
2881447 한글 프로그래밍 언어 호랑 발명도둑잡기갤로그로 이동합니다. 08.14 37 0
2881445 쉬는청년, 청년빈곤 << 이거 진짜임 ㅇㅅㅇ?? [3] ㅇㅇ(223.39) 08.14 79 0
2881444 코파일럿씨가 챗티씨보다 낳은것같기도? [2] 헬마스터갤로그로 이동합니다. 08.14 43 0
2881441 ebs 다큐보는데 왜 기초수급자가 저축못하는걸 얘기하는거임?? [4] ㅇㅇ(223.39) 08.14 74 0
2881440 2024년 9급 국어3개영어4개 틀렸는데 ㅇㅇ(14.32) 08.14 32 0
2881439 골치아픈 문제네요. 프갤러(220.84) 08.14 33 0
2881438 오타쿠는 왜 개발을 잘할까 [3] ㅇㅇ(106.101) 08.14 75 0
2881437 개나 소나 다 하는 언어면 그렇게 대단할게 있을까? [2] 프갤러(218.154) 08.14 76 0
2881436 쇼핑몰 만들때 환불기능 꼭 넣어야됨? [1] ㅇㅇ(211.235) 08.14 52 0
2881435 러스트는 왜 저럼? [5] 프갤러(49.165) 08.14 56 1
2881434 개발자 취업 안되는거 ok [1] 프갤러(222.116) 08.14 106 0
2881433 한국노인들이 전세계에 이루어낸게 뭐있길래 남의나라욕하는거임?? 뒷통수한방(1.213) 08.14 29 0
2881432 노인들의 열등감 어떻하누 뒷통수한방(1.213) 08.14 21 0
2881431 부성애 모성애도 존재하는데 '효'라는 단어는 왜 안씀?? 뒷통수한방(1.213) 08.14 29 0
2881428 휴가쓰고 사천놀러옴 [2] 밀우갤로그로 이동합니다. 08.14 39 0
2881427 오늘 쉬는사람이 승자 [1] ㅇ.ㅇ(122.199) 08.14 50 0
2881426 다음 납품은 중학교 방과후 수업용 유니티 게임 납품. ㅆㅇㅆ(124.216) 08.14 32 0
2881425 R이 학부생~석사 초입 상대로 그래프 장사하니까 돈이 됨 ㅆㅇㅆ(124.216) 08.14 30 0
2881424 지금은 닥치는대로 다 하는데 범위를 좀 줄여야하는데 ㅆㅇㅆ(124.216) 08.14 27 0
2881423 게임,클라,웹,통계 안받는 분야가 없는데 ㅆㅇㅆ(124.216) 08.14 46 0
2881422 일어났다 또 작업 해야한다.. [2] ㅆㅇㅆ(124.216) 08.14 38 0
2881421 의외의 사실: [4] 아스카영원히사랑해갤로그로 이동합니다. 08.14 61 0
2881420 폭풍전야 개멍청한유라갤로그로 이동합니다. 08.14 20 0
2881419 [대한민국] 트럼프 정책 관련되어서- 프갤러(121.172) 08.14 15 0
2881414 여행지에 사전조사 / 볼거리들 다 알아보고 가야 잘 즐길 수 있음?? ㅇㅇ(223.39) 08.14 19 0
2881410 PwC 삼일회계법인 인턴 하는것에 대해 프갤러(117.111) 08.14 42 0
2881409 그 약이라는게 그렇게 끊기가 힘듬?? 계속 생각나?? [1] ㅇㅇ(223.39) 08.14 67 0
2881408 개발이 근데 그렇게 힘듬? [3] 프갤러(106.101) 08.14 97 0
2881407 시골 터미널 ㅇㅅㅇ [1] 헤르 미온느갤로그로 이동합니다. 08.14 52 0
2881406 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.14 27 0
2881405 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.14 43 0
뉴스 제이에스티나 X 아이유, 행복의 조각 ‘모자이크(Mosaique)’ 컬렉션 공개 디시트렌드 08.14
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2