{"version":3,"sources":["../src/is/port.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AAEH,OAAO,EAAC,IAAI,EAAC,MAAM,SAAS,CAAC;AAE7B,OAAO,EAAC,QAAQ,EAAC,MAAM,cAAc,CAAC;AAKtC;;;;GAIG;AACH,oBAAY,MAAM,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC;AAE1D;;;;;;;;GAQG;AACH,wBAAgB,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,KAAK,IAAI,MAAM,CActD;AAOD;;;;;;;;GAQG;AACH,wBAAgB,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,CAWhG","file":"port.d.ts","sourcesContent":["/**\n *\tMIT License\n *\n *\tCopyright (c) 2019 - 2021 Toreda, Inc.\n *\n *\tPermission is hereby granted, free of charge, to any person obtaining a copy\n *\tof this software and associated documentation files (the \"Software\"), to deal\n *\tin the Software without restriction, including without limitation the rights\n *\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n *\tcopies of the Software, and to permit persons to whom the Software is\n *\tfurnished to do so, subject to the following conditions:\n\n * \tThe above copyright notice and this permission notice shall be included in all\n * \tcopies or substantial portions of the Software.\n *\n * \tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n *\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n *\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * \tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n *\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n *\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * \tSOFTWARE.\n *\n */\n\nimport {Rule} from '../rule';\nimport {RuleFn} from '../rule/fn';\nimport {RuleMods} from '../rule/mods';\nimport {RuleNode} from '../rule/node';\nimport {RuleNodeType} from '../rule/node/type';\nimport {isInt} from './int';\n\n/**\n * Type signature for isPort validators used in rule chains.\n *\n * @category System Info Validators\n */\nexport type IsPort<CallerT> = (value?: number) => CallerT;\n\n/**\n * Check if provided value is a valid port number. Does not differentiate\n * between reserved system ports (root only)and non-reserved ports, only that\n * the port is in the valid port range.\n * @param value\n * @returns\n *\n * @category System Info Validators\n */\nexport function isPort(value?: number): value is number {\n\tif (typeof value !== 'number') {\n\t\treturn false;\n\t}\n\n\tif (value < 0) {\n\t\treturn false;\n\t}\n\n\tif (value > 65353) {\n\t\treturn false;\n\t}\n\n\treturn isInt(value);\n}\n\n//Must be an unsigned int (whole number).\n//Must be from 0 to 65353 .\n//port > 65353 is invalid.\n//port < 0 is invalid.\n\n/**\n * Factory to create isPort validator function used in rule chains.\n * @param caller\n * @param rule\n * @param mods\n * @returns\n *\n * @category Validator Factory Functions\n */\nexport function isPortMake<CallerT>(caller: CallerT, rule: Rule, mods: RuleMods): IsPort<CallerT> {\n\treturn (): CallerT => {\n\t\tconst fn: RuleFn<number> = (curr: number): boolean => {\n\t\t\treturn isPort(curr);\n\t\t};\n\n\t\tconst node = new RuleNode<number>('IS_PORT', RuleNodeType.CMP, fn, mods);\n\t\trule.add(node);\n\n\t\treturn caller;\n\t};\n}\n"]}