| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 | 
							- 'use strict'
 
- var types = require('pg-types')
 
- var matchRegexp = /^([A-Za-z]+)(?: (\d+))?(?: (\d+))?/
 
- // result object returned from query
 
- // in the 'end' event and also
 
- // passed as second argument to provided callback
 
- class Result {
 
-   constructor(rowMode, types) {
 
-     this.command = null
 
-     this.rowCount = null
 
-     this.oid = null
 
-     this.rows = []
 
-     this.fields = []
 
-     this._parsers = undefined
 
-     this._types = types
 
-     this.RowCtor = null
 
-     this.rowAsArray = rowMode === 'array'
 
-     if (this.rowAsArray) {
 
-       this.parseRow = this._parseRowAsArray
 
-     }
 
-     this._prebuiltEmptyResultObject = null
 
-   }
 
-   // adds a command complete message
 
-   addCommandComplete(msg) {
 
-     var match
 
-     if (msg.text) {
 
-       // pure javascript
 
-       match = matchRegexp.exec(msg.text)
 
-     } else {
 
-       // native bindings
 
-       match = matchRegexp.exec(msg.command)
 
-     }
 
-     if (match) {
 
-       this.command = match[1]
 
-       if (match[3]) {
 
-         // COMMMAND OID ROWS
 
-         this.oid = parseInt(match[2], 10)
 
-         this.rowCount = parseInt(match[3], 10)
 
-       } else if (match[2]) {
 
-         // COMMAND ROWS
 
-         this.rowCount = parseInt(match[2], 10)
 
-       }
 
-     }
 
-   }
 
-   _parseRowAsArray(rowData) {
 
-     var row = new Array(rowData.length)
 
-     for (var i = 0, len = rowData.length; i < len; i++) {
 
-       var rawValue = rowData[i]
 
-       if (rawValue !== null) {
 
-         row[i] = this._parsers[i](rawValue)
 
-       } else {
 
-         row[i] = null
 
-       }
 
-     }
 
-     return row
 
-   }
 
-   parseRow(rowData) {
 
-     var row = { ... this._prebuiltEmptyResultObject }
 
-     for (var i = 0, len = rowData.length; i < len; i++) {
 
-       var rawValue = rowData[i]
 
-       var field = this.fields[i].name
 
-       if (rawValue !== null) {
 
-         row[field] = this._parsers[i](rawValue)
 
-       }
 
-     }
 
-     return row
 
-   }
 
-   addRow(row) {
 
-     this.rows.push(row)
 
-   }
 
-   addFields(fieldDescriptions) {
 
-     // clears field definitions
 
-     // multiple query statements in 1 action can result in multiple sets
 
-     // of rowDescriptions...eg: 'select NOW(); select 1::int;'
 
-     // you need to reset the fields
 
-     this.fields = fieldDescriptions
 
-     if (this.fields.length) {
 
-       this._parsers = new Array(fieldDescriptions.length)
 
-     }
 
-     for (var i = 0; i < fieldDescriptions.length; i++) {
 
-       var desc = fieldDescriptions[i]
 
-       if (this._types) {
 
-         this._parsers[i] = this._types.getTypeParser(desc.dataTypeID, desc.format || 'text')
 
-       } else {
 
-         this._parsers[i] = types.getTypeParser(desc.dataTypeID, desc.format || 'text')
 
-       }
 
-     }
 
-     this._createPrebuiltEmptyResultObject()
 
-   }
 
-   _createPrebuiltEmptyResultObject() {
 
-     var row = {}
 
-     for (var i = 0; i < this.fields.length; i++) {
 
-       row[this.fields[i].name] = null
 
-     }
 
-     this._prebuiltEmptyResultObject = { ... row }
 
-   }
 
- }
 
- module.exports = Result
 
 
  |