디시인사이드 갤러리

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

갤러리 본문 영역

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

나르시갤로그로 이동합니다. 2025.08.11 00:28:05
조회 87 추천 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/01 - -
AD 가전디지털, 신학기 페스타! 운영자 25/08/29 - -
2884718 러스트는 근본적으로 설계가 잘못되었습니다 나르시갤로그로 이동합니다. 08.26 93 1
2884716 유데미 강의 추천해주싈? ㅇㅇ(121.137) 08.26 847 0
2884715 러스트는 만들다만 언어입니다 나르시갤로그로 이동합니다. 08.26 77 0
2884714 국힘 좆병신 같은 새끼 뽑혔네 [4] 아스카영원히사랑해갤로그로 이동합니다. 08.26 153 0
2884711 되다만 똥같은 것들이 남 긁는걸 가지고 스스로 우월하다고 정신승리함. 프갤러(218.154) 08.26 80 0
2884710 확실히 한국애들이 잘 긁히는경향이 있음 ㅇㅇ(58.229) 08.26 84 0
2884705 러스트를 볼때마다 종이 빨대가 생각남 ㅇ.ㅇ(59.151) 08.26 93 0
2884703 1인 개발보다 그냥 사람모아서 창업하는게 나을텐데 [7] 네오커헠(121.157) 08.26 237 0
2884692 업워크 며칠째 일을 못받네 ㅆㅇㅆ(124.216) 08.26 80 0
2884690 개고기 팔이는 그냥 저능한 일베충 빠돌이 상대로 있어보이는 척 프갤러(211.234) 08.26 79 0
2884684 인지과학조져라 손발이시립디다갤로그로 이동합니다. 08.26 94 0
2884670 영업중인가.? ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.26 59 0
2884668 태연 ㅇㅅㅇ 헤르 미온느갤로그로 이동합니다. 08.26 59 0
2884666 하루 한 번 헤르미온느 찬양 헤르 미온느갤로그로 이동합니다. 08.26 93 0
2884605 누가 더 유명함 홀란드 제나 오르테가 디바(59.28) 08.26 116 0
2884599 단독보도) 러스트 언어를 배우면 안되는 결정적 이유 나르시갤로그로 이동합니다. 08.26 87 0
2884597 러빨러들이 허구한 날 타 언어를 쓰레기라 나르시갤로그로 이동합니다. 08.26 88 0
2884594 러스트, 반짝이는 갑옷의 무게 나르시갤로그로 이동합니다. 08.26 76 0
2884589 러빨러가 c/c++, 자바, 파이선 등의 언어 까듯, 러스트 까줄게요 나르시갤로그로 이동합니다. 08.26 77 0
2884580 러스트는 절름발이 쓰레기 언어입니다 나르시갤로그로 이동합니다. 08.26 80 0
2884572 서양존예 동양존예 차이 ㅇㅇ(58.229) 08.26 84 0
2884565 바텐더 내가 모든걸 다 잊을수있게 [2] 개멍청한유라갤로그로 이동합니다. 08.26 108 0
2884564 사실 러스트는 자바보다 후달려요 ㅎㅎ3 나르시갤로그로 이동합니다. 08.26 78 0
2884560 사실 러스트는 자바보다도 후달려요 ㅎㅎ 2 나르시갤로그로 이동합니다. 08.26 86 0
2884559 자바충일 될빠에 파이썬충이 될거임 뒷통수한방(1.213) 08.26 76 0
2884555 좇센 연봉 억단위인 과기부장관부터가 자바충인데 뒷통수한방(1.213) 08.26 80 0
2884552 좇센은 자바공화국 자격증공화국임 뒷통수한방(1.213) 08.26 68 0
2884550 준석이는 코딩할때마다 뽀록나서 요즘은 그냥 AI 잘 다룬다는 티내나본데 ㅆㅇㅆ(124.216) 08.26 105 0
2884542 사실 러스트는 자바보다도 후달려요 ㅎㅎ 나르시갤로그로 이동합니다. 08.26 62 0
2884527 준석이는 나랏세금으로 나랏일할시간이 개발함??? 뒷통수한방(1.213) 08.26 79 0
2884526 준석이는 왜 컴공으로 개발자 않하고 정치질하냐?? [1] 뒷통수한방(1.213) 08.26 132 0
2884524 준석이가 만든 프로그램인데 어캐생각함???? [9] ㅇㅇ(211.241) 08.26 183 0
2884523 코스플레이어가되… 꼬치의달인갤로그로 이동합니다. 08.26 76 0
2884501 나 안경낀게나음 안낀게나음? [2] ㅇㅇ(222.108) 08.25 146 0
2884491 홈페이지 서버비용과 광고노출 수익 비교 프갤러(58.29) 08.25 76 0
2884490 러스트는 현대적인 틀딱 언어입니다. 나르시갤로그로 이동합니다. 08.25 84 0
2884462 nimf 출시가 2015년, 2016년인데 무슨 ㅎㅎ 나르시갤로그로 이동합니다. 08.25 71 0
2884458 꿈을 위해 달려가는 모든분들에게 ㅇㅇ(58.229) 08.25 74 0
2884457 뉴프로 재앙지원금 500포인트 지원안내 헬마스터갤로그로 이동합니다. 08.25 81 0
2884450 맨날 정치글 도배하시는 분께서 친히 언급해주시니 감격스럽네요. 프갤러(110.8) 08.25 78 0
2884447 요즘 코딩 존나 현타오지않냐 [1] 프갤러(175.193) 08.25 118 0
2884446 님프 목적은 아무래도 러스트로 분탕쳐서 인지도 쌓은 뒤 프갤러(110.8) 08.25 66 0
2884445 고 망한 이유가 구글임? [2] 프갤러(211.234) 08.25 88 0
2884444 님프 vs 러스트충 아직도 싸우고있노 [2] 헬마스터갤로그로 이동합니다. 08.25 88 0
2884443 "친구 만나는데 한 달에 35만원 나가네"…'우정 모임비' 압박에 美Z세 발명도둑잡기갤로그로 이동합니다. 08.25 84 0
2884442 에이다가 살짝 뜨니까 이슈몰이해서 랜섬웨어 만들려고 한듯 프갤러(27.177) 08.25 66 0
2884440 오늘 더워서 온라인에 싸우는 글이 많아졌다 발명도둑잡기갤로그로 이동합니다. 08.25 48 0
2884437 아하 그래서 님프 오픈소스에서 프리웨어로 돌렸나봅니다. 프갤러(223.63) 08.25 85 0
2884436 이야 잠깐 봤는데 님프는 정말 쓰레기가 맞습니다. [9] 프갤러(27.166) 08.25 112 0
2884434 항암치료제 리브리반트 국민청원 도와드리자. 목도Reason(119.195) 08.25 60 0
뉴스 윤민수 이혼 후, 이종혁과 헤어스타일 파격 변신...모친의 곱지 않은 시선 디시트렌드 09.02
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2