• SEARCH

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

      • 오뉴노노
      • 1시간 전 1

    [Rust 공식문서 한국어 정리] ㉜. Rust 프로시저 매크로(Procedural Macros) 가이드

    원문 제목: Procedural Macros — The Rust Reference
    작성자: Rust Language Team

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

    이 문서는 Rust의 프로시저 매크로(Procedural Macro)를 작성하는 방법을 체계적으로 설명합니다.
    선언적 매크로(macro_rules!)를 넘어, 컴파일 타임에 Rust 코드를 생성하는 강력한 도구인 proc macro를 다룹니다.
    Derive, Attribute, Function-like 세 가지 종류의 프로시저 매크로와 그 작성 방법, 제약, 모범 사례를 설명합니다.
    TokenStream을 다루고, syn/quote 크레이트를 활용해 복잡한 AST 파싱을 단순화하는 기법도 포함합니다.
    메타프로그래밍과 도메인 특화 언어(DSL)에 관심 있는 Rust 개발자에게 고급 주제입니다.

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
    🔑 2. 핵심 개념 4가지
    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    ① Derive Macro: #[derive(TraitName)] 형태로 구조체/열거형에 자동으로 트레이트 구현을 생성합니다.
    ② Attribute Macro: #[attribute_name] 형태로 선언된 항목을 다른 코드로 변환합니다.
    ③ Function-like Macro: macro_name!(...) 형태로 호출되며, 임의의 토큰을 입력받아 코드를 생성합니다.
    ④ TokenStream: proc_macro의 기본 입출력 단위로, Rust 소스 코드를 토큰 단위로 표현합니다.

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
    📖 3. 주요 내용 상세
    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    프로시저 매크로는 proc-macro 타입의 크레이트로 작성됩니다.
    Cargo.toml에서 [lib] crate-type = ["proc-macro"]를 지정해야 하며, proc-macro 크레이트에 의존합니다.
    proc_macro::TokenStream을 입력으로 받고, 변환된 TokenStream을 반환하는 함수를 정의합니다.

    Derive 매크로는 #[proc_macro_derive(TraitName)]으로 선언합니다.
    입력으로는 구조첵나 열거형의 TokenStream이 들어오며, 출력으로는 impl 블록을 생성합니다.
    syn 크레이트는 TokenStream을 파싱해 DeriveInput 구조체로 변환하여, 필드와 제네릭 정보를 쉽게 접근할 수 있게 합니다.
    quote! 매크로는 템플릿 기반으로 TokenStream을 생성하여, 복잡한 코드 조립을 간결하게 만듭니다.

    Attribute 매크로는 #[proc_macro_attribute]로 선언합니다.
    두 개의 TokenStream을 받습니다: 하나는 속성 자신의 인자, 다른 하나는 속성이 붙은 항목입니다.
    이를 통해 함수나 모듈 전체를 래핑하거나, 계측(instrumentation), 라우팅 등의 메타데이터를 주입할 수 있습니다.

    Function-like 매크로는 #[proc_macro]로 선언합니다.
    macro_rules!와 유사하게 보이지만, 훨씬 유연하게 임의의 문법을 파싱할 수 있습니다.
    SQL 쿼리, 정규식, HTML 템플릿 등을 컴파일 타임에 검증하고 변환하는 DSL로 자주 사용됩니다.

    매크로 작성 시 주의할 점은 Hygiene(위생)과 Span 정보입니다.
    proc_macro는 기본적으로 위생을 보장하며, 생성된 변수가 호출자의 네임스페이스를 오염시키지 않습니다.
    Span은 생성된 코드의 오류 메시지 위치를 정확히 매핑하는 데 사용되며, 사용자 경험에 큰 영향을 줍니다.

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
    🛠 4. 실전 활용
    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    serde의 Serialize/Serialize, tokio의 #[main], actix-web의 #[get("/")] 등이 모두 프로시저 매크로입니다.
    자체 ORM이나 설정 파일 파서를 proc macro로 작성하여 컴파일 타임 검증을 강화합니다.
    syn/quote를 활용해 AST 파싱과 코드 생성의 보일러플레이트를 줄이고, Span을 정확히 전달해 디버깅을 용이하게 합니다.

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
    ✅ 5. 정리
    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    프로시저 매크로는 Rust 메타프로그래밍의 정점입니다.
    Derive, Attribute, Function-like 세 종류를 적재적소에 활용하면 반복적인 코드를 극적으로 줄일 수 있습니다.
    TokenStream과 syn/quote를 익히면 거의 모든 컴파일 타임 코드 생성이 가능해집니다.

    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
    🔗 출처 링크
    ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

    원문: https://doc.rust-lang.org/reference/procedural-macros.html
    The Little Book of Rust Macros: https://danielkeep.github.io/tlborm/book/index.html

    #Rust #ProcMacro #Macro #Derive #MetaProgramming #DSL #번역

    이 게시물을..
    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