本文整理汇总了TypeScript中@glimmer/debug.check函数的典型用法代码示例。如果您正苦于以下问题:TypeScript check函数的具体用法?TypeScript check怎么用?TypeScript check使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了check函数的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: check
APPEND_OPCODES.add(Op.SetBlock, (vm, { op1: symbol }) => {
let handle = check(vm.stack.pop(), CheckOr(CheckOption(CheckHandle), CheckCompilableBlock));
let table = check(vm.stack.pop(), CheckOption(CheckBlockSymbolTable));
let block: Option<ScopeBlock> = table ? [handle!, table] : null;
vm.scope().bindBlock(symbol, block);
});
示例2: check
APPEND_OPCODES.add(Op.PutIterator, vm => {
let stack = vm.stack;
let listRef = check(stack.pop(), CheckPathReference);
let key = check(stack.pop(), CheckPathReference);
let iterable = vm.env.iterableFor(listRef, check(key.value(), CheckString));
let iterator = new ReferenceIterator(iterable);
stack.push(iterator);
stack.push(new IterablePresenceReference(iterator.artifacts));
});
示例3: Array
APPEND_OPCODES.add(Op.Concat, (vm, { op1: count }) => {
let out: Array<VersionedPathReference<Opaque>> = new Array(count);
for (let i = count; i > 0; i--) {
let offset = i - 1;
out[offset] = check(vm.stack.pop(), CheckPathReference);
}
vm.stack.push(new ConcatReference(out));
});
示例4: check
APPEND_OPCODES.add(Op.InvokePartial, (vm, { op1: _meta, op2: _symbols, op3: _evalInfo }) => {
let { constants, constants: { resolver }, stack } = vm;
let name = check(stack.pop(), CheckReference).value();
assert(typeof name === 'string', `Could not find a partial named "${String(name)}"`);
let meta = constants.getSerializable<TemplateMeta>(_meta);
let outerSymbols = constants.getStringArray(_symbols);
let evalInfo = constants.getArray(_evalInfo);
let specifier = resolver.lookupPartial(name as string, meta);
assert(specifier, `Could not find a partial named "${name}"`);
let definition = resolver.resolve<PartialDefinition>(specifier!);
let { symbolTable, handle } = definition.getPartial();
{
let partialSymbols = symbolTable.symbols;
let outerScope = vm.scope();
let partialScope = vm.pushRootScope(partialSymbols.length, false);
partialScope.bindCallerScope(outerScope.getCallerScope());
partialScope.bindEvalScope(outerScope.getEvalScope());
partialScope.bindSelf(outerScope.getSelf());
let locals = dict<VersionedPathReference<Opaque>>();
for (let i = 0; i < evalInfo.length; i++) {
let slot = evalInfo[i];
let name = outerSymbols[slot - 1];
let ref = outerScope.getSymbol(slot);
locals[name] = ref;
}
let evalScope = outerScope.getEvalScope()!;
for (let i = 0; i < partialSymbols.length; i++) {
let name = partialSymbols[i];
let symbol = i + 1;
let value = evalScope[name];
if (value !== undefined) partialScope.bind(symbol, value);
}
partialScope.bindPartialMap(locals);
vm.pushFrame(); // sp += 2
vm.call(handle!);
}
expectStackChange(vm.stack, 1, 'InvokePartial');
});
示例5: clearsArgs
function clearsArgs(options: ClearsArgs): DebugMetadata<number> {
return {
name: options.name,
ops: options.ops || [],
operands: options.operands || 0,
before(_opcode: Opaque, vm: VM): number {
return check(vm.stack.peek(options.argsPosition || 0), CheckInterface({ length: CheckNumber })).length;
},
stackChange({ state: args }: { state: number }): number {
return -args - 1 + (options.netPushes || 0) - (options.netPops || 0);
}
};
}
示例6: check
APPEND_OPCODES.add(Op.DynamicContent, (vm, { op1: isTrusting }) => {
let reference = check(vm.stack.pop(), CheckPathReference);
let value = reference.value();
let content: DynamicContentWrapper;
if (isTrusting) {
content = vm.elements().appendTrustingDynamicContent(value);
} else {
content = vm.elements().appendCautiousDynamicContent(value);
}
if (!isConst(reference)) {
vm.updateWith(new UpdateDynamicContentOpcode(reference, content));
}
expectStackChange(vm.stack, -1, 'DynamicContent');
});