UNPKG

molstar

Version:

A comprehensive macromolecular library.

166 lines 7.16 kB
/** * Copyright (c) 2018 Mol* contributors, licensed under MIT, See LICENSE file for more info. * * @author David Sehnal <david.sehnal@gmail.com> */ import { Type } from '../type'; import { Arguments, Argument } from '../symbol'; import { symbol, normalizeTable, symbolList } from '../helpers'; export var Types; (function (Types) { Types.AnyVar = Type.Variable('a', Type.Any); Types.AnyValueVar = Type.Variable('a', Type.Any); Types.ConstrainedVar = Type.Variable('a', Type.Any, true); Types.Regex = Type.Value('Core', 'Regex'); Types.Set = function (t) { return Type.Container('Core', 'Set', t || Types.AnyValueVar); }; Types.List = function (t) { return Type.Container('Core', 'List', t || Types.AnyVar); }; Types.Fn = function (t, alias) { return Type.Container('Core', 'Fn', t || Types.AnyVar, alias); }; Types.Flags = function (t, alias) { return Type.Container('Core', 'Flags', t, alias); }; Types.BitFlags = Types.Flags(Type.Num, 'BitFlags'); })(Types || (Types = {})); function unaryOp(type, description) { return symbol(Arguments.Dictionary({ 0: Argument(type) }), type, description); } function binOp(type, description) { return symbol(Arguments.List(type, { nonEmpty: true }), type, description); } function binRel(src, target, description) { return symbol(Arguments.Dictionary({ 0: Argument(src), 1: Argument(src) }), target, description); } export var TTargs = Arguments.Dictionary({ 0: Argument(Type.Num), 1: Argument(Type.Num) }); var XX = { test: Argument(Type.Str) }; var t = 0; t.test; var type = { '@header': 'Types', bool: symbol(Arguments.Dictionary({ 0: Argument(Type.AnyValue) }), Type.Bool, 'Convert a value to boolean.'), num: symbol(Arguments.Dictionary({ 0: Argument(Type.AnyValue) }), Type.Num, 'Convert a value to number.'), str: symbol(Arguments.Dictionary({ 0: Argument(Type.AnyValue) }), Type.Str, 'Convert a value to string.'), regex: symbol(Arguments.Dictionary({ 0: Argument(Type.Str, { description: 'Expression' }), 1: Argument(Type.Str, { isOptional: true, description: "Flags, e.g. 'i' for ignore case" }) }), Types.Regex, 'Creates a regular expression from a string using the ECMAscript syntax.'), list: symbol(Arguments.List(Types.AnyVar), Types.List()), set: symbol(Arguments.List(Types.AnyValueVar), Types.Set()), bitflags: symbol(Arguments.Dictionary({ 0: Argument(Type.Num) }), Types.BitFlags, 'Interpret a number as bitflags.'), compositeKey: symbol(Arguments.List(Type.AnyValue), Type.AnyValue), }; var logic = { '@header': 'Logic', not: unaryOp(Type.Bool), and: binOp(Type.Bool), or: binOp(Type.Bool), }; var ctrl = { '@header': 'Control', eval: symbol(Arguments.Dictionary({ 0: Argument(Types.Fn(Types.AnyVar)) }), Types.AnyVar, 'Evaluate a function.'), fn: symbol(Arguments.Dictionary({ 0: Argument(Types.AnyVar) }), Types.Fn(Types.AnyVar), 'Wrap an expression to a "lazy" function.'), if: symbol(Arguments.Dictionary({ 0: Argument(Type.Bool, { description: 'Condition' }), 1: Argument(Type.Variable('a', Type.Any), { description: 'If true' }), 2: Argument(Type.Variable('b', Type.Any), { description: 'If false' }) }), Type.Union([Type.Variable('a', Type.Any), Type.Variable('b', Type.Any)])), assoc: symbol(Arguments.Dictionary({ 0: Argument(Type.Str, { description: 'Name' }), 1: Argument(Type.Variable('a', Type.Any), { description: 'Value to assign' }) }), Type.Variable('a', Type.Any)) }; var rel = { '@header': 'Relational', eq: binRel(Type.Variable('a', Type.AnyValue, true), Type.Bool), neq: binRel(Type.Variable('a', Type.AnyValue, true), Type.Bool), lt: binRel(Type.Num, Type.Bool), lte: binRel(Type.Num, Type.Bool), gr: binRel(Type.Num, Type.Bool), gre: binRel(Type.Num, Type.Bool), inRange: symbol(Arguments.Dictionary({ 0: Argument(Type.Num, { description: 'Value to test' }), 1: Argument(Type.Num, { description: 'Minimum value' }), 2: Argument(Type.Num, { description: 'Maximum value' }) }), Type.Bool, 'Check if the value of the 1st argument is >= 2nd and <= 3rd.'), }; var math = { '@header': 'Math', add: binOp(Type.Num), sub: binOp(Type.Num), mult: binOp(Type.Num), div: binRel(Type.Num, Type.Num), pow: binRel(Type.Num, Type.Num), mod: binRel(Type.Num, Type.Num), min: binOp(Type.Num), max: binOp(Type.Num), floor: unaryOp(Type.Num), ceil: unaryOp(Type.Num), roundInt: unaryOp(Type.Num), abs: unaryOp(Type.Num), sqrt: unaryOp(Type.Num), cbrt: unaryOp(Type.Num), sin: unaryOp(Type.Num), cos: unaryOp(Type.Num), tan: unaryOp(Type.Num), asin: unaryOp(Type.Num), acos: unaryOp(Type.Num), atan: unaryOp(Type.Num), sinh: unaryOp(Type.Num), cosh: unaryOp(Type.Num), tanh: unaryOp(Type.Num), exp: unaryOp(Type.Num), log: unaryOp(Type.Num), log10: unaryOp(Type.Num), atan2: binRel(Type.Num, Type.Num) }; var str = { '@header': 'Strings', concat: binOp(Type.Str), match: symbol(Arguments.Dictionary({ 0: Argument(Types.Regex), 1: Argument(Type.Str) }), Type.Bool) }; var list = { '@header': 'Lists', getAt: symbol(Arguments.Dictionary({ 0: Argument(Types.List()), 1: Argument(Type.Num) }), Types.AnyVar), equal: symbol(Arguments.Dictionary({ 0: Argument(Types.List()), 1: Argument(Types.List()) }), Type.Bool) }; var set = { '@header': 'Sets', has: symbol(Arguments.Dictionary({ 0: Argument(Types.Set(Types.ConstrainedVar)), 1: Argument(Types.ConstrainedVar) }), Type.Bool, 'Check if the the 1st argument includes the value of the 2nd.'), isSubset: symbol(Arguments.Dictionary({ 0: Argument(Types.Set(Types.ConstrainedVar)), 1: Argument(Types.Set(Types.ConstrainedVar)) }), Type.Bool, 'Check if the the 1st argument is a subset of the 2nd.') }; var flags = { '@header': 'Flags', hasAny: symbol(Arguments.Dictionary({ 0: Argument(Types.Flags(Types.ConstrainedVar)), 1: Argument(Types.Flags(Types.ConstrainedVar)) }), Type.Bool, 'Check if the the 1st argument has at least one of the 2nd one\'s flags.'), hasAll: symbol(Arguments.Dictionary({ 0: Argument(Types.Flags(Types.ConstrainedVar)), 1: Argument(Types.Flags(Types.ConstrainedVar)) }), Type.Bool, 'Check if the the 1st argument has all 2nd one\'s flags.'), }; export var core = { '@header': 'Language Primitives', type: type, logic: logic, ctrl: ctrl, rel: rel, math: math, str: str, list: list, set: set, flags: flags }; normalizeTable(core); export var SymbolList = symbolList(core); export var SymbolMap = (function () { var map = Object.create(null); for (var _i = 0, SymbolList_1 = SymbolList; _i < SymbolList_1.length; _i++) { var s = SymbolList_1[_i]; map[s.id] = s; } return map; })(); //# sourceMappingURL=core.js.map