<?xml version="1.0" encoding="UTF-8" ?><rdf:RDF 
  xmlns="http://purl.org/rss/1.0/"
  xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" 
  xmlns:dc="http://purl.org/dc/elements/1.1/"
  xml:lang="ja">
  <channel rdf:about="http://www20.atwiki.jp/air-lang/">
    <title>AIR-Lang@Wiki</title>
    <link>http://www20.atwiki.jp/air-lang/</link>
    <description>AIR-Lang@Wiki</description>

    <dc:language>ja</dc:language>
    <dc:date>2010-03-08T21:24:57+09:00</dc:date>

    <items>
      <rdf:Seq>
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/13.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/56.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/35.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/34.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/37.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/31.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/29.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/38.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/30.html" />
                <rdf:li rdf:resource="http://www20.atwiki.jp/air-lang/pages/54.html" />
              </rdf:Seq>
    </items>
	
		
    
  </channel>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/13.html">
    <title>スクリプト言語ＡＩＲマニュアル ( Script Language AIR Manual )</title>
    <link>http://www20.atwiki.jp/air-lang/pages/13.html</link>
    <description>
      + [[プロジェクトの紹介 ( Project HomePage )&gt;http://www.air-lang.org/]]
+ サンプルプログラム ( Sample Programs  )
++ [[最初のプログラム - Hello World!]]
++ [[変数値の簡易表示]]
++ [[基本データと配列＆変数]]
++ [[コマンドライン引数]]
++ [[条件分岐と繰り返し]]
++ [[ファイル入出力 - テキスト]]
++ [[ファイル入出力 - バイナリ]]
++ [[ユーザー関数の定義]]
++ [[日付と時刻]]
++ [[シグナル(割り込み)]]
+ [[言語ハッキング方法 ( Hack AIR-Engine! )]]
+ [[ソースコード一式ダウンロード ( Download from SourceFourge.Jp )&gt;http://sourceforge.jp/projects/air-lang/]]

&amp;br()

** インストール方法 ( How to Install )
 # tar zxvf air-1.8x.tgz ; cd air-1.8
 # make
 # cp air /usr/local/bin

** アンインストール方法 ( How to UnInstall )
 # rm -r air-1.8
 # rm /usr/local/bin/air

&amp;br()

** プログラムの実行方法 ( How to Execute )

ＡＩＲプログラムの実行に必要なものは、ＡＩＲインタプリタ本体 /usr/local/bin/air のみです。コマンド PATH が通っていることを確認してから、以下のいずれかの方法でＡＩＲプログラムを実行して下さい。

** (１)通常モードで実行する方法:

&gt; 通常は、(先頭のシェバング行でＡＩＲインタプリタを指定して、実行可能属性を持った)テキストファイルにＡＩＲプログラム本文を保存し、そのファイル名を直接指定して実行します。(次のサンプルは、この方法で実行しています。)

  % cat vvv                             # ファイルの内容を確認します。
  #!/usr/local/bin/air
  print(&quot;Hello World!\n&quot;)
  % chmod 0755 vvv                      # 実行可能属性を持たせます。
  % vvv                                 # ファイル名を直接指定して実行します。
  Hello World!
  %

** (２)対話モードで実行する方法:

&gt; オプション -i を付けてＡＩＲインタプリタを起動すると対話モードとなります。キーボードより入力されたＡＩＲプログラムは、１文づつ逐次実行されます。又、このモードでは GNU Read Line 行編集機能が有効となります。( &quot;AIR&gt;&quot; は対話モード時のプロンプトです。)
  % air -i
  AIR&gt; print(&quot;Hello World!\n&quot;)
  Hello World!
  AIR&gt; ^D
  %

** (３)ワンライナーモードで実行する方法:

&gt; オプション -e を付けてＡＩＲインタプリタを起動すると、次の引数をＡＩＲプログラム本文と見なして実行します。プログラム本文に含まれる各種記号をシェルに解釈されないために、プログラム全体を &#039; &#039; (一重引用符)で囲むことをお薦めします。
  % air -e &#039;print(&quot;Hello World!\n&quot;)&#039;
  Hello World!
  %

&amp;br()
&amp;br()
&amp;br()    </description>
    <dc:date>2010-03-08T21:24:57+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/56.html">
    <title>条件分岐と繰り返し</title>
    <link>http://www20.atwiki.jp/air-lang/pages/56.html</link>
    <description>
      ** 条件分岐

- if文の例です。この例では、中括弧 { } は省略可能です。また、elif は else if としても同じです。
  # 電源ラインの周波数を調べます。
  if( addr==&quot;東京&quot; )
      freq=&quot;50[Hz]&quot;
  elif( addr==&quot;大阪&quot; )
      freq=&quot;60[Hz]&quot;
  else
      freq=&quot;??[Hz]&quot;

- switch文の例です。swch と deft は省略形のキーワードです。(switchとdefault)
条件は複数指定できます。また、アスタリスク * は全てにマッチします。
  # 上場企業を分類します。
  swch( market,grade ){
      case &quot;東証&quot;,&quot;1部&quot;: print(&quot;東証一部上場企業です。&quot;); break;
      case &quot;東証&quot;,&quot;2部&quot;: print(&quot;東証二部上場企業です。&quot;); break;
      case &quot;東証&quot;,  *  :
      case &quot;大証&quot;,  *  :
      case &quot;名証&quot;,  *  :
      case &quot;福証&quot;,  *  :
      case &quot;札証&quot;,  *  : print(&quot;  上場企業です。&quot;); break;
      deft:              print(&quot;非上場企業です。&quot;); break;
  }

- 3項演算子の例です。
  # 改行コード又は区切り記号を出力します。
  puts( last?&quot;\n&quot;:&quot;,&quot; )

** 繰り返し

- loop文の例です。最初に数(整数)を評価して、その数(整数)だけループ本体を実行します。
無指定時には、無限ループとなります。
  # アスタリスクを80個出力します。
  loop(80)
     putc(&#039;*&#039;)

- while文の例です。ループ毎に条件式を前評価して、TRUE等である限り繰り返しループを実行します。
  # 標準入力を行毎に行末まで読み込みます。
  while( line=gets() ){
      ;
  }

- while文のバリエーションとして、ループ毎に条件式を後評価するdo_while文、及び、
これらとは真偽が逆のuntil文とdo_until文があります。(サンプル省略)

- for文の例です。(0〜9までの整数を加算します。)
  sum=0
  for( i=0 ; i&lt;10 ; i++ )
      sum+=i

- each文の例です。配列要素(と配列添字)を順次設定してループを実行します。
  # コマンドライン引数を全て表示します。
  each( val=ARGV )
      print(&quot;%s\n&quot;,val)

  # 環境変数を全て表示します。(表示イメージ → &quot;PATH=/bin:/usr/bin&quot;)
  each( val,key=ENV )
      print(&quot;%s=%s\n&quot;,key,val)


&amp;br()
&amp;br()
&amp;br()    </description>
    <dc:date>2010-02-26T01:20:47+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/35.html">
    <title>ファイル入出力 - バイナリ</title>
    <link>http://www20.atwiki.jp/air-lang/pages/35.html</link>
    <description>
      ** バイナリファイル入出力 ( Binary File Input&amp;Output )

+ バイナリデータのファイル入出力は、関数 read()/write() を使用すると便利です。
+ 関数 buf,cnt=read(fname,byte) は、指定されたファイル fname より byte バイト分だけデータを読み込み、左辺の第１変数 buf に設定します。また、左辺の第２変数 cnt には、読み込んだバイト数がセットされます。
+ 変数 buf の内容へのアクセスは、(バイナリデータである可能性があるため)関数 peek()/poke() を使用します。(通常の文字列関数は、&#039;\0&#039;文字を文字列末と認識します。)

** 簡易 dump プログラ ( Simple dump program )
&gt; コマンドライン引数で指定されたファイル名(省略時は標準入力)の内容を、標準出力へダンプ表示します。

  fname=shift(stdin)                     # 引数をセットします。（デフォルトは stdin ）
  
  do_while(cnt!=0){                      # {} 内を実行して、cntが 0 でない限りループを繰り返します。
      buf,cnt=read(fname,16)             # ファイル fname から１６バイト読み込み、データとバイト数をセットします。
      for(i=0;i&lt;cnt;i++)                 # １バイトづつ１６進数表示を行います。
          printf(&quot;%02X &quot;,peek(buf,i))   # 関数 peek() は、バイナリデータ buf 内の i 番目のデータを取り出します。
      print(&quot;\n&quot;)
  }    </description>
    <dc:date>2010-02-25T00:58:25+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/34.html">
    <title>ファイル入出力 - テキスト</title>
    <link>http://www20.atwiki.jp/air-lang/pages/34.html</link>
    <description>
      ** 簡易 cat プログラム ( Simple cat program )

&gt; 指定されたファイルの内容を標準出力に１行ずつ表示します。
  fname=shift(STDIN)                       # コマンドライン引数よりファイル名、又は、STDIN をセットします。
  while( str=gets(fname) ){                # ファイルから１行ずつデータを読み込み、変数 str にセットします。
      puts(str)                            # 変数 str の内容を標準出力へ出力します。
  }

** 簡易 cp プログラム ( Simple cp program )

&gt; 指定されたファイルの内容を別のファイルに１行ずつコピーします。
  if( ARGS!=2 ) exit(1)                    # コマンドライン引数でファイル名が２個指定されていることを確認します。
  fi=shift()                               # 送り元ファイル名をセットします。
  fo=shift()                               # 送り先ファイル名をセットします。
  while( str=gets(fi) ){                   # ファイル fi から１行ずつデータを読み込み、変数 str にセットします。
      fputs(fo,str)                        # 変数 str の内容をファイル fo へ出力します。
  }

** 簡易２分岐プログラム ( Simple 2 way branch program )

&gt; 標準入力から読み込んだ内容を、標準出力と標準エラー出力に出力します。
  while( str=gets() ){                     # 標準入力から１行ずつデータを読み込み、変数 str にセットします。
      fputs(STDOUT,str)                    # 変数 str の内容を標準出力へ出力します。
      fputs(STDERR,str)                    # 変数 str の内容を標準エラー出力へ出力します。
  }

** 簡易 ls プログラム ( Simple ls program )

&gt; カレントディレクトリのファイル一覧を取得出力します。
  each( f=glob(&quot;*&quot;) ){                     # ワイルドカード文字 * を展開後配列化し、１要素ずつ変数 f へ代入します。
      print(&quot;%s\n&quot;,f)                      # 各個別要素(ファイル名)を表示します。
  }

&amp;br()
&amp;br()
&amp;br()     </description>
    <dc:date>2010-02-25T00:58:04+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/37.html">
    <title>日付と時刻</title>
    <link>http://www20.atwiki.jp/air-lang/pages/37.html</link>
    <description>
      ** 現在時刻(UNIX時刻)を取得し、UTCとローカルタイムで表示します。

&gt; 世界時とローカル時の時差は、実行環境 OS より正しく取得します。

  t=time()                              # 現在のUNIX時刻を取得します。
  
  utc=abs2utc(t)                        # UNIX時刻→ＵＴＣ配列化
  jst=abs2ltz(t)                        # UNIX時刻→ＬＴＺ配列化 ( Local Time Zone  )
    
  print(&quot;UTC = %02d:%02d:%02d\n&quot;,utc[&quot;hour&quot;],utc[&quot;min&quot;],utc[&quot;sec&quot;])
  print(&quot;JST = %02d:%02d:%02d\n&quot;,jst[&quot;hour&quot;],jst[&quot;min&quot;],jst[&quot;sec&quot;])

&amp;br()

** 2038年問題の発生日時を表示します。

&gt; 2038年問題とは、UNIX時刻を３２ビット整数値で表現した場合に、2038年中にオーバーフローしてしまう問題をいいます。(日付や時刻の処理が誤動作する。)

  t=INT_MAX                              # UNIX時刻として整数の最大値をセットします。
  
  utc=abs2utc(t)                         # UNIX時刻→ＵＴＣ配列化
  print(&quot;%s %s [UTC]\n&quot;,sdate(utc),stime(utc))    </description>
    <dc:date>2010-02-25T00:57:08+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/31.html">
    <title>シグナル(割り込み)</title>
    <link>http://www20.atwiki.jp/air-lang/pages/31.html</link>
    <description>
      ** シグナル処理プログラムの記述方法(全体の流れ)
+ 処理対象とするシグナル番号を選びます。
+ シグナル受信時の処理内容を、ユーザ定義関数として記述します。
-- ユーザ定義関数内では、第１引数がシグナル番号となります。
-- ユーザ定義関数内での、使用できる関数に制約はありません。
+ 定義したユーザ関数をシグナルハンドラとして設定します。

&amp;br()

** シグナルモニタの例

&gt; 受信したシグナル番号を表示する例です。このため、処理対象とするシグナル番号は、ユーザー側にてキャッチ可能な全てシグナル番号とします。なお、このプログラムは CTRL+C でも終了しなくなるため、CTRL+C 受信時には KILL -9 による終了方法を表示することとしました。
&gt; なお、ここではシグナル待ち受け時間中は pause() 関数で待つこととしましたが、他の処理を実行させていても問題はありません。

  # シグナルハンドラとなるユーザ定義関数を２つ定義します。
  
  # その１:CTRL+C 受信時のシグナルハンドラです。
  def disp_signumber2(ival){
      print(&quot;Signal Received!! [%d]\n&quot;,ival)
      print(&quot;終了の仕方：当プロセス（%d）に、シグナル９番を送信して下さい。\n&quot;,PID);
      print(&quot;( kill -9 %d )\n&quot;,PID);
  }
  
  # その２:他のシグナル受信時のシグナルハンドラです。
  def disp_signumber (ival){
      print(&quot;Signal Received!! [%d]\n&quot;,ival)
  }

  # シグナルハンドラを設定します。
  for(i=1;i&lt;NSIG;i++){                    # i = シグナル番号です。(全てのシグナル番号を処理対象とします。)
      if(i==2)                            # CTRL+C 受信時のシグナルハンドラを設定します。
          rx_signal(i,&amp;disp_signumber2())
      else                                # 他のシグナル受信時のシグナルハンドラを設定します。
          rx_signal(i,&amp;disp_signumber ())
  }
  
  # シグナル待ち受けループに入ります。
  while(TRUE){                            # 繰り返しモニタ出来るように、無限ループとします。
      pause()                             # シグナル待ち受け時はポーズで待ちます。
  }

&amp;br()
&amp;br()
&amp;br()    </description>
    <dc:date>2010-02-25T00:56:52+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/29.html">
    <title>コマンドライン引数</title>
    <link>http://www20.atwiki.jp/air-lang/pages/29.html</link>
    <description>
      ** 整数 ARGC と 整数 ARGS

&gt; &#039;&#039;ARGC&#039;&#039; には、コマンド名自身を含むコマンドライン引数の数(整数値)がセットされます。&#039;&#039;ARGS&#039;&#039; には、[[shift()]]可能なコマンドライン引数の数(整数値)がセットされます。(初期値は &#039;&#039;ARGC-1&#039;&#039; ですが、 [[shift()]]ファミリ関数実行時に値が調整されます。)

- ARGC と ARGS を表示します。
  print(&quot;ARGC=%d,ARGS=%d\n&quot;,ARGC,ARGS)
  str=shift()                              # コマンドライン引数を取得します。
  print(&quot;ARGC=%d,ARGS=%d\n&quot;,ARGC,ARGS)

** 配列 ARGV[]

&gt; &#039;&#039;ARGV[]&#039;&#039; には、コマンド名自身を含むコマンドライン引数(文字列)がセットされます。

- ARGV[] の全要素を表示します。
  for(i=0;i&lt;ARGC;i++){                     # 0 から ARGC-1 までループします。
      print(&quot;値=%s\n&quot;,ARGV[i])             # ARGV[i] は文字列です。
  }

** 関数 shift()

&gt; 関数 &#039;&#039;shift()&#039;&#039; は、呼び出される度に次のコマンドライン引数(文字列)を順番に戻します。戻すべきコマンドライン引数が無い場合は、引数で指定されたデフォルト値、又は、&#039;&#039;NULL&#039;&#039; が戻されます。

- コマンドライン引数より２つのパラメータを取得します。
  if( ARGC!=3 ){                           # 引数の数を確認します。
      eprint(&quot;Usage: ${CMD} p1 p2\n&quot;)      # 使用方法を表示します。${CMD}はコマンド名に置換されます。
      exit(0)
  }
  p1=shift()                               # 第１コマンドライン引数を変数 p1 へセットします。(文字列)
  p2=shift()                               # 第２コマンドライン引数を変数 p2 へセットします。(文字列)

- コマンドライン引数より１つのパラメータ(ファイル名)を取得します。ただし、何も指定されなかった場合は、標準入力 STDIN をセットするものとします。
  if( ARGC!=1 &amp;&amp; ARGC!=2 ){                # 引数の数を確認します。
      eprint(&quot;Usage: ${CMD} [file]\n&quot;)     # 使用方法を表示します。${CMD}はコマンド名に置換されます。
      exit(0)
  }
  file=shift(STDIN)                        # コマンドライン引数(又は、STDIN)を変数 file へセットします。

&amp;br()
&amp;br()
&amp;br()    </description>
    <dc:date>2010-02-25T00:56:18+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/38.html">
    <title>基本データと配列＆変数</title>
    <link>http://www20.atwiki.jp/air-lang/pages/38.html</link>
    <description>
      &amp;br()

* 基本データの種類
- 論理値・文字列・整数値・実数値・ポインタの５種類があります。
- 全ての基本データは、&#039;&#039;値&#039;&#039;情報と&#039;&#039;型&#039;&#039;情報を同時に保有しています。

&amp;br()

** 論理値 ( Logical )
&gt; &#039;&#039;TRUE&#039;&#039; と &#039;&#039;FALSE&#039;&#039; があります。

  log1 = TRUE                              # 真です。
  log2 = FALSE                             # 偽です。
  
  log3 = (3&lt;M_PI &amp;&amp; M_PI&lt;4)                # 円周率 M_PI=3.14... ですので、log3 の値は TRUE となります。

** 文字列 ( String )
&gt; 文字列は本体部分を２重引用符 又は ２重大括弧で囲んで指定します。後者の場合は、複数行に渡る文字列を(各行行末をエスケープすることなく)そのまま記述できます。どちらの場合も、エスケープ文字はC言語のものと互換性があります。

  str1 = &quot;AIR-Lang\n&quot;
  str2 = [[
      AIR-Lang
  ]]
  
  re = &quot;/[ABC]+/&quot;                          # 正規表現は、&quot;/POSIX規格/&quot; で指定します。

** 整数値と実数値 ( Integer and Double )
&gt; 整数値の内部表現はC言語の int を利用しています。実数値の内部表現はC言語の double を利用しています。(必要な場合は、自動型変換が行われます。)

  a = +100 , b = -333 , c = INT_MAX        # 整数の指定例です。  
  i = 0b11 , j = 0o77 , k = 0xFF           # ２進数、８進数、１６進数の指定例です。
  c = &#039;\n&#039;                                 # C言語と同じエスケープ文字が使えます。
  
  x = -1.0E+99 , y = +1E-7 , z = 0.0       # 実数の指定例です。

  ans = int(&quot;3&quot;) + int(2) + int(NULL)      # 関数 int() で値の整数化ができます。( ans=5   )
  ans = dbl(&quot;3&quot;) + dbl(2) + dbl(NULL)      # 関数 dbl() で値の実数化ができます。( ans=5.0 )

** ポインタ ( Pointer )
&gt; 関数のエラー戻り値や、[[ファイルポインタ]]などで使われます。

  x = NULL                                 # &#039;&#039;NULL&#039;&#039; ポインタです。
  
  p1 = STDIN                               # 標準入力です。( stdin  は別名です。)
  p2 = STDOUT                              # 標準出力です。( stdout は別名です。)
  p3 = STDERR                              # 標準エラー出力です。( stderr は別名です。)

&amp;br()

* 配列について
- １つ以上の基本データ又は配列を、添字を用いてまとめて保持したものです。
- 配列と連想配列(ハッシュ)は、統一的に扱えます。互いに混在が可能です。異次元であっても同様です。

&amp;br()

Example: 配列 a と配列 b は、同じ値の要素を持ちます。
  a[0]=00, a[1]=11, a[2]=22, a[5]=55       # 配列は添字と値を指定して初期化します。
  b={00,11,22,,,55}                        # 初期値を一括指定することも可能です。
  p(a,b)                                   # ２つの配列の内容を出力します。

Example: 配列 c と配列 d は、同じ値の要素を持ちます。
  c[&quot;US&quot;]=0, c[&quot;EU&quot;]=1, c[&quot;JP&quot;]=2         # 配列と連想配列は統一的に扱えます。
  d={&quot;US&quot;-&gt;0,&quot;EU&quot;-&gt;1,&quot;JP&quot;-&gt;2}             # (連想配列的な)初期値を一括指定することも可能です。
  p(c,d)                                  # ２つの配列の内容を出力します。

Example: 配列 e は異次元要素が混在しています。
  e[0]=00,e[1]=11,e[&quot;TEST&quot;]=&quot;???&quot;         # 配列と連想配列は互いに混在が可能です。
  e[1,2,3,&quot;TEST&quot;]=&quot;OK&quot;                    # 次元数が異なっていても混在が可能です。
  p(e)                                    # 配列全体の内容を出力します。

&amp;br()

* 変数について
- 変数は、１つの基本データの&#039;&#039;型&#039;&#039;と&#039;&#039;値&#039;&#039;を同時に保持します。又は、１つの配列データを保持します。
- 変数の定義は、単に変数を初期化することで行います。(デフォルトはLocal変数となります。)

&amp;br()

Example: １〜１００までの数の和を計算します。
  sum=0                                    # 変数 sum を初期値 0 で初期化(=定義)します。(Local変数)
  for(i=1;i&lt;=100;i++)                      # 変数 i もLocal変数です。
    sum+=i
  print(&quot;Answer=%d\n&quot;,sum)

&amp;br()

Example: 明示的な変数定義の例です。スコープを指定します。(Static変数はユーザー定義関数内のみ有効です。)
  global gx=0,gy,gz                       # Global変数 gx,gy,gz を定義します。
  static sx=1,sy,sz                       # Static変数 sx,sy,sz を定義します。
  local  lx=2,ly,lz                       # Local 変数 lx,ly,lz を(明示的に)定義します。

&amp;br()
&amp;br()
&amp;br()      </description>
    <dc:date>2010-02-25T00:55:23+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/30.html">
    <title>最初のプログラム - Hello World!</title>
    <link>http://www20.atwiki.jp/air-lang/pages/30.html</link>
    <description>
      ** その１
  print(&quot;Hello World!\n&quot;)               # &#039;#&#039;文字〜行末まではコメントとなります。

** その２
  str=&quot;Hello &quot;+&quot;World!&quot;+&quot;\n&quot;            # 文字列を連結して、変数 str に代入します。
  puts(str)                             # その内容を標準出力へ出力します。

** その３
  str=sprint(&quot;%s\n&quot;,&quot;Hello World!&quot;)     # 文字列を書式指定で生成して、変数 str に代入します。
  puts(str)                             # その内容を標準出力へ出力します。

** 追加
  while( str=gets(DATA) ){              # __DATA__ 以降を1行ずつ読み込み、変数 str に代入します。
      puts(str)                         # その内容を標準出力へ出力します。
  }
  __DATA__
  Hello World!

&amp;br()
----
&amp;br()

** ★print() ファミリー関数について

&gt; 関数 print(),eprint(),sprint(),fprint() は、Ｃ言語 printf() 書式と互換性のある出力関数です。

|COLOR(white):BGCOLOR(blue): 関数 |COLOR(white):BGCOLOR(green): (別名) |COLOR(white):BGCOLOR(red): 機能説明 |h
|  print(format, ... )      |  printf(format, ... )      | 与えられた引数を書式変換して、標準出力(stdout)に出力します。                      |
| eprint(format, ... )      | eprintf(format, ... )      | 与えられた引数を書式変換して、標準エラー出力(stderr)に出力します。                      |
| sprint(format, ... )      | sprintf(format, ... )      | 与えられた引数を書式変換して、文字列(関数の戻り値)として出力します。                    |
| fprint(file,format, ... ) | fprintf(file,format, ... ) | 与えられた引数を書式変換して、指定ファイル([[ファイルポインタ]]でも可)に出力します。 |

&amp;br()

** ★puts() ファミリー関数について

&gt; 関数 putc(),puts(),putn() は、文字と文字列の出力関数です。

|COLOR(white):BGCOLOR(blue): 関数 |COLOR(white):BGCOLOR(green): (別名) |COLOR(white):BGCOLOR(red): 機能説明 |h
|  putc(char ) |-| 標準出力(stdout)に１文字を出力します。                          |
|  puts(str  ) |-| 標準出力(stdout)に文字列を出力します。                          |
|  putn(str,n) |-| 標準出力(stdout)に文字列(ただし、最大 n 文字まで)を出力します。 |
| fputc(file,char ) |-| 指定ファイル([[ファイルポインタ]]でも可)に１文字を出力します。                          |
| fputs(file,str  ) |-| 指定ファイル([[ファイルポインタ]]でも可)に文字列を出力します。                          |
| fputn(file,str,n) |-| 指定ファイル([[ファイルポインタ]]でも可)に文字列(ただし、最大 n 文字まで)を出力します。 |

&amp;br()

** ★gets() ファミリー関数について

&gt; 関数 getc(),gets(),getn() は、文字と文字列の入力関数です。

|COLOR(white):BGCOLOR(blue): 関数 |COLOR(white):BGCOLOR(green): (別名) |COLOR(white):BGCOLOR(red): 機能説明 |h
|  getc( ) |-| 標準入力(stdin)より１文字を読み込み、それを戻り値とします。                          |
|  gets( ) |-| 標準入力(stdin)より文字列を読み込み、それを戻り値とします。                          |
|  getn(n) |-| 標準入力(stdin)より文字列(ただし、最大 n 文字まで)を読み込み、それを戻り値とします。 |
| fgetc(file  ) |-| 指定ファイル([[ファイルポインタ]]でも可)より１文字を読み込み、それを戻り値とします。 |
| fgets(file  ) |-| 指定ファイル([[ファイルポインタ]]でも可)より文字列を読み込み、それを戻り値とします。 |
| fgetn(file,n) |-| 指定ファイル([[ファイルポインタ]]でも可)より文字列(ただし、最大 n 文字まで)を読み込み、それを戻り値とします。 |

&amp;br()
&amp;br()
&amp;br()    </description>
    <dc:date>2010-02-25T00:54:34+09:00</dc:date>
  </item>
    <item rdf:about="http://www20.atwiki.jp/air-lang/pages/54.html">
    <title>変数値の簡易表示</title>
    <link>http://www20.atwiki.jp/air-lang/pages/54.html</link>
    <description>
      変数値の簡易表示には、関数 p() が便利です。関数 p() は、引数の種別・個数などに制約はありません。
  p(x)                                     # 変数 x の値を表示します。
  p(a,b,c)                                 # ３つの変数 a b c の値を一括表示します。
  p(ARGV)                                  # 配列 ARGV[] の全要素の値を一括表示します。
  
  p(2.0*M_PI*r)                            # 式 ２πr の値を計算して表示します。

変数名をそのまま直接入力すると、関数 p() が自動実行されます。
これは、対話モード時に便利ですが、実行モードに制約はありません。
  % air -i                                 # AIR を対話モードで立ち上げます。
  AIR&gt; x                                   # p(x) と同じです。
  AIR&gt; a,b,c                               # p(a,b,c) と同じです。
  AIR&gt; ARGV                                # p(ARGV) と同じです。

&amp;br()
&amp;br()
&amp;br()    </description>
    <dc:date>2009-12-24T14:21:13+09:00</dc:date>
  </item>
  </rdf:RDF>

