読者です 読者をやめる 読者になる 読者になる

EventEmitter

今日はEventEmitterです。
JQueryとかでイベントリスナーを使ったことがあったので概要はわかりました。

完全なコードはこちら

var util = require('util'),
    url  = require('url'),
    http = require('http'),
    EventEmitter = require('events').EventEmitter;
// レスポンスを格納する
var sites = function(checkSiteNum){
  var that = {
    downloads: [],
    max: checkSiteNum,
    done: 0
  };

  // レスポンスを格納
  var add = function(index, response, body){
    // 省略
  };
  // すべて格納したか判断
  var isFinish = function(){
    // 省略
  };
  // 結果を表示
  var showAll = function(){
    // 省略
  };
  that.add = add;
  that.isFinish = isFinish;
  that.showAll = showAll;
  return that;
};

function download(urlStr, index){
  var u = url.parse(urlStr);
  var options = {
    host: u.host,
    port: u.port || 80,
    path: u.path
  };
  var ev = new EventEmitter();

  http.get(options, function(res){
    var buf = '';
    res.setEncoding('utf8');
    
    // レスポンスを受け付けた時
    res.on('data', function(chunk){
      buf += chunk;
    });

    res.on('end', function(){
      // イベントの発火
      ev.emit('notify', index, res, buf);
    });
  }).on('error', function(e){
    console.log('get error %s', e.message);
  });

  return ev;
}

// main
var argv = process.argv;
var len = argv.length;
var downloadSite = sites(len-2);

for(var i = 2; i < len ; i++){
  var ev = download(argv[i], i-2); 
  // イベントハンドラ登録
  ev.on('notify', function(index, res, buf){
    downloadSite.add(index, res, buf);
    if(downloadSite.isFinish()){
      downloadSite.showAll();
    }
  });
}

もし、emitの第一引数に定義されていないものを入れたらどうなるんでしょう?