• SEARCH

    통합검색
  • GAMEZONE
    • 커뮤니티
      • 공지사항
      • 유저게시판
        • 등업게시판
        • 출석체크
        • 정회원 무료자료실
      • 스크린샷
      • 인증자료실
    • 리니지
      • 게임공략 & 팁
      • 홍보게시판
      • 유틸자료실
      • 소스자료실
      • 자유게시판
      • 노하우 게시판
    • 메이플스토리
      • 게임공략 & 팁
      • 홍보게시판
      • 유틸자료실
      • 소스자료실
      • 자유게시판
      • 노하우 게시판
    • 바람의나라
      • 자유게시판
      • 홍보게시판
      • 자료게시판
        • 유틸자료실
        • 소스자료실
        • 클라이언트
        • 팩 자료실
      • 연구게시판
        • 개발내역
        • 질문과답변
        • 기타
      • 강의게시판
        • DR
        • CR
        • 구버전
        • 클라이언트 개조
        • 노하우 게시판
        • 게임공략 & 팁
    • 다크에덴
      • 게임공략 & 팁
      • 홍보게시판
      • 유틸자료실
      • 소스자료실
      • 자유게시판
      • 노하우 게시판
    • 믹스마스터
      • 게임공략 & 팁
      • 홍보게시판
      • 유틸자료실
      • 소스자료실
      • 자유게시판
      • 노하우 게시판
    • 라그나로크
      • 게임공략 & 팁
      • 홍보게시판
      • 유틸자료실
      • 소스자료실
      • 자유게시판
      • 노하우 게시판
    • 기타게임
      • 게임공략 & 팁
      • 홍보게시판
      • 유틸자료실
      • 소스자료실
      • 자유게시판
      • 노하우 게시판
    • 게임강의
    • 비베&포토샵
      • 자유게시판
      • 자료실
        • 일반자료실
        • 포인트 자료실
      • 노하우게시판
      • 포토샵게시판
    • 모바일
      • 게임공략
      • 포인트 자료실
      • 유틸자료실
      • 자유게시판
  • 기타게임 소스자료실
    • 기타게임 소스자료실 기타 ()
    • [Rust 공식문서 한국어 정리] ㊼. Rust CLI 파싱 가이드 — Clap

      • 오뉴노노
      • 2026.06.08 - 12:14 0

    [Rust 공식문서 한국어 정리] ㊼. Rust CLI 파싱 가이드 — Clap



    원문 제목: clap — Command Line Argument Parser

    작성자: clap Contributors



    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    📌 1. 서론 — 이 문서가 다루는 내용

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━



    이 문서는 Rust의 대표적인 명령줄 인자 파싱 라이브러리인 clap의 사용법을 설명합니다.

    derive 매크로 기반 선언적 API와 빌더 패턴 기반의 명령적 API 두 가지 스타일을 다룹니다.

    서브커맨드, 인자 유효성 검증, 자동 생성 도움말, 셸 보완 기능까지 체계적으로 안내합니다.

    사용자 친화적인 CLI 도구를 빠르게 개발하면서도, 타입 안전성과 유지보수성을 확보하는 방법을 중심으로 설명합니다.

    CLI 도구를 개발하는 모든 Rust 개발자에게 가장 많이 사용되는 라이브러리입니다.



    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    🔑 2. 핵심 개념 4가지

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━



    ① Derive API: #[derive(Parser)]로 구조체를 CLI 인자로 매핑하여 보일러플레이트를 제거합니다.

    ② Builder API: Command::new()로 프로그래매틱하게 인자를 정의하고 파싱합니다.

    ③ Subcommands: #[derive(Subcommand)]로 git처럼 다중 서브커맨드를 구성합니다.

    ④ Validation: value_parser, arg_enum 등으로 인자 타입과 범위를 컴파일 타임에 검증합니다.



    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    📖 3. 주요 내용 상세

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━



    clap의 derive API는 복잡한 CLI도 간결하게 정의할 수 있게 합니다.

    #[derive(Parser)] struct Args { #[arg(short, long)] name: String, count: u8 } 형태로, 필드가 곧 CLI 인자가 됩니다.

    타입이 bool이면 플래그, String이면 옵션, Vec면 다중 값으로 자동 해석됩니다.



    빌더 API는 런타임에 동적으로 인자를 구성해야 할 때 유용합니다.

    Command::new("myapp").arg(arg!(-c --config "Config file"))처럼 체이닝으로 정의합니다.

    플러그인 시스템처럼 런타임에 명령어를 추가해야 하는 경우 derive 대신 builder를 사용합니다.



    서브커맨드는 대형 CLI 도구의 필수 구조입니다.

    #[derive(Subcommand)] enum Commands { Add { name: String }, Remove { name: String } } 형태로 정의합니다.

    서브커맨드별로 독립적인 인자 집합을 가지며, 각각의 핸들러 함수로 분리할 수 있습니다.



    자동 도움말과 에러 메시지는 clap의 큰 장점입니다.

    --help와 --version 플래그가 자동으로 생성되며, 잘못된 인자 입력 시 색상이 입혀진 에러 메시지를 출력합니다.

    cargo run -- --help로 미리 확인하고, 출력 형식을 Term styling으로 커스터마이징할 수 있습니다.



    셸 자동 완성은 clap_complete로 생성합니다.

    clap_complete::shells::Bash, Zsh, Fish, PowerShell 등의 생성기를 제공하여, 배포 시 셸 설정 파일을 함께 제공할 수 있습니다.

    사용자 경험을 크게 향상시키며, modern CLI의 기대 수준을 충족합니다.



    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    🛠 4. 실전 활용

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━



    CLI 도구의 메인 진입점에서 #[derive(Parser)] 구조체로 인자를 파싱하고 match로 서브커맨드를 분기합니다.

    env_logger와 clap_verbosity_flag를 조합하여 -v, -vv 등의 verbosity 플래그를 표준화합니다.

    clap_complete으로 셸 자동 완성 스크립트를 생성하여 설치 패키지에 포함합니다.



    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    ✅ 5. 정리

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━



    clap은 Rust CLI 개발의 사실상 표준으로, derive API로 빠르게 구현할 수 있습니다.

    자동 도움말, 타입 검증, 서브커맨드, 셸 완성까지 갖춘 종합 CLI 프레임워크입니다.

    복잡도에 따라 derive와 builder API를 적절히 선택하여 사용하세요.



    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    🔗 출처 링크

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━



    원문: https://docs.rs/clap/latest/clap/

    clap Book: https://docs.rs/clap/latest/clap/_derive/_tutorial/index.html



    #Rust #Clap #CLI #Parser #Subcommand #ShellCompletion #번역

    이 게시물을..
    N
    0
    0
    • [Rust 공식문서 한국어 정리] 150. Attribute Macros오뉴노노
    • 2
      오뉴노노

    오뉴노노 님의 최근 글

    [Rust 공식문서 한국어 정리] 184. PartialOrd 16 2026 06.08 [Rust 공식문서 한국어 정리] 183. Ord 13 2026 06.08 [Rust 공식문서 한국어 정리] 182. Eq 15 2026 06.08 [Rust 공식문서 한국어 정리] 181. PartialEq 15 2026 06.08 [Rust 공식문서 한국어 정리] 180. TryFrom 13 2026 06.08

    오뉴노노 님의 최근 댓글

    ㅋㅋㅋㅋㅋ 2019 01.14 잘 읽었습니다 2018 12.30 포인트가 없어서 아직 시작을 못하고있는데요! 글은 잘 읽었습니다! 포인트 쌓고 도전할거에요 2018 12.30
    글쓴이의 서명작성글 감추기 
    댓글 쓰기 에디터 사용하기 닫기
    • view_headline 목록
    • 14px
    • [Rust 공식문서 한국어 정리] 150. Attribute Macros
    • 목록
      view_headline
    × CLOSE
    전체 던파 5 뮤 18 천상비 프로젝트신루 5 아이온 18 어둠의전설 28 리니지2 7 크로노스 5 칼온라인 3 기타 490
    기본 (582) 제목 날짜 수정 조회 댓글 추천 비추
    분류 정렬 검색
    • 포인트 획득 공지
      5
      2026.04.24 - 19:48 4953 5
    • 링크 업로드 관련 공지
      8
      2026.03.25 - 21:56 4715 8
    • 인증메일 공지
      3
      2026.03.15 - 16:42 4606 3
    • 파일링크 및 인증메일 발송 관련 문의 안내
      9
      2026.03.14 - 22:03 5258 9
    • 포인트 게시판 안내
      2026.02.28 - 19:14 5997
    • 게임존 사이트 변경 사항 안내
      9
      2026.02.26 - 01:07 7855 9
    • 소스자료는 직접 올려주세요
      2017.06.06 - 16:16 853
    582
    기타
    [Rust 공식문서 한국어 정리] 184. PartialOrd
    오뉴노노 2026.06.08 - 15:42 16
    581
    기타
    [Rust 공식문서 한국어 정리] 183. Ord
    오뉴노노 2026.06.08 - 15:42 13
    580
    기타
    [Rust 공식문서 한국어 정리] 182. Eq
    오뉴노노 2026.06.08 - 15:42 15
    579
    기타
    [Rust 공식문서 한국어 정리] 181. PartialEq
    오뉴노노 2026.06.08 - 15:42 15
    578
    기타
    [Rust 공식문서 한국어 정리] 180. TryFrom
    오뉴노노 2026.06.08 - 15:42 13
    577
    기타
    [Rust 공식문서 한국어 정리] 179. TryInto
    오뉴노노 2026.06.08 - 15:42 11
    576
    기타
    [Rust 공식문서 한국어 정리] 178. From
    오뉴노노 2026.06.08 - 15:39 14
    575
    기타
    [Rust 공식문서 한국어 정리] 177. Into
    오뉴노노 2026.06.08 - 15:39 9
    574
    기타
    [Rust 공식문서 한국어 정리] 176. AsRef
    오뉴노노 2026.06.08 - 15:39 5
    573
    기타
    [Rust 공식문서 한국어 정리] 175. Deref
    오뉴노노 2026.06.08 - 15:39 4
    572
    기타
    [Rust 공식문서 한국어 정리] 174. Default
    오뉴노노 2026.06.08 - 15:39
    571
    기타
    [Rust 공식문서 한국어 정리] 173. Clone
    오뉴노노 2026.06.08 - 15:38
    570
    기타
    [Rust 공식문서 한국어 정리] 172. Copy
    오뉴노노 2026.06.08 - 15:38
    569
    기타
    [Rust 공식문서 한국어 정리] 171. Drop
    오뉴노노 2026.06.08 - 15:38
    568
    기타
    [Rust 공식문서 한국어 정리] 170. Weak
    오뉴노노 2026.06.08 - 15:37
    567
    기타
    [Rust 공식문서 한국어 정리] 169. Arc
    오뉴노노 2026.06.08 - 15:37
    566
    기타
    [Rust 공식문서 한국어 정리] 168. Rc
    오뉴노노 2026.06.08 - 15:37
    565
    기타
    [Rust 공식문서 한국어 정리] 167. Box
    오뉴노노 2026.06.08 - 15:36
    564
    기타
    [Rust 공식문서 한국어 정리] 166. str
    오뉴노노 2026.06.08 - 15:36
    563
    기타
    [Rust 공식문서 한국어 정리] 165. String
    오뉴노노 2026.06.08 - 15:36
    562
    기타
    [Rust 공식문서 한국어 정리] 164. HashMap
    오뉴노노 2026.06.08 - 15:36 1
    561
    기타
    [Rust 공식문서 한국어 정리] 163. Vec
    오뉴노노 2026.06.08 - 15:35
    560
    기타
    [Rust 공식문서 한국어 정리] 162. Result
    오뉴노노 2026.06.08 - 15:35
    559
    기타
    [Rust 공식문서 한국어 정리] 161. Option
    오뉴노노 2026.06.08 - 15:35
    558
    기타
    [Rust 공식문서 한국어 정리] 160. Iterators
    오뉴노노 2026.06.08 - 15:35
    557
    기타
    [Rust 공식문서 한국어 정리] 159. Closures
    오뉴노노 2026.06.08 - 15:35
    556
    기타
    [Rust 공식문서 한국어 정리] 158. Trait Objects
    오뉴노노 2026.06.08 - 15:34
    555
    기타
    [Rust 공식문서 한국어 정리] 157. Lifetimes
    오뉴노노 2026.06.08 - 15:34 1
    554
    기타
    [Rust 공식문서 한국어 정리] 156. Cargo.lock
    오뉴노노 2026.06.08 - 15:34
    553
    기타
    [Rust 공식문서 한국어 정리] 155. Cargo.toml
    오뉴노노 2026.06.08 - 15:34 1
    552
    기타
    [Rust 공식문서 한국어 정리] 154. Workspaces
    오뉴노노 2026.06.08 - 15:34
    551
    기타
    [Rust 공식문서 한국어 정리] 153. Crates
    오뉴노노 2026.06.08 - 15:33
    550
    기타
    [Rust 공식문서 한국어 정리] 152. Modules
    오뉴노노 2026.06.08 - 15:33
    549
    기타
    [Rust 공식문서 한국어 정리] 151. Proc Macros
    오뉴노노 2026.06.08 - 15:32 1
    548
    기타
    [Rust 공식문서 한국어 정리] 150. Attribute Macros
    오뉴노노 2026.06.08 - 15:32
    547
    기타
    [Rust 공식문서 한국어 정리] 149. cfg
    오뉴노노 2026.06.08 - 15:32
    546
    기타
    [Rust 공식문서 한국어 정리] 148. assert
    오뉴노노 2026.06.08 - 15:31
    545
    기타
    [Rust 공식문서 한국어 정리] 147. panic
    오뉴노노 2026.06.08 - 15:27
    544
    기타
    [Rust 공식문서 한국어 정리] 146. Error
    오뉴노노 2026.06.08 - 15:24
    543
    기타
    [Rust 공식문서 한국어 정리] 145. Any
    오뉴노노 2026.06.08 - 15:22
    542
    기타
    [Rust 공식문서 한국어 정리] 144. Unpin
    오뉴노노 2026.06.08 - 15:19
    541
    기타
    [Rust 공식문서 한국어 정리] 143. Pin
    오뉴노노 2026.06.08 - 15:17 2
    540
    기타
    [Rust 공식문서 한국어 정리] 142. LazyLock
    오뉴노노 2026.06.08 - 15:14 1
    539
    기타
    [Rust 공식문서 한국어 정리] 141. OnceCell
    오뉴노노 2026.06.08 - 15:11
    538
    기타
    [Rust 공식문서 한국어 정리] 140. Atomic
    오뉴노노 2026.06.08 - 15:06
    537
    기타
    [Rust 공식문서 한국어 정리] 139. RwLock
    오뉴노노 2026.06.08 - 14:34 3
    536
    기타
    [Rust 공식문서 한국어 정리] 152. Modules
    오뉴노노 2026.06.08 - 14:00
    535
    기타
    [Rust 공식문서 한국어 정리] 151. Proc Macros
    오뉴노노 2026.06.08 - 14:00
    534
    기타
    [Rust 공식문서 한국어 정리] 150. Attribute Macros
    오뉴노노 2026.06.08 - 14:00 3
    533
    기타
    [Rust 공식문서 한국어 정리] 149. cfg
    오뉴노노 2026.06.08 - 14:00 3
    • 1 2 3 4 5 6 7 8 9 10 .. 12
    • / 12 GO
  • GAMEZONE
 GAMEZONE all rights reserved.
by OrangeDay