Hatena::Groupcadr

わだばLisperになる このページをアンテナに追加 RSSフィード

2004 | 12 |
2005 | 01 | 02 | 07 | 10 | 11 |
2006 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2007 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2008 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2009 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2010 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2011 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 11 |

2009-11-21

KMRCLを眺める (18) with-each-stream-line

| 15:59 | KMRCLを眺める (18) with-each-stream-line - わだばLisperになる を含むブックマーク はてなブックマーク - KMRCLを眺める (18) with-each-stream-line - わだばLisperになる

今日は、KMRCLのmacros.lispの中からWITH-EACH-STREAM-LINEです。

定義は、

(defmacro with-each-stream-line ((var stream) &body body)
  (let ((eof (gensym))
        (eof-value (gensym))
        (strm (gensym)))
    `(let ((,strm ,stream)
           (,eof ',eof-value))
      (do ((,var (read-line ,strm nil ,eof) (read-line ,strm nil ,eof)))
          ((eql ,var ,eof))
        ,@body))))

というもので、ストリームをREAD-LINEする部分をまとめたもののようです。

確かに頻出するパターンなのでマクロにすると便利だなと思いました。

使われ方としては、

(WITH-INPUT-FROM-STRING (IN
                         "Linux setq 2.6.31-14-generic #48-Ubuntu SMP Fri Oct 16 14:05:01 UTC 2009 x86_64

To access official Ubuntu documentation, please visit:
http://help.ubuntu.com/")
    (WITH-OUTPUT-TO-STRING (OUT)
      (LET ((LINE-NUM 0))
        (WITH-EACH-STREAM-LINE (LINE IN)
          (FORMAT OUT "~4D: ~A~%" (INCF LINE-NUM) LINE)))))
;⇒
"   1: Linux setq 2.6.31-14-generic #48-Ubuntu SMP Fri Oct 16 14:05:01 UTC 2009 x86_64
   2: 
   3: To access official Ubuntu documentation, please visit:
   4: http://help.ubuntu.com/
"

みたいな感じでしょうか。

地味に良いマクロだと思いました。

ゲスト



トラックバック - http://cadr.g.hatena.ne.jp/g000001/20091121