2023-10-03 11:14:36 +08:00
var _typeof = require ( "./typeof.js" ) [ "default" ] ;
var checkInRHS = require ( "./checkInRHS.js" ) ;
function createAddInitializerMethod ( initializers , decoratorFinishedRef ) {
return function ( initializer ) {
assertNotFinished ( decoratorFinishedRef , "addInitializer" ) , assertCallable ( initializer , "An initializer" ) , initializers . push ( initializer ) ;
} ;
}
function assertInstanceIfPrivate ( has , target ) {
if ( ! has ( target ) ) throw new TypeError ( "Attempted to access private element on non-instance" ) ;
}
function memberDec ( dec , name , desc , initializers , kind , isStatic , isPrivate , value , hasPrivateBrand ) {
var kindStr ;
switch ( kind ) {
case 1 :
kindStr = "accessor" ;
break ;
case 2 :
kindStr = "method" ;
break ;
case 3 :
kindStr = "getter" ;
break ;
case 4 :
kindStr = "setter" ;
break ;
default :
kindStr = "field" ;
}
var get ,
set ,
ctx = {
kind : kindStr ,
name : isPrivate ? "#" + name : name ,
"static" : isStatic ,
"private" : isPrivate
} ,
decoratorFinishedRef = {
v : ! 1
} ;
if ( 0 !== kind && ( ctx . addInitializer = createAddInitializerMethod ( initializers , decoratorFinishedRef ) ) , isPrivate || 0 !== kind && 2 !== kind ) {
if ( 2 === kind ) get = function get ( target ) {
return assertInstanceIfPrivate ( hasPrivateBrand , target ) , desc . value ;
} ; else {
var t = 0 === kind || 1 === kind ;
( t || 3 === kind ) && ( get = isPrivate ? function ( target ) {
return assertInstanceIfPrivate ( hasPrivateBrand , target ) , desc . get . call ( target ) ;
} : function ( target ) {
return desc . get . call ( target ) ;
} ) , ( t || 4 === kind ) && ( set = isPrivate ? function ( target , value ) {
assertInstanceIfPrivate ( hasPrivateBrand , target ) , desc . set . call ( target , value ) ;
} : function ( target , value ) {
desc . set . call ( target , value ) ;
} ) ;
}
} else get = function get ( target ) {
return target [ name ] ;
} , 0 === kind && ( set = function set ( target , v ) {
target [ name ] = v ;
} ) ;
var has = isPrivate ? hasPrivateBrand . bind ( ) : function ( target ) {
return name in target ;
} ;
ctx . access = get && set ? {
get : get ,
set : set ,
has : has
} : get ? {
get : get ,
has : has
} : {
set : set ,
has : has
} ;
try {
return dec ( value , ctx ) ;
} finally {
decoratorFinishedRef . v = ! 0 ;
}
}
function assertNotFinished ( decoratorFinishedRef , fnName ) {
if ( decoratorFinishedRef . v ) throw new Error ( "attempted to call " + fnName + " after decoration was finished" ) ;
}
function assertCallable ( fn , hint ) {
if ( "function" != typeof fn ) throw new TypeError ( hint + " must be a function" ) ;
}
function assertValidReturnValue ( kind , value ) {
var type = _typeof ( value ) ;
if ( 1 === kind ) {
if ( "object" !== type || null === value ) throw new TypeError ( "accessor decorators must return an object with get, set, or init properties or void 0" ) ;
void 0 !== value . get && assertCallable ( value . get , "accessor.get" ) , void 0 !== value . set && assertCallable ( value . set , "accessor.set" ) , void 0 !== value . init && assertCallable ( value . init , "accessor.init" ) ;
} else if ( "function" !== type ) {
var hint ;
throw hint = 0 === kind ? "field" : 10 === kind ? "class" : "method" , new TypeError ( hint + " decorators must return a function or void 0" ) ;
}
}
function curryThis1 ( fn ) {
return function ( ) {
return fn ( this ) ;
} ;
}
function curryThis2 ( fn ) {
return function ( value ) {
fn ( this , value ) ;
} ;
}
function applyMemberDec ( ret , base , decInfo , name , kind , isStatic , isPrivate , initializers , hasPrivateBrand ) {
var desc ,
init ,
value ,
newValue ,
get ,
set ,
decs = decInfo [ 0 ] ;
if ( isPrivate ? desc = 0 === kind || 1 === kind ? {
get : curryThis1 ( decInfo [ 3 ] ) ,
set : curryThis2 ( decInfo [ 4 ] )
} : 3 === kind ? {
get : decInfo [ 3 ]
} : 4 === kind ? {
set : decInfo [ 3 ]
} : {
value : decInfo [ 3 ]
} : 0 !== kind && ( desc = Object . getOwnPropertyDescriptor ( base , name ) ) , 1 === kind ? value = {
get : desc . get ,
set : desc . set
} : 2 === kind ? value = desc . value : 3 === kind ? value = desc . get : 4 === kind && ( value = desc . set ) , "function" == typeof decs ) void 0 !== ( newValue = memberDec ( decs , name , desc , initializers , kind , isStatic , isPrivate , value , hasPrivateBrand ) ) && ( assertValidReturnValue ( kind , newValue ) , 0 === kind ? init = newValue : 1 === kind ? ( init = newValue . init , get = newValue . get || value . get , set = newValue . set || value . set , value = {
get : get ,
set : set
} ) : value = newValue ) ; else for ( var i = decs . length - 1 ; i >= 0 ; i -- ) {
var newInit ;
if ( void 0 !== ( newValue = memberDec ( decs [ i ] , name , desc , initializers , kind , isStatic , isPrivate , value , hasPrivateBrand ) ) ) assertValidReturnValue ( kind , newValue ) , 0 === kind ? newInit = newValue : 1 === kind ? ( newInit = newValue . init , get = newValue . get || value . get , set = newValue . set || value . set , value = {
get : get ,
set : set
} ) : value = newValue , void 0 !== newInit && ( void 0 === init ? init = newInit : "function" == typeof init ? init = [ init , newInit ] : init . push ( newInit ) ) ;
}
if ( 0 === kind || 1 === kind ) {
if ( void 0 === init ) init = function init ( instance , _init ) {
return _init ;
} ; else if ( "function" != typeof init ) {
var ownInitializers = init ;
init = function init ( instance , _init2 ) {
for ( var value = _init2 , i = 0 ; i < ownInitializers . length ; i ++ ) value = ownInitializers [ i ] . call ( instance , value ) ;
return value ;
} ;
} else {
var originalInitializer = init ;
init = function init ( instance , _init3 ) {
return originalInitializer . call ( instance , _init3 ) ;
} ;
}
ret . push ( init ) ;
}
0 !== kind && ( 1 === kind ? ( desc . get = value . get , desc . set = value . set ) : 2 === kind ? desc . value = value : 3 === kind ? desc . get = value : 4 === kind && ( desc . set = value ) , isPrivate ? 1 === kind ? ( ret . push ( function ( instance , args ) {
return value . get . call ( instance , args ) ;
} ) , ret . push ( function ( instance , args ) {
return value . set . call ( instance , args ) ;
} ) ) : 2 === kind ? ret . push ( value ) : ret . push ( function ( instance , args ) {
return value . call ( instance , args ) ;
} ) : Object . defineProperty ( base , name , desc ) ) ;
}
function applyMemberDecs ( Class , decInfos , instanceBrand ) {
for ( var protoInitializers , staticInitializers , staticBrand , ret = [ ] , existingProtoNonFields = new Map ( ) , existingStaticNonFields = new Map ( ) , i = 0 ; i < decInfos . length ; i ++ ) {
var decInfo = decInfos [ i ] ;
if ( Array . isArray ( decInfo ) ) {
var base ,
initializers ,
kind = decInfo [ 1 ] ,
name = decInfo [ 2 ] ,
isPrivate = decInfo . length > 3 ,
isStatic = kind >= 5 ,
hasPrivateBrand = instanceBrand ;
if ( isStatic ? ( base = Class , 0 !== ( kind -= 5 ) && ( initializers = staticInitializers = staticInitializers || [ ] ) , isPrivate && ! staticBrand && ( staticBrand = function staticBrand ( _ ) {
return checkInRHS ( _ ) === Class ;
} ) , hasPrivateBrand = staticBrand ) : ( base = Class . prototype , 0 !== kind && ( initializers = protoInitializers = protoInitializers || [ ] ) ) , 0 !== kind && ! isPrivate ) {
var existingNonFields = isStatic ? existingStaticNonFields : existingProtoNonFields ,
existingKind = existingNonFields . get ( name ) || 0 ;
if ( ! 0 === existingKind || 3 === existingKind && 4 !== kind || 4 === existingKind && 3 !== kind ) throw new Error ( "Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: " + name ) ;
! existingKind && kind > 2 ? existingNonFields . set ( name , kind ) : existingNonFields . set ( name , ! 0 ) ;
}
applyMemberDec ( ret , base , decInfo , name , kind , isStatic , isPrivate , initializers , hasPrivateBrand ) ;
}
}
return pushInitializers ( ret , protoInitializers ) , pushInitializers ( ret , staticInitializers ) , ret ;
}
function pushInitializers ( ret , initializers ) {
initializers && ret . push ( function ( instance ) {
for ( var i = 0 ; i < initializers . length ; i ++ ) initializers [ i ] . call ( instance ) ;
return instance ;
} ) ;
}
function applyClassDecs ( targetClass , classDecs ) {
if ( classDecs . length > 0 ) {
for ( var initializers = [ ] , newClass = targetClass , name = targetClass . name , i = classDecs . length - 1 ; i >= 0 ; i -- ) {
var decoratorFinishedRef = {
v : ! 1
} ;
try {
var nextNewClass = classDecs [ i ] ( newClass , {
kind : "class" ,
name : name ,
addInitializer : createAddInitializerMethod ( initializers , decoratorFinishedRef )
} ) ;
} finally {
decoratorFinishedRef . v = ! 0 ;
}
void 0 !== nextNewClass && ( assertValidReturnValue ( 10 , nextNewClass ) , newClass = nextNewClass ) ;
}
return [ newClass , function ( ) {
for ( var i = 0 ; i < initializers . length ; i ++ ) initializers [ i ] . call ( newClass ) ;
} ] ;
}
}
function applyDecs2301 ( targetClass , memberDecs , classDecs , instanceBrand ) {
return {
e : applyMemberDecs ( targetClass , memberDecs , instanceBrand ) ,
get c ( ) {
return applyClassDecs ( targetClass , classDecs ) ;
}
} ;
}
2023-09-25 15:58:56 +08:00
module . exports = applyDecs2301 , module . exports . _ _esModule = true , module . exports [ "default" ] = module . exports ;