• SEARCH

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

      • 오뉴노노
      • 1시간 전 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 공식문서 한국어 정리] 71. Rust Crossbeam 가이드오뉴노노
    • 2
      오뉴노노

    오뉴노노 님의 최근 글

    [Rust 공식문서 한국어 정리] 135. Rust Weak<T> 가이드 2026 06.08 [Rust 공식문서 한국어 정리] 118. Rust Tuple 타입 가이드 2026 06.08 [Rust 공식문서 한국어 정리] 117. Rust Type Alias 가이드 2026 06.08 [Rust 공식문서 한국어 정리] 116. Rust Existential Types 가이드 2026 06.08 [Rust 공식문서 한국어 정리] 115. Rust Generic Associated Types 가이드 2026 06.08

    오뉴노노 님의 최근 댓글

    ㅋㅋㅋㅋㅋ 2019 01.14 잘 읽었습니다 2018 12.30 포인트가 없어서 아직 시작을 못하고있는데요! 글은 잘 읽었습니다! 포인트 쌓고 도전할거에요 2018 12.30
    글쓴이의 서명작성글 감추기 
    댓글 쓰기 에디터 사용하기 닫기
    • view_headline 목록
    • 14px
    • [Rust 공식문서 한국어 정리] 71. Rust Crossbeam 가이드
    • 목록
      view_headline
    × CLOSE
    전체 던파 5 뮤 18 천상비 프로젝트신루 5 아이온 18 어둠의전설 28 리니지2 7 크로노스 5 칼온라인 3 기타 411
    기본 (503) 제목 날짜 수정 조회 댓글 추천 비추
    분류 정렬 검색
    • 포인트 획득 공지
      5
      2026.04.24 - 19:48 4853 5
    • 링크 업로드 관련 공지
      8
      2026.03.25 - 21:56 4660 8
    • 인증메일 공지
      3
      2026.03.15 - 16:42 4559 3
    • 파일링크 및 인증메일 발송 관련 문의 안내
      9
      2026.03.14 - 22:03 5163 9
    • 포인트 게시판 안내
      2026.02.28 - 19:14 5940
    • 게임존 사이트 변경 사항 안내
      9
      2026.02.26 - 01:07 7799 9
    • 소스자료는 직접 올려주세요
      2017.06.06 - 16:16 852
    503
    기타
    [Rust 공식문서 한국어 정리] 135. Rust Weak<T> 가이드
    N
    오뉴노노 18분 전
    502
    기타
    [Rust 공식문서 한국어 정리] 118. Rust Tuple 타입 가이드
    N
    오뉴노노 18분 전
    501
    기타
    [Rust 공식문서 한국어 정리] 117. Rust Type Alias 가이드
    N
    오뉴노노 19분 전
    500
    기타
    [Rust 공식문서 한국어 정리] 116. Rust Existential Types 가이드
    N
    오뉴노노 19분 전
    499
    기타
    [Rust 공식문서 한국어 정리] 115. Rust Generic Associated Types 가이드
    N
    오뉴노노 19분 전
    498
    기타
    [Rust 공식문서 한국어 정리] 114. Rust Impl Trait 반환 가이드
    N
    오뉴노노 19분 전
    497
    기타
    [Rust 공식문서 한국어 정리] 113. Rust Higher-Ranked Trait Bounds 가이드
    N
    오뉴노노 20분 전
    496
    기타
    [Rust 공식문서 한국어 정리] 112. Rust 라이프타임 서브타이핑 가이드
    N
    오뉴노노 20분 전
    495
    기타
    [Rust 공식문서 한국어 정리] 111. Rust 'static 라이프타임 가이드
    N
    오뉴노노 20분 전
    494
    기타
    [Rust 공식문서 한국어 정리] 110. Rust Sync 트레이트 가이드
    N
    오뉴노노 21분 전
    493
    기타
    [Rust 공식문서 한국어 정리] 109. Rust Send 트레이트 가이드
    N
    오뉴노노 21분 전
    492
    기타
    [Rust 공식문서 한국어 정리] 108. Rust Sized 트레이트 가이드
    N
    오뉴노노 22분 전
    491
    기타
    [Rust 공식문서 한국어 정리] 107. Rust Copy/Clone 트레이트 가이드
    N
    오뉴노노 22분 전
    490
    기타
    [Rust 공식문서 한국어 정리] 106. Rust Hash 트레이트 가이드
    N
    오뉴노노 22분 전
    489
    기타
    [Rust 공식문서 한국어 정리] 105. Rust PartialOrd/Ord 트레이트 가이드
    N
    오뉴노노 23분 전
    488
    기타
    [Rust 공식문서 한국어 정리] 104. Rust PartialEq/Eq 트레이트 가이드
    N
    오뉴노노 23분 전
    487
    기타
    [Rust 공식문서 한국어 정리] 103. Rust Debug 트레이트 가이드
    N
    오뉴노노 24분 전
    486
    기타
    [Rust 공식문서 한국어 정리] 102. Rust Display/Formatter 가이드
    N
    오뉴노노 24분 전
    485
    기타
    [Rust 공식문서 한국어 정리] 101. Rust Default 트레이트 가이드
    N
    오뉴노노 24분 전
    484
    기타
    [Rust 공식문서 한국어 정리] 100. Rust Deref/DerefMut 트레이트 가이드
    N
    오뉴노노 25분 전
    483
    기타
    [Rust 공식문서 한국어 정리] 99. Rust Drop 트레이트 가이드
    N
    오뉴노노 27분 전
    482
    기타
    [Rust 공식문서 한국어 정리] 98. Rust ToOwned 트레이트 가이드
    N
    오뉴노노 28분 전
    481
    기타
    [Rust 공식문서 한국어 정리] 97. Rust Borrow/BorrowMut 트레이트 가이드
    N
    오뉴노노 28분 전
    480
    기타
    [Rust 공식문서 한국어 정리] 96. Rust AsRef/AsMut 트레이트 가이드
    N
    오뉴노노 28분 전
    479
    기타
    [Rust 공식문서 한국어 정리] 95. Rust From/Into 트레이트 가이드
    N
    오뉴노노 28분 전
    478
    기타
    [Rust 공식문서 한국어 정리] 94. Rust IntoIterator 가이드
    N
    오뉴노노 29분 전
    477
    기타
    [Rust 공식문서 한국어 정리] 93. Rust Iterator 가이드
    N
    오뉴노노 29분 전
    476
    기타
    [Rust 공식문서 한국어 정리] 92. Rust Option<T> 가이드
    N
    오뉴노노 29분 전
    475
    기타
    [Rust 공식문서 한국어 정리] 91. Rust Result<T,E> 가이드
    N
    오뉴노노 30분 전
    474
    기타
    [Rust 공식문서 한국어 정리] 90. Rust panic! 매크로 가이드
    N
    오뉴노노 30분 전
    473
    기타
    [Rust 공식문서 한국어 정리] 89. Rust Release 빌드 최적화 가이드
    N
    오뉴노노 30분 전
    472
    기타
    [Rust 공식문서 한국어 정리] 88. Rust Profile 설정 가이드
    N
    오뉴노노 31분 전
    471
    기타
    [Rust 공식문서 한국어 정리] 87. Rust Cargo.lock 가이드
    N
    오뉴노노 31분 전
    470
    기타
    [Rust 공식문서 한국어 정리] 86. Rust Cargo.toml 가이드
    N
    오뉴노노 31분 전
    469
    기타
    [Rust 공식문서 한국어 정리] 85. Rust Cargo 가이드
    N
    오뉴노노 32분 전
    468
    기타
    [Rust 공식문서 한국어 정리] 84. Rust rustup 가이드
    N
    오뉴노노 1시간 전 1
    467
    기타
    [Rust 공식문서 한국어 정리] 83. Rust cargo-deny 가이드
    N
    오뉴노노 1시간 전
    466
    기타
    [Rust 공식문서 한국어 정리] 82. Rust cargo-audit 가이드
    N
    오뉴노노 1시간 전
    465
    기타
    [Rust 공식문서 한국어 정리] 81. Rust Miri 가이드
    N
    오뉴노노 1시간 전
    464
    기타
    [Rust 공식문서 한국어 정리] 80. Rust Criterion 가이드
    N
    오뉴노노 1시간 전
    463
    기타
    [Rust 공식문서 한국어 정리] 79. Rust OpenTelemetry 가이드
    N
    오뉴노노 1시간 전
    462
    기타
    [Rust 공식문서 한국어 정리] 78. Rust Tracing 가이드
    N
    오뉴노노 1시간 전
    461
    기타
    [Rust 공식문서 한국어 정리] 77. Rust Axum 가이드
    N
    오뉴노노 1시간 전
    460
    기타
    [Rust 공식문서 한국어 정리] 76. Rust Reqwest 가이드
    N
    오뉴노노 1시간 전
    459
    기타
    [Rust 공식문서 한국어 정리] 75. Rust Hyper 가이드
    N
    오뉴노노 1시간 전
    458
    기타
    [Rust 공식문서 한국어 정리] 74. Rust MIO 가이드
    N
    오뉴노노 1시간 전
    457
    기타
    [Rust 공식문서 한국어 정리] 73. Rust Tokio 가이드
    N
    오뉴노노 1시간 전
    456
    기타
    [Rust 공식문서 한국어 정리] 72. Rust Rayon 가이드
    N
    오뉴노노 1시간 전
    455
    기타
    [Rust 공식문서 한국어 정리] 71. Rust Crossbeam 가이드
    N
    오뉴노노 1시간 전
    454
    기타
    [Rust 공식문서 한국어 정리] 70. Rust thread_local 가이드
    N
    오뉴노노 1시간 전
    • 1 2 3 4 5 6 7 8 9 10 .. 11
    • / 11 GO
  • GAMEZONE
 GAMEZONE all rights reserved.
by OrangeDay