晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/proc/self/root/lib/node_modules/npm/node_modules/genfun/lib/ |
| Current File : //proc/self/root/lib/node_modules/npm/node_modules/genfun/lib/method.js |
'use strict'
/*
* Method
*
* Methods are added, conceptually, to Genfuns, not to objects
* themselves, although the Genfun object does not have any pointers to
* method objects.
*
* The _rank vector is an internal datastructure used during dispatch
* to figure out whether a method is applicable, and if so, how to
* order multiple discovered methods.
*
* Right now, the score method on Method does not take into account any
* ordering, and all arguments to a method are ranked equally for the
* sake of ordering.
*
*/
const Role = require('./role')
const util = require('./util')
module.exports = Method
function Method (genfun, selector, func) {
var method = this
method.genfun = genfun
method.func = func
method._rank = []
method.minimalSelector = 0
const tmpSelector = selector.length ? selector : [Object.prototype]
for (var object, i = tmpSelector.length - 1; i >= 0; i--) {
object = Object.hasOwnProperty.call(tmpSelector, i)
? tmpSelector[i]
: Object.prototype
object = util.dispatchableObject(object)
if (
typeof object === 'function' &&
!object.isGenfun
) {
object = object.prototype
}
if (i > 0 &&
!method.minimalSelector &&
util.isObjectProto(object)) {
continue
} else {
method.minimalSelector++
if (!Object.hasOwnProperty.call(object, Role.roleKeyName)) {
// Object.defineProperty is JS 1.8.0+
Object.defineProperty(
object, Role.roleKeyName, {value: [], enumerable: false})
}
// XXX HACK - no method replacement now, so we just shove
// it in a place where it'll always show up first. This
// would probably seriously break method combination if we
// had it.
object[Role.roleKeyName].unshift(new Role(method, i))
}
}
}
Method.setRankHierarchyPosition = (method, index, hierarchyPosition) => {
method._rank[index] = hierarchyPosition
}
Method.clearRank = method => {
method._rank = []
}
Method.isFullySpecified = method => {
for (var i = 0; i < method.minimalSelector; i++) {
if (!method._rank.hasOwnProperty(i)) {
return false
}
}
return true
}
Method.score = method => {
// TODO - this makes all items in the list equal
return method._rank.reduce((a, b) => a + b, 0)
}
|