码迷,mamicode.com
首页 > 其他好文 > 详细

scheme 中的宏使用

时间:2015-07-04 14:09:08      阅读:221      评论:0      收藏:0      [点我收藏+]

标签:

#lang scheme

( define-syntax my-when 
   ( syntax-rules ()
      [ ( _ pred body ... )
        ( if pred ( begin body ... ) ( void ) ) ] ) )

( my-when 
  ( = 2 1 )
  ( display 1 )
  ( display 2 ) )

( define-syntax my-let 
   ( syntax-rules () 
      [ ( my-let ( [ var exp ] ... )
                 body ... )
        ( ( lambda ( var ... )
             body ... ) exp ... ) ] ) )

( my-let 
  ( [ a 1 ]
    [ b 2 ] )
  ( display a )
  ( display b ) )

( define-syntax my-let* 
   ( syntax-rules ()
      [ ( my-let* ( [ var exp ] ) body ... )
        ( my-let ( [ var exp ] ) body ... ) ]
      [ ( my-let* ( [ var exp ] 
                    [ var1 exp1 ] ... ) body ... )
        ( my-let ( [ var exp ] )
                 ( my-let* ( [ var1 exp1 ] ... )
                           body ... ) ) ] ) )

( define-syntax my-for 
   ( syntax-rules ()
      [ ( my-for ( var from to ) body ... )
        ( let loop ( [ var from ] )
           ( my-when 
             ( < var to )
             body ... 
             ( loop ( + var 1 ) ) ) ) ] ) )

( my-for 
  ( i 0 10 )
  ( display "a" )
  ( display "b" ) )


;;; 一种比较有意思的用法

( define-syntax loop 
   ( syntax-rules ( begin end from to )
      [ ( loop <var> from <min> to <max> start body ... end )
        ( let loop1 ( [ <var> <min> ] )
           ( cond 
              [ ( < <var> <max> ) body ... ( loop1 ( + 1 <var> ) ) ]
              [ else ( void ) ] ) ) ] ) )

( loop i from 1 to 10
   begin 
       ( display 1 )
       ( newline )
       ( display 2 ) 
       ( newline )
   end )

版权声明:本文为博主原创文章,未经博主允许不得转载。

scheme 中的宏使用

标签:

原文地址:http://blog.csdn.net/pandora_madara/article/details/46754495

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!