wink-nlp
Version:
Developer friendly Natural Language Processing ✨
77 lines (68 loc) • 2.85 kB
JavaScript
// wink-nlp
//
// Copyright (C) GRAYPE Systems Private Limited
//
// This file is part of “wink-nlp”.
//
// Permission is hereby granted, free of charge, to any
// person obtaining a copy of this software and
// associated documentation files (the "Software"), to
// deal in the Software without restriction, including
// without limitation the rights to use, copy, modify,
// merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to
// whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice
// shall be included in all copies or substantial
// portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF
// ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
// TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
// PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
// CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
var its = require( '../its.js' );
var as = require( '../as.js' );
var allowed = require( '../allowed.js' );
var colTokensOut = require( './col-tokens-out.js' );
// ## itmEntityOut
/**
* Out method for an entity. Note: the out always returns a Javascript
* data type or data structure. There is no word vector support for entity.
* @param {number} index The index of desired entity.
* @param {Object} entities The entities from the `rdd`; could be custom.
* @param {Object} rdd Raw Document Data-structure.
* @param {function} itsf Desired `its` mapper.
* @return {*} Mapped value.
* @private
*/
var itmEntityOut = function ( index, entities, rdd, itsf ) {
var entity = entities[ index ];
var itsfn = ( itsf && allowed.its4entity.has( itsf ) ) ? itsf : its.value;
var detail;
if ( itsfn === its.detail ) {
// In case of `detail`, return an object containing entity's `text` & `type`.
detail = Object.create( null );
detail.value = colTokensOut( entity[ 0 ], entity[ 1 ], rdd, its.value, as.text );
detail.type = entity[ 2 ];
return detail;
}
if ( itsfn === its.type ) {
// Extract `type` and return directly.
return entity[ 2 ];
}
if ( itsfn === its.span ) {
// Extract span and return.
return its.span( entity );
}
// Balance cases ( i.e. value, normal, and type ) are handled via `colTokensOut()`.
return colTokensOut( entity[ 0 ], entity[ 1 ], rdd, itsfn, as.text );
}; // itmEntityOut()
module.exports = itmEntityOut;