diff options
| author | Yaroslav De La Peña Smirnov <yaros.rus_89@live.com.mx> | 2017-11-29 11:44:34 +0300 | 
|---|---|---|
| committer | Yaroslav De La Peña Smirnov <yaros.rus_89@live.com.mx> | 2017-11-29 11:44:34 +0300 | 
| commit | 67fdec20726e48ba3a934cb25bb30d47ec4a4f29 (patch) | |
| tree | 37fd9f4f0b0c20103e1646fc83021e4765de3680 /node_modules/socket.io-client/lib/index.js | |
| download | spanish-checkers-67fdec20726e48ba3a934cb25bb30d47ec4a4f29.tar.gz spanish-checkers-67fdec20726e48ba3a934cb25bb30d47ec4a4f29.zip  | |
Initial commit, version 0.5.3
Diffstat (limited to 'node_modules/socket.io-client/lib/index.js')
| -rw-r--r-- | node_modules/socket.io-client/lib/index.js | 94 | 
1 files changed, 94 insertions, 0 deletions
diff --git a/node_modules/socket.io-client/lib/index.js b/node_modules/socket.io-client/lib/index.js new file mode 100644 index 0000000..6bc993c --- /dev/null +++ b/node_modules/socket.io-client/lib/index.js @@ -0,0 +1,94 @@ + +/** + * Module dependencies. + */ + +var url = require('./url'); +var parser = require('socket.io-parser'); +var Manager = require('./manager'); +var debug = require('debug')('socket.io-client'); + +/** + * Module exports. + */ + +module.exports = exports = lookup; + +/** + * Managers cache. + */ + +var cache = exports.managers = {}; + +/** + * Looks up an existing `Manager` for multiplexing. + * If the user summons: + * + *   `io('http://localhost/a');` + *   `io('http://localhost/b');` + * + * We reuse the existing instance based on same scheme/port/host, + * and we initialize sockets for each namespace. + * + * @api public + */ + +function lookup (uri, opts) { +  if (typeof uri === 'object') { +    opts = uri; +    uri = undefined; +  } + +  opts = opts || {}; + +  var parsed = url(uri); +  var source = parsed.source; +  var id = parsed.id; +  var path = parsed.path; +  var sameNamespace = cache[id] && path in cache[id].nsps; +  var newConnection = opts.forceNew || opts['force new connection'] || +                      false === opts.multiplex || sameNamespace; + +  var io; + +  if (newConnection) { +    debug('ignoring socket cache for %s', source); +    io = Manager(source, opts); +  } else { +    if (!cache[id]) { +      debug('new io instance for %s', source); +      cache[id] = Manager(source, opts); +    } +    io = cache[id]; +  } +  if (parsed.query && !opts.query) { +    opts.query = parsed.query; +  } +  return io.socket(parsed.path, opts); +} + +/** + * Protocol version. + * + * @api public + */ + +exports.protocol = parser.protocol; + +/** + * `connect`. + * + * @param {String} uri + * @api public + */ + +exports.connect = lookup; + +/** + * Expose constructors for standalone build. + * + * @api public + */ + +exports.Manager = require('./manager'); +exports.Socket = require('./socket');  | 
