Full Code of any86/any-rule for AI

master 43abe0f89526 cached
39 files
88.6 KB
33.4k tokens
21 symbols
1 requests
Download .txt
Repository: any86/any-rule
Branch: master
Commit: 43abe0f89526
Files: 39
Total size: 88.6 KB

Directory structure:
gitextract_h_p5umc3/

├── .circleci/
│   └── config.yml
├── .gitattributes
├── .github/
│   └── workflows/
│       └── nodejs.yml
├── .gitignore
├── .vscodeignore
├── CHANGELOG.md
├── LICENSE
├── README.md
├── __test__/
│   └── rule.js
├── package.json
├── packages/
│   └── www/
│       ├── .gitignore
│       ├── LICENSE
│       ├── babel.config.js
│       ├── package.json
│       ├── prettier.config.js
│       ├── public/
│       │   ├── index.html
│       │   ├── manifest.json
│       │   └── sw.js
│       ├── scripts/
│       │   └── demo.js
│       ├── src/
│       │   ├── App.vue
│       │   ├── RULES.js
│       │   └── main.js
│       └── vue.config.js
├── scripts/
│   ├── genCommond.js
│   └── md.js
├── src/
│   ├── extension.ts
│   ├── insertLog.ts
│   ├── interface.d.ts
│   ├── shared.ts
│   ├── showResultMessage.ts
│   ├── test/
│   │   ├── runTest.ts
│   │   └── suite/
│   │       ├── extension.test.ts
│   │       └── index.ts
│   ├── useCommand.ts
│   ├── useMenuCommand.ts
│   └── useQuickPick.ts
├── tsconfig.json
├── tslint.json
└── webpack.config.js

================================================
FILE CONTENTS
================================================

================================================
FILE: .circleci/config.yml
================================================
# Javascript Node CircleCI 2.0 configuration file
#
# Check https://circleci.com/docs/2.0/language-javascript/ for more details
#
version: 2
jobs:
    build:
        filters:
            branches:
                ignore:
                    - gh-pages
        docker:
        # specify the version you desire here
        - image: circleci/node:12.14.1
        
        # Specify service dependencies here if necessary
        # CircleCI maintains a library of pre-built images
        # documented at https://circleci.com/docs/2.0/circleci-images/
        # - image: circleci/mongo:3.4.4

        working_directory: ~/repo

        parallelism: 1

        steps:
        - checkout

        # - restore_cache: 
        #     key: dependency-cache-{{ checksum "package.json" }}

        # - run: yarn install
        # - run: yarn add codecov
        - run: yarn add chalk@2.4.2

        

        # - save_cache:
        #     key: dependency-cache-{{ checksum "package.json" }}
        #     paths:
        #         - ./node_modules
        # run tests!  
        - run: yarn test:rules
        # - run: ./node_modules/.bin/codecov


================================================
FILE: .gitattributes
================================================
packages/*/** linguist-vendored

================================================
FILE: .github/workflows/nodejs.yml
================================================
name: Node CI

on: [push]

jobs:
  test:

    runs-on: ubuntu-latest

    steps:
    - uses: actions/checkout@master
    - name: Use Node.js 10.x
      uses: actions/setup-node@v1
      with:
        node-version: 10.x
    - name: test
      run: |
        npm i
        npm run test:rules


================================================
FILE: .gitignore
================================================
out
node_modules
coverage
.nyc_output
.vscode-test/
.idea
.vscode
.DS_Store
*.vsix
yarn-error.log
.rpt2_cache
dist


================================================
FILE: .vscodeignore
================================================
.vscode/**
.vscode-test/**
out/test/**
src/**
.gitignore
vsc-extension-quickstart.md
**/tsconfig.json
**/tslint.json
**/*.map
**/*.ts
**/node_modules

================================================
FILE: CHANGELOG.md
================================================
# 更新日志
🚀 [提交问题](https://github.com/any86/any-rule/issues/new)

### 0.3.18(2022-11-07)

- 优化数字/货币金额(支持负数、千分位分隔符)
- 优化小数(支持科学计数)
- 优化缩短"用户名校验"正则长度
- 增加户口薄正则
- 增加军官证正则
- 修复MAC地址的第二位一定是偶数(#264)

### 0.3.13(2022-01-10)
- 修正"网址"正则, 兼容更多符合的网址.
- 修正澳门身份证错误.

### 0.3.12(2021-10-20)
- 修复网址中带有"()"不能通过.
- 新增"整数"/"浮点数"等正则.

### 0.3.11(2021-09-26)
- 修复新版vscode中"@zz"字符失效.
- 优化"身份证15/18"正则.

### 0.3.10(2021-05-28)
- 禁止"日期"可以通过"00"月和"00"日
### 0.3.9(2021-04-20)
- 新增"GUID/UUID"正则.
- 修复ip中的"."没有被转义.


### 0.3.8(2021-01-17)
- 优化一些冗余的正则拼写
- 修复新能源汽车不匹配第三位为字母的情况.
- 座机电话兼容带分机号的情况.

### 0.3.7(2020-11-25)
- 修复"IPv4"不严格, 且增加端口校验.
- 新增"座机电话(区号可选)"

### 0.3.6(2020-08-03)
- 新增"港澳台身份证"

### 0.3.5(2020-07-18)
- 修复"车牌号"可以通过"浙苏H6F681"的问题
- 新增"数字和英文字母组成,并且同时含有数字和英文字母"

### 0.3.4(2020-06-14)
- 修正"车牌号(新能源+非新能源)"未对长度进行限制.
- 修正"身份证"中月份可以匹配00月的bug.
- 新增"匹配连续重复的字符"正则.
- 修正座机支持4位区号,8位电话号.
- 修正, 根据用户需求, "qq@qq"样式的email邮箱地址不再通过验证.

### 0.3.3(2020-04-28)
- 优化增加"身份证中日期的约束".
- 优化"html注释|座机|密码"等正则.
- 新增"mac地址"正则.

### 0.3.2(2020-04-03)
- 修复"linux文件夹"正则不能匹配"/".
- 部分正则标题增加"英文关键字", 方便检索.

### 0.3.1 (2020-03-12)
- 修复"@zz唤醒"和"菜单唤醒"在某些机型下失效的bug.
- 修复"设置后未生效".
- 修改部分提示图标.
- 合并'linux文件'和'linux文件夹'正则.
- 新增'linux隐藏文件'正则.

### 0.3.0 (2020-02-28)
- 修改"zz."触发为"@zz"触发.
- 增加右键唤醒正则菜单.
![](https://user-gold-cdn.xitu.io/2020/2/28/1708764046b38231?w=381&h=413&f=png&s=73047)

### 0.2.0 (2020-02-21)

- 优化"zz."体验, 改用"quickPick"组件以支持"模糊搜索".
![gif](https://user-gold-cdn.xitu.io/2020/2/23/1706df78b18466fd?w=954&h=372&f=gif&s=1732199)
- 增加"设置"功能, 可以在设置中搜索"any-rule".
- 新增"🦕图解正则".
![](https://user-gold-cdn.xitu.io/2020/2/23/1706e32c3a6fb116?w=533&h=95&f=png&s=21563)

![](https://user-gold-cdn.xitu.io/2020/2/23/1706e349b600c28b?w=1151&h=500&f=png&s=45210)

### 0.1.0
- 新增支持在代码任意位置输入"zz."唤醒正则列表.

### 0.0.13
- 给"统一社会信用代码"增加^$标记
- 修复图片/视频连接匹配不严谨
- 增加"机身码IMEI"正则
- 增加"火车车次"正则

### 0.0.12
- 增加"必须带端口号的网址(或ip)"正则
- 修复网址可以匹配"...."的错误

### 0.0.11
- 增加"统一社会信用代码"正则

### 0.0.10
- 迅雷正则增加thunderx规则的支持

### 0.0.9
- 修复"ed2k"正则错误

### 0.0.8
- 优化车牌号正则

### 0.0.7
- 更新"银行卡"的匹配长度为10-30位,参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1)

### 0.0.6
- 修复"手机号(严禁)正则"错误.

### 0.0.5
- 增加正则"迅雷链接" / "ed2k连接" / "磁力链接" / "子网掩码" / "linux文件(夹)路径" / "window文件(夹)路径"


### 0.0.4
- 优化"大于0, 小于150, 支持小数位出现5"减少没必要的捕获
- 修复"html注释"没有匹配换行符

### 0.0.3

- 解决vscode低版本兼容问题
- 替换主页的git图地址

================================================
FILE: LICENSE
================================================
MIT License

Copyright (c) 2021 Russell

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.


================================================
FILE: README.md
================================================
# 正则大全  ![已收录84条](https://img.shields.io/badge/已收录-84条-673ab7.svg) [![版本](https://badgen.net/vs-marketplace/v/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule) [![安装量](https://badgen.net/vs-marketplace/i/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule) [![下载量](https://badgen.net/vs-marketplace/d/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule) ![MIT](https://img.shields.io/badge/license-MIT-F44336.svg) [![CircleCI](https://badgen.net/github/status/any86/any-rule/master/ci/circleci)](https://circleci.com/gh/any86/any-rule)

🦕支持**web** / **vscode** / **idea** / **Alfred Workflow**多平台

## :rocket:web版本
https://any-rule.vercel.app/

## 🍭vscode插件

### 安装
vscode应用商店中搜索"**any-rule**".

### 使用
**方式1:**

1. 按**F1**(mac下fn+F1)打开正则列表.
2. **输入关键词搜索**, 比如"手机".

![GIF](https://user-images.githubusercontent.com/8264787/146724787-888a8666-5d2a-4e5e-b383-aec7c53bd312.gif)

**方式2:**

右键选择"🦕正则大全".

![GIF](https://user-images.githubusercontent.com/8264787/146725447-4d92caed-2dd0-4f11-91d1-8da9cd8ff08b.gif)

**方式3:**

在代码任意位置输入"**@zz**".

![GIF](https://user-images.githubusercontent.com/8264787/146725402-30b34119-b709-4d49-adb2-af8dbb786d3b.gif)

## 👩‍🏫图解正则
<details>
<summary>查看详情</summary>
每次在any-rule中选择正则后会弹出提示, 可点击"🤖图解正则".

![image](https://user-images.githubusercontent.com/8264787/146726200-d97e48c3-df76-4531-8210-b6935fffb997.png)

点击后可以看到正则解析, 方便大家学习.

![image](https://user-images.githubusercontent.com/8264787/146726350-58166bf9-7f7f-4685-86aa-f055d0c0b914.png)

**注意**: 图解直接使用了https://regexper.com, 在此对作者表示敬意和感谢.
</details>

## 社区版本

社区版本非本人维护, 只是其他开发者使用了any-rule整理的正则内容, 如使用出现问题可直接与其开发者联系.

[idea版](https://github.com/zhoriya/idea-rule)

[Alfred Workflow版](https://github.com/cccyb/workflows)

[hyjs: 函数封装版](https://github.com/heiyehk/hyjs/tree/main/packages/utils)

[命令行版本](https://github.com/shenguanjiejie/workwork)

[uTools版本](https://github.com/trentlee0/utools-any-rule)

## :fire:关于PR
欢迎大家PR, 步骤如下:
1. **正则**请在**packages/www/src/RULES.js**中添加.
2. 运行`npm run test:rules`进行测试.
3. 运行`npm run build:md`更新**README.md**.
4. 请务必提交到**develop**分支.

在此感谢大家对**any-rule**做出的贡献! 

## 🍔正则

### 火车车次
```javascript
/^[GCDZTSPKXLY1-9]\d{1,4}$/
```

### 手机机身码(IMEI)
```javascript
/^\d{15,17}$/
```

### 必须带端口号的网址(或ip)
```javascript
/^((ht|f)tps?:\/\/)?[\w-]+(\.[\w-]+)+:\d{1,5}\/?$/
```

### 网址(URL)
```javascript
/^(((ht|f)tps?):\/\/)?([^!@#$%^&*?.\s-]([^!@#$%^&*?.\s]{0,63}[^!@#$%^&*?.\s])?\.)+[a-z]{2,6}\/?/
```

### 统一社会信用代码
```javascript
/^[0-9A-HJ-NPQRTUWXY]{2}\d{6}[0-9A-HJ-NPQRTUWXY]{10}$/
```

### 统一社会信用代码(宽松匹配)(15位/18位/20位数字/字母)
```javascript
/^(([0-9A-Za-z]{15})|([0-9A-Za-z]{18})|([0-9A-Za-z]{20}))$/
```

### 迅雷链接
```javascript
/^thunderx?:\/\/[a-zA-Z\d]+=$/
```

### ed2k链接(宽松匹配)
```javascript
/^ed2k:\/\/\|file\|.+\|\/$/
```

### 磁力链接(宽松匹配)
```javascript
/^magnet:\?xt=urn:btih:[0-9a-fA-F]{40,}.*$/
```

### 子网掩码(不包含 0.0.0.0)
```javascript
/^(254|252|248|240|224|192|128)\.0\.0\.0|255\.(254|252|248|240|224|192|128|0)\.0\.0|255\.255\.(254|252|248|240|224|192|128|0)\.0|255\.255\.255\.(255|254|252|248|240|224|192|128|0)$/
```

### linux"隐藏文件"路径
```javascript
/^\/(?:[^/]+\/)*\.[^/]*/
```

### linux文件夹路径
```javascript
/^\/(?:[^/]+\/)*$/
```

### linux文件路径
```javascript
/^\/(?:[^/]+\/)*[^/]+$/
```

### window"文件夹"路径
```javascript
/^[a-zA-Z]:\\(?:\w+\\?)*$/
```

### window下"文件"路径
```javascript
/^[a-zA-Z]:\\(?:\w+\\)*\w+\.\w+$/
```

### 股票代码(A股)
```javascript
/^(s[hz]|S[HZ])(000[\d]{3}|002[\d]{3}|300[\d]{3}|600[\d]{3}|60[\d]{4})$/
```

### 大于等于0, 小于等于150, 支持小数位出现5, 如145.5, 用于判断考卷分数
```javascript
/^150$|^(?:\d|[1-9]\d|1[0-4]\d)(?:\.5)?$/
```

### html注释
```javascript
/<!--[\s\S]*?-->/g
```

### md5格式(32位)
```javascript
/^[a-fA-F0-9]{32}$/
```

### GUID/UUID
```javascript
/^[a-f\d]{4}(?:[a-f\d]{4}-){4}[a-f\d]{12}$/i
```

### 版本号(version)格式必须为X.Y.Z
```javascript
/^\d+(?:\.\d+){2}$/
```

### 视频(video)链接地址(视频格式可按需增删)
```javascript
/^https?:\/\/(.+\/)+.+(\.(swf|avi|flv|mpg|rm|mov|wav|asf|3gp|mkv|rmvb|mp4))$/i
```

### 图片(image)链接地址(图片格式可按需增删)
```javascript
/^https?:\/\/(.+\/)+.+(\.(gif|png|jpg|jpeg|webp|svg|psd|bmp|tif))$/i
```

### 24小时制时间(HH:mm:ss)
```javascript
/^(?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/
```

### 12小时制时间(hh:mm:ss)
```javascript
/^(?:1[0-2]|0?[1-9]):[0-5]\d:[0-5]\d$/
```

### base64格式
```javascript
/^\s*data:(?:[a-z]+\/[a-z0-9-+.]+(?:;[a-z-]+=[a-z0-9-]+)?)?(?:;base64)?,([a-z0-9!$&',()*+;=\-._~:@/?%\s]*?)\s*$/i
```

### 数字/货币金额(支持负数、千分位分隔符)
```javascript
/^-?\d{1,3}(,\d{3})*(\.\d{1,2})?$/
```

### 银行卡号(10到30位, 覆盖对公/私账户, 参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1))
```javascript
/^[1-9]\d{9,29}$/
```

### 中文姓名
```javascript
/^(?:[\u4e00-\u9fa5·]{2,16})$/
```

### 英文姓名
```javascript
/(^[a-zA-Z][a-zA-Z\s]{0,20}[a-zA-Z]$)/
```

### 车牌号(新能源)
```javascript
/^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z](([DF]((?![IO])[a-zA-Z0-9](?![IO]))[0-9]{4})|([0-9]{5}[DF]))$/
```

### 车牌号(非新能源)
```javascript
/^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]$/
```

### 车牌号(新能源+非新能源)
```javascript
/^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4,5}[A-HJ-NP-Z0-9挂学警港澳]$/
```

### 手机号(mobile phone)中国(严谨), 根据工信部2019年最新公布的手机号段
```javascript
/^(?:(?:\+|00)86)?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[01256789]))\d{8}$/
```

### 手机号(mobile phone)中国(宽松), 只要是13,14,15,16,17,18,19开头即可
```javascript
/^(?:(?:\+|00)86)?1[3-9]\d{9}$/
```

### 手机号(mobile phone)中国(最宽松), 只要是1开头即可, 如果你的手机号是用来接收短信, 优先建议选择这一条
```javascript
/^(?:(?:\+|00)86)?1\d{10}$/
```

### 日期(宽松)
```javascript
/^\d{1,4}(-)(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31)$/
```

### 日期(严谨, 支持闰年判断)
```javascript
/^(([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29)$/
```

### 中国省
```javascript
/^浙江|上海|北京|天津|重庆|黑龙江|吉林|辽宁|内蒙古|河北|新疆|甘肃|青海|陕西|宁夏|河南|山东|山西|安徽|湖北|湖南|江苏|四川|贵州|云南|广西|西藏|江西|广东|福建|台湾|海南|香港|澳门$/
```

### 可以被moment转化成功的时间 YYYYMMDD HH:mm:ss
```javascript
/^\d{4}([/:-\S])(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31) (?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/
```

### email(邮箱)
```javascript
/^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/
```

### 座机(tel phone)电话(国内),如: 0341-86091234
```javascript
/^(?:(?:\d{3}-)?\d{8}|^(?:\d{4}-)?\d{7,8})(?:-\d+)?$/
```

### 身份证号(1代,15位数字)
```javascript
/^[1-9]\d{7}(?:0\d|10|11|12)(?:0[1-9]|[1-2][\d]|30|31)\d{3}$/
```

### 身份证号(2代,18位数字),最后一位是校验位,可能为数字或字符X
```javascript
/^[1-9]\d{5}(?:18|19|20)\d{2}(?:0[1-9]|10|11|12)(?:0[1-9]|[1-2]\d|30|31)\d{3}[\dXx]$/
```

### 身份证号, 支持1/2代(15位/18位数字)
```javascript
/^\d{6}((((((19|20)\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|(((19|20)\d{2})(0[13578]|1[02])31)|((19|20)\d{2})02(0[1-9]|1\d|2[0-8])|((((19|20)([13579][26]|[2468][048]|0[48]))|(2000))0229))\d{3})|((((\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|((\d{2})(0[13578]|1[02])31)|((\d{2})02(0[1-9]|1\d|2[0-8]))|(([13579][26]|[2468][048]|0[048])0229))\d{2}))(\d|X|x)$/
```

### 护照(包含香港、澳门)
```javascript
/(^[EeKkGgDdSsPpHh]\d{8}$)|(^(([Ee][a-fA-F])|([DdSsPp][Ee])|([Kk][Jj])|([Mm][Aa])|(1[45]))\d{7}$)/
```

### 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线组合
```javascript
/^[a-zA-Z]\w{4,15}$/
```

### 中文/汉字
```javascript
/^(?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])+$/
```

### 小数(支持科学计数)
```javascript
/^[+-]?(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)$/
```

### 只包含数字
```javascript
/^\d+$/
```

### html标签(宽松匹配)
```javascript
/<(\w+)[^>]*>(.*?<\/\1>)?/
```

### 匹配中文汉字和中文标点
```javascript
/[\u4e00-\u9fa5|\u3002|\uff1f|\uff01|\uff0c|\u3001|\uff1b|\uff1a|\u201c|\u201d|\u2018|\u2019|\uff08|\uff09|\u300a|\u300b|\u3008|\u3009|\u3010|\u3011|\u300e|\u300f|\u300c|\u300d|\ufe43|\ufe44|\u3014|\u3015|\u2026|\u2014|\uff5e|\ufe4f|\uffe5]/
```

### qq号格式正确
```javascript
/^[1-9][0-9]{4,10}$/
```

### 数字和字母组成
```javascript
/^[A-Za-z0-9]+$/
```

### 英文字母
```javascript
/^[a-zA-Z]+$/
```

### 小写英文字母组成
```javascript
/^[a-z]+$/
```

### 大写英文字母
```javascript
/^[A-Z]+$/
```

### 密码强度校验,最少6位,包括至少1个大写字母,1个小写字母,1个数字,1个特殊字符
```javascript
/^\S*(?=\S{6,})(?=\S*\d)(?=\S*[A-Z])(?=\S*[a-z])(?=\S*[!@#$%^&*? ])\S*$/
```

### 用户名校验,4到16位(字母,数字,下划线,减号)
```javascript
/^[\w-]{4,16}$/
```

### ip-v4[:端口]
```javascript
/^((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.){3}(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])(?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$/
```

### ip-v6[:端口]
```javascript
/(^(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))$)|(^\[(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))\](?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$)/i
```

### 16进制颜色
```javascript
/^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}|[a-fA-F0-9]{8}|[a-fA-F0-9]{4})$/
```

### 微信号(wx),6至20位,以字母开头,字母,数字,减号,下划线
```javascript
/^[a-zA-Z][-_a-zA-Z0-9]{5,19}$/
```

### 邮政编码(中国)
```javascript
/^(0[1-7]|1[0-356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[0-5]|8[013-6])\d{4}$/
```

### 中文和数字
```javascript
/^((?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])|(\d))+$/
```

### 不能包含字母
```javascript
/^[^A-Za-z]*$/
```

### java包名
```javascript
/^([a-zA-Z_]\w*)+([.][a-zA-Z_]\w*)+$/
```

### mac地址
```javascript
/^(([a-f0-9][0,2,4,6,8,a,c,e]:([a-f0-9]{2}:){4})|([a-f0-9][0,2,4,6,8,a,c,e]-([a-f0-9]{2}-){4}))[a-f0-9]{2}$/i
```

### 匹配连续重复的字符
```javascript
/(.)\1+/
```

### 数字和英文字母组成,并且同时含有数字和英文字母
```javascript
/^(?=.*[a-zA-Z])(?=.*\d).+$/
```

### 香港身份证 
```javascript
/^[a-zA-Z]\d{6}\([\dA]\)$/
```

### 澳门身份证 
```javascript
/^[1|5|7]\d{6}\(\d\)$/
```

### 台湾身份证 
```javascript
/^[a-zA-Z][0-9]{9}$/
```

### 大写字母,小写字母,数字,特殊符号 `@#$%^&*`~()-+=` 中任意3项密码
```javascript
/^(?![a-zA-Z]+$)(?![A-Z0-9]+$)(?![A-Z\W_!@#$%^&*`~()-+=]+$)(?![a-z0-9]+$)(?![a-z\W_!@#$%^&*`~()-+=]+$)(?![0-9\W_!@#$%^&*`~()-+=]+$)[a-zA-Z0-9\W_!@#$%^&*`~()-+=]/
```

### ASCII码表中的全部的特殊字符
```javascript
/[\x21-\x2F\x3A-\x40\x5B-\x60\x7B-\x7E]+/
```

### 正整数,不包含0
```javascript
/^\+?[1-9]\d*$/
```

### 负整数,不包含0
```javascript
/^-[1-9]\d*$/
```

### 整数
```javascript
/^(?:0|(?:-?[1-9]\d*))$/
```

### 浮点数
```javascript
/^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9]\d*|0\.0+)$/
```

### 浮点数(严格)
```javascript
/^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9])$/
```

### email(支持中文邮箱)
```javascript
/^[A-Za-z0-9\u4e00-\u9fa5]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
```

### 域名(非网址, 不包含协议)
```javascript
/^([0-9a-zA-Z-]{1,}\.)+([a-zA-Z]{2,})$/
```

### 军官/士兵证
```javascript
/^[\u4E00-\u9FA5](字第)([0-9a-zA-Z]{4,8})(号?)$/
```

### 户口薄
```javascript
/(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/
```


================================================
FILE: __test__/rule.js
================================================
const chalk = require('chalk');
const RULES = require('../packages/www/src/RULES');
let failGroup = [];


RULES.forEach(RULE => {
    testOne(RULE);
});


function testOne(one) {
    const {
        rule,
        examples,
        title,
        counterExamples
    } = one;
    examples.forEach(example => {
        const isSuccess = rule.test(example);
        if (isSuccess) {
            console.log(chalk.green(`成功: ${title}, 用例: ${example}`));
        } else {
            failGroup.push({title, example, is:'正例'});
            
            console.log(chalk.red(`失败: ${title}, 用例: ${example}`));
        }
    })

    if (counterExamples) {
        counterExamples.forEach(example => {
            const isFail = !rule.test(example);
            if (isFail) {
                console.log(chalk.green(`反例成功(counterExamples): ${title}`));
            } else {
                failGroup.push({title, example, is: '反例'});
                console.log(chalk.red(`反例失败(counterExamples): ${title}, 用例: ${example}`));
            }
        });
    }
}

if(0 === failGroup.length) {
    console.log(chalk.green('\r\n🚀 全部测试通过!'))
} else {
    console.log(chalk.red('='.repeat(30) + '🔥 未通过测试' + '='.repeat(30)));

    // 失败列表
    failGroup.forEach(item=>{
        const str = `${item.title}[${item.is}]: ${item.example}`;
        console.log(chalk.red(str));
    });
}


================================================
FILE: package.json
================================================
{
    "name": "any-rule",
    "publisher": "russell",
    "displayName": "any-rule",
    "description": "你要的\"正则\"都在这!",
    "version": "0.3.18",
    "keywords": [
        "vscode",
        "typescript",
        "regxp",
        "正则"
    ],
    "husky": {
        "hooks": {
            "pre-push": "npm run test:rules"
        }
    },
    "scripts": {
        "build:md": "node ./scripts/md.js",
        "build": "npm run test:rules && npm version patch && node ./scripts/genCommond.js && vsce package --yarn && npm run build:md",
        "vscode:prepublish": "npm run compile",
        "compile": "webpack --mode production",
        "watch": "tsc -watch -p ./",
        "pretest": "npm run compile",
        "test": "node ./out/test/runTest.js",
        "test:rules": "node __test__/rule",
        "release:demo": "cd packages/www && yarn release",
        "dev:demo": "cd packages/www && yarn serve"
    },
    "engines": {
        "vscode": "^1.12.0"
    },
    "categories": [
        "Snippets",
        "Other"
    ],
    "icon": "images/vscode-logo.png",
    "bugs": {
        "url": "https://github.com/any86/any-rule/issues"
    },
    "repository": {
        "type": "git",
        "url": "https://github.com/any86/any-rule.git"
    },
    "activationEvents": [
        "*"
    ],
    "main": "./out/extension.js",
    "contributes": {
        "configuration": {
            "type": "object",
            "title": "any-rule",
            "properties": {
                "any-rule.triggerString": {
                    "type": "string",
                    "default": "@zz",
                    "description": "触发字符串"
                },
                "any-rule.supportedLanguages": {
                    "type": "string",
                    "default": "*,javascript,javascriptreact,typescript,typescriptreact,vue,vue-postcss,vue-sugarss,vue-html,json,jsonc,graphql,dart,sql,go,java,php,jade,python,swift,markdown",
                    "description": "支持的开发语言(用','分割)"
                }
            }
        },
        "menus": {
            "editor/context": [
                {
                    "when": "editorFocus",
                    "command": "extension.rule.callByMenu",
                    "group": "navigation"
                }
            ]
        },
        "commands": [
            {
                "command": "extension.rule0",
                "title": "$(rocket) zz: 火车车次"
            },
            {
                "command": "extension.rule1",
                "title": "$(rocket) zz: 手机机身码(IMEI)"
            },
            {
                "command": "extension.rule2",
                "title": "$(rocket) zz: 必须带端口号的网址(或ip)"
            },
            {
                "command": "extension.rule3",
                "title": "$(rocket) zz: 网址(URL)"
            },
            {
                "command": "extension.rule4",
                "title": "$(rocket) zz: 统一社会信用代码"
            },
            {
                "command": "extension.rule5",
                "title": "$(rocket) zz: 统一社会信用代码(宽松匹配)(15位/18位/20位数字/字母)"
            },
            {
                "command": "extension.rule6",
                "title": "$(rocket) zz: 迅雷链接"
            },
            {
                "command": "extension.rule7",
                "title": "$(rocket) zz: ed2k链接(宽松匹配)"
            },
            {
                "command": "extension.rule8",
                "title": "$(rocket) zz: 磁力链接(宽松匹配)"
            },
            {
                "command": "extension.rule9",
                "title": "$(rocket) zz: 子网掩码(不包含 0.0.0.0)"
            },
            {
                "command": "extension.rule10",
                "title": "$(rocket) zz: linux\"隐藏文件\"路径"
            },
            {
                "command": "extension.rule11",
                "title": "$(rocket) zz: linux文件夹路径"
            },
            {
                "command": "extension.rule12",
                "title": "$(rocket) zz: linux文件路径"
            },
            {
                "command": "extension.rule13",
                "title": "$(rocket) zz: window\"文件夹\"路径"
            },
            {
                "command": "extension.rule14",
                "title": "$(rocket) zz: window下\"文件\"路径"
            },
            {
                "command": "extension.rule15",
                "title": "$(rocket) zz: 股票代码(A股)"
            },
            {
                "command": "extension.rule16",
                "title": "$(rocket) zz: 大于等于0, 小于等于150, 支持小数位出现5, 如145.5, 用于判断考卷分数"
            },
            {
                "command": "extension.rule17",
                "title": "$(rocket) zz: html注释"
            },
            {
                "command": "extension.rule18",
                "title": "$(rocket) zz: md5格式(32位)"
            },
            {
                "command": "extension.rule19",
                "title": "$(rocket) zz: GUID/UUID"
            },
            {
                "command": "extension.rule20",
                "title": "$(rocket) zz: 版本号(version)格式必须为X.Y.Z"
            },
            {
                "command": "extension.rule21",
                "title": "$(rocket) zz: 视频(video)链接地址(视频格式可按需增删)"
            },
            {
                "command": "extension.rule22",
                "title": "$(rocket) zz: 图片(image)链接地址(图片格式可按需增删)"
            },
            {
                "command": "extension.rule23",
                "title": "$(rocket) zz: 24小时制时间(HH:mm:ss)"
            },
            {
                "command": "extension.rule24",
                "title": "$(rocket) zz: 12小时制时间(hh:mm:ss)"
            },
            {
                "command": "extension.rule25",
                "title": "$(rocket) zz: base64格式"
            },
            {
                "command": "extension.rule26",
                "title": "$(rocket) zz: 数字/货币金额(支持负数、千分位分隔符)"
            },
            {
                "command": "extension.rule27",
                "title": "$(rocket) zz: 银行卡号(10到30位, 覆盖对公/私账户, 参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1))"
            },
            {
                "command": "extension.rule28",
                "title": "$(rocket) zz: 中文姓名"
            },
            {
                "command": "extension.rule29",
                "title": "$(rocket) zz: 英文姓名"
            },
            {
                "command": "extension.rule30",
                "title": "$(rocket) zz: 车牌号(新能源)"
            },
            {
                "command": "extension.rule31",
                "title": "$(rocket) zz: 车牌号(非新能源)"
            },
            {
                "command": "extension.rule32",
                "title": "$(rocket) zz: 车牌号(新能源+非新能源)"
            },
            {
                "command": "extension.rule33",
                "title": "$(rocket) zz: 手机号(mobile phone)中国(严谨), 根据工信部2019年最新公布的手机号段"
            },
            {
                "command": "extension.rule34",
                "title": "$(rocket) zz: 手机号(mobile phone)中国(宽松), 只要是13,14,15,16,17,18,19开头即可"
            },
            {
                "command": "extension.rule35",
                "title": "$(rocket) zz: 手机号(mobile phone)中国(最宽松), 只要是1开头即可, 如果你的手机号是用来接收短信, 优先建议选择这一条"
            },
            {
                "command": "extension.rule36",
                "title": "$(rocket) zz: 日期(宽松)"
            },
            {
                "command": "extension.rule37",
                "title": "$(rocket) zz: 日期(严谨, 支持闰年判断)"
            },
            {
                "command": "extension.rule38",
                "title": "$(rocket) zz: 中国省"
            },
            {
                "command": "extension.rule39",
                "title": "$(rocket) zz: 可以被moment转化成功的时间 YYYYMMDD HH:mm:ss"
            },
            {
                "command": "extension.rule40",
                "title": "$(rocket) zz: email(邮箱)"
            },
            {
                "command": "extension.rule41",
                "title": "$(rocket) zz: 座机(tel phone)电话(国内),如: 0341-86091234"
            },
            {
                "command": "extension.rule42",
                "title": "$(rocket) zz: 身份证号(1代,15位数字)"
            },
            {
                "command": "extension.rule43",
                "title": "$(rocket) zz: 身份证号(2代,18位数字),最后一位是校验位,可能为数字或字符X"
            },
            {
                "command": "extension.rule44",
                "title": "$(rocket) zz: 身份证号, 支持1/2代(15位/18位数字)"
            },
            {
                "command": "extension.rule45",
                "title": "$(rocket) zz: 护照(包含香港、澳门)"
            },
            {
                "command": "extension.rule46",
                "title": "$(rocket) zz: 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线组合"
            },
            {
                "command": "extension.rule47",
                "title": "$(rocket) zz: 中文/汉字"
            },
            {
                "command": "extension.rule48",
                "title": "$(rocket) zz: 小数(支持科学计数)"
            },
            {
                "command": "extension.rule49",
                "title": "$(rocket) zz: 只包含数字"
            },
            {
                "command": "extension.rule50",
                "title": "$(rocket) zz: html标签(宽松匹配)"
            },
            {
                "command": "extension.rule51",
                "title": "$(rocket) zz: 匹配中文汉字和中文标点"
            },
            {
                "command": "extension.rule52",
                "title": "$(rocket) zz: qq号格式正确"
            },
            {
                "command": "extension.rule53",
                "title": "$(rocket) zz: 数字和字母组成"
            },
            {
                "command": "extension.rule54",
                "title": "$(rocket) zz: 英文字母"
            },
            {
                "command": "extension.rule55",
                "title": "$(rocket) zz: 小写英文字母组成"
            },
            {
                "command": "extension.rule56",
                "title": "$(rocket) zz: 大写英文字母"
            },
            {
                "command": "extension.rule57",
                "title": "$(rocket) zz: 密码强度校验,最少6位,包括至少1个大写字母,1个小写字母,1个数字,1个特殊字符"
            },
            {
                "command": "extension.rule58",
                "title": "$(rocket) zz: 用户名校验,4到16位(字母,数字,下划线,减号)"
            },
            {
                "command": "extension.rule59",
                "title": "$(rocket) zz: ip-v4[:端口]"
            },
            {
                "command": "extension.rule60",
                "title": "$(rocket) zz: ip-v6[:端口]"
            },
            {
                "command": "extension.rule61",
                "title": "$(rocket) zz: 16进制颜色"
            },
            {
                "command": "extension.rule62",
                "title": "$(rocket) zz: 微信号(wx),6至20位,以字母开头,字母,数字,减号,下划线"
            },
            {
                "command": "extension.rule63",
                "title": "$(rocket) zz: 邮政编码(中国)"
            },
            {
                "command": "extension.rule64",
                "title": "$(rocket) zz: 中文和数字"
            },
            {
                "command": "extension.rule65",
                "title": "$(rocket) zz: 不能包含字母"
            },
            {
                "command": "extension.rule66",
                "title": "$(rocket) zz: java包名"
            },
            {
                "command": "extension.rule67",
                "title": "$(rocket) zz: mac地址"
            },
            {
                "command": "extension.rule68",
                "title": "$(rocket) zz: 匹配连续重复的字符"
            },
            {
                "command": "extension.rule69",
                "title": "$(rocket) zz: 数字和英文字母组成,并且同时含有数字和英文字母"
            },
            {
                "command": "extension.rule70",
                "title": "$(rocket) zz: 香港身份证 "
            },
            {
                "command": "extension.rule71",
                "title": "$(rocket) zz: 澳门身份证 "
            },
            {
                "command": "extension.rule72",
                "title": "$(rocket) zz: 台湾身份证 "
            },
            {
                "command": "extension.rule73",
                "title": "$(rocket) zz: 大写字母,小写字母,数字,特殊符号 `@#$%^&*`~()-+=` 中任意3项密码"
            },
            {
                "command": "extension.rule74",
                "title": "$(rocket) zz: ASCII码表中的全部的特殊字符"
            },
            {
                "command": "extension.rule75",
                "title": "$(rocket) zz: 正整数,不包含0"
            },
            {
                "command": "extension.rule76",
                "title": "$(rocket) zz: 负整数,不包含0"
            },
            {
                "command": "extension.rule77",
                "title": "$(rocket) zz: 整数"
            },
            {
                "command": "extension.rule78",
                "title": "$(rocket) zz: 浮点数"
            },
            {
                "command": "extension.rule79",
                "title": "$(rocket) zz: 浮点数(严格)"
            },
            {
                "command": "extension.rule80",
                "title": "$(rocket) zz: email(支持中文邮箱)"
            },
            {
                "command": "extension.rule81",
                "title": "$(rocket) zz: 域名(非网址, 不包含协议)"
            },
            {
                "command": "extension.rule82",
                "title": "$(rocket) zz: 军官/士兵证"
            },
            {
                "command": "extension.rule83",
                "title": "$(rocket) zz: 户口薄"
            },
            {
                "command": "extension.rule.callByMenu",
                "title": "🦕正则大全(84条)"
            }
        ]
    },
    "devDependencies": {
        "@types/glob": "^7.1.1",
        "@types/mocha": "^5.2.6",
        "@types/node": "^10.12.21",
        "@types/vscode": "^1.12.0",
        "glob": "^7.1.4",
        "husky": "^4.2.5",
        "mocha": "^6.1.4",
        "qiniu-js": "^2.5.5",
        "ts-loader": "^6.2.1",
        "tslint": "^5.12.1",
        "typescript": "^3.3.1",
        "vsce": "^1.74.0",
        "vscode-test": "^1.0.2",
        "webpack": "^4.41.6",
        "webpack-cli": "^3.3.11"
    },
    "dependencies": {
        "axios": "^0.19.2",
        "transliteration": "^2.1.8"
    }
}

================================================
FILE: packages/www/.gitignore
================================================
.DS_Store
node_modules
/dist

# local env files
.env.local
.env.*.local

# Log files
npm-debug.log*
yarn-debug.log*
yarn-error.log*

# Editor directories and files
.idea
.vscode
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?


================================================
FILE: packages/www/LICENSE
================================================
MIT License

Copyright (c) 2019 any86

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.


================================================
FILE: packages/www/babel.config.js
================================================
module.exports = {
  presets: [
    '@vue/app'
  ]
}


================================================
FILE: packages/www/package.json
================================================
{
  "name": "any-rule",
  "version": "0.1.0",
  "private": true,
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "release": "npm run build && node ./scripts/demo",
    "lint": "vue-cli-service lint",
    "rm:nm":"rimraf node_modules"
  },
  "dependencies": {
    "clipboard": "^2.0.4",
    "core-js": "^2.6.5",
    "crypto-js": "^4.0.0",
    "lodash": "^4.17.13",
    "node-sass": "^6.0.0",
    "sass-loader": "^10.0.0",
    "vue": "^2.6.10"
  },
  "devDependencies": {
    "@vue/cli-plugin-babel": "^3.8.0",
    "@vue/cli-plugin-eslint": "^3.8.0",
    "@vue/cli-service": "^3.8.0",
    "chalk": "^2.4.2",
    "gh-pages": "^2.0.1",
    "shelljs": "^0.8.3",
    "vue-template-compiler": "^2.6.10"
  },
  "eslintConfig": {
    "root": true,
    "env": {
      "node": true
    },
    "extends": [
      "plugin:vue/essential",
      "eslint:recommended"
    ],
    "rules": {},
    "parserOptions": {
      "parser": "babel-eslint"
    }
  },
  "postcss": {
    "plugins": {
      "autoprefixer": {}
    }
  },
  "browserslist": [
    "> 1%",
    "last 2 versions"
  ]
}


================================================
FILE: packages/www/prettier.config.js
================================================
// prettier.config.js or .prettierrc.js
module.exports = {
    tabWidth: 4,
    semi: true,
    singleQuote: true,
    arrowParens: 'always',
    printWidth: 120
};

================================================
FILE: packages/www/public/index.html
================================================
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width" />
    <link rel="icon" href="<%= BASE_URL %>favicon.ico">
    <link rel="manifest" href="<%= BASE_URL %>manifest.json">
    <title>正则大全</title>
    <!-- 百度统计 -->
    <script>
        var _hmt = _hmt || [];
        (function() {
            var hm = document.createElement("script");
            hm.src = "https://hm.baidu.com/hm.js?0a8aba0d0567d5e3b7fa2c9eac9d781f";
            var s = document.getElementsByTagName("script")[0];
            s.parentNode.insertBefore(hm, s);
        })();
    </script>
    <!-- <link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.15.8/styles/github.min.css">
    <script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.15.8/highlight.min.js"></script> -->
    <style>
        :root {
            --primary: #42b983;
        }

        * {
            padding: 0;
            margin: 0;
            box-sizing: border-box;
        }

        body {
            overflow-x: hidden;
            overflow-y: scroll;
        }

        a {
            text-decoration: none;
        }

        input {
            outline: none;
            border: 0 none;
        }

        li {
            list-style-type: none;
        }

        @keyframes rotate {
            from {
                transform: rotate(0);
            }

            to {
                transform: rotate(360deg);
            }
        }

        .loading {
            animation: rotate 1s infinite linear;
            margin: 0;
            padding: 0;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            margin: auto;
            display: block;
            width: 100px;
            height: 100px;
            border: 0 solid #42b983;
            border-right-width: 4px;
            border-radius: 50%;
        }
    </style>
</head>

<body>
    <noscript>
        <strong>We're sorry but any-rule doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
    </noscript>

    <div id="app">
        <i class="loading"></i>
    </div>
    <!-- built files will be auto injected -->
</body>

</html>

================================================
FILE: packages/www/public/manifest.json
================================================
{
    "short_name": "any-rule",
    "name": "正则大全",
    "icons": [
        {
            "src": "/any-rule/icon.png",
            "type": "image/png",
            "sizes": "192x192"
        }
    ],
    "background_color": "#2196F3",
    "theme_color": "#2196F3",
    "display": "standalone",
    "start_url": "/any-rule"
}

================================================
FILE: packages/www/public/sw.js
================================================


================================================
FILE: packages/www/scripts/demo.js
================================================
var ghpages = require('gh-pages');
const shell = require('shelljs');
const chalk = require('chalk');

// 发布
ghpages.publish('./dist', {
    branch: 'gh-pages',
}, (err) => {
    if(err) {
        console.log(chalk.red(err));
    } else {
        shell.rm('-rf', './dist');
        console.log(chalk.green('demo同步完成!'));
    }
});

================================================
FILE: packages/www/src/App.vue
================================================
<template>
    <main>
        <article class="fixed">
            <a
                onclick="_hmt.push(['_trackEvent', '交互', '提问'])"
                class="message"
                href="https://github.com/any86/any-rule/issues/new"
                target="_blank"
                ><svg
                    style="margin-right: 8px"
                    height="24"
                    width="24"
                    viewBox="0 0 16 16"
                    version="1.1"
                    aria-hidden="true"
                >
                    <path
                        fill-rule="evenodd"
                        fill="#fff"
                        d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z"
                    ></path>
                </svg>
                提问</a
            >
        </article>
        <header>
            <a
                onclick="_hmt.push(['_trackEvent', '交互', '点击github', '头部'])"
                href="https://github.com/any86/any-rule"
                target="_blank"
                class="github"
            >
                <!-- <svg height="32" viewBox="0 0 16 16" version="1.1" width="32" aria-hidden="true">
                    <path
                        fill-rule="evenodd"
                        d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z"
                    ></path>
                </svg> -->
                <h1>🦕正则大全</h1>
            </a>

            <iframe
                style="display: block; margin-top: 15px"
                src="https://ghbtns.com/github-btn.html?user=any86&repo=any-rule&type=star&count=true"
                frameborder="0"
                scrolling="0"
                width="170px"
                height="20px"
            ></iframe>

            <input
                ref="searchInput"
                v-model="keyword"
                autofocus
                @keyup="search"
                @mouseenter="selectSearchInputText"
                @focus="selectSearchInputText"
                class="search-input"
                placeholder="搜索关键词, 如'手机'"
                type="text"
            />
        </header>

        <article>
            <ul v-if="0 < rules.length" class="list">
                <li
                    @mouseenter="mouseenterHandler(index)"
                    v-for="({ title, rule, events, examples, counterExamples }, index) in rules"
                    :key="title"
                    class="row"
                >
                    <i class="border"></i>
                    <h2>{{ title }}</h2>
                    <p class="rule">
                        <span :data-clipboard-text="rule" class="btn-copy">点击复制</span>
                        <a
                            :href="`https://github.com/any86/any-rule/issues/new?title=我有更好的正则: ${title}`"
                            target="_blank"
                            class="btn-better"
                            >我有更好的正则</a
                        >
                        <code ref="code" class="javascript">{{ rule }}</code>
                    </p>
                    <section class="verification">
                        <label>
                            <input
                                ref="input"
                                :key="title"
                                v-model="list[index].value"
                                :placeholder="parseExample(examples, counterExamples)"
                                @compositionstart="check(index, 'blur')"
                                @compositionupdate="check(index, 'blur')"
                                @compositionend="check(index, 'blur')"
                                @blur="check(index, 'blur')"
                                @keyup="check(index, 'keyup')"
                            />
                            <span class="btn-clear" @click="reset(index)">清空</span>
                        </label>

                        <div class="tip">
                            <template v-if="undefined !== list[index].isOk">
                                <p v-if="list[index].isOk" class="success">通过</p>
                                <p v-else class="error">不通过</p>
                            </template>
                        </div>
                    </section>

                    <section class="trigger">
                        <h3>验证时机</h3>
                        <label> <input v-model="list[index].events.blur" type="checkbox" /> blur </label>

                        <label> <input v-model="list[index].events.keyup" type="checkbox" /> keyup </label>
                    </section>
                </li>
            </ul>
            <p v-else align="center">无数据</p>
        </article>
    </main>
</template>

<script>
import RULES from '@/RULES';
import ClipboardJS from 'clipboard';
export default {
    name: 'app',

    components: {},

    data() {
        Object.freeze(RULES);

        return {
            token: '',
            timer: null,
            keyword: '',
            rules: RULES,
            list: RULES.map(() => ({
                value: '',
                isOk: undefined,
                events: {
                    blur: true,
                    keyup: true,
                },
            })),
        };
    },

    mounted() {
        // this.$nextTick(() => {
        //     // 高亮
        //     this.$refs.code.forEach((block) => {
        //         console.log(block);
        //         /* eslint-disable */
        //         hljs.highlightBlock(block);
        //     });
        // });

        const clipboard = new ClipboardJS('.btn-copy');

        this.$on('hook:destroyed', () => {
            clipboard.destroy();
        });
        let timer = null;
        clipboard.on('success', (e) => {
            clearTimeout(timer);
            const el = e.trigger;
            if (el.classList.contains('success')) {
                el.classList.remove('success');
            }
            el.classList.add('success');
            timer = setTimeout(() => {
                el.classList.remove('success');
            }, 1000);
        });
    },

    methods: {
        parseExample(examples, counterExamples) {
            let arr = [`例如: ${examples.join(', ')}`];
            if (undefined !== counterExamples) {
                arr.push(`反例: ${counterExamples.join(', ')}`);
            }
            return arr.join(' , ');
        },

        search() {
            if ('' !== this.keyword) {
                this.rules = this.rules.filter(({ title }) => -1 !== title.toLowerCase().indexOf(this.keyword.toLowerCase()));
            } else {
                this.rules = RULES;
            }
            /* eslint-disable */
            _hmt.push(['_trackEvent', '交互', '搜索', '关键词', this.keyword]);
        },

        selectSearchInputText() {
            this.$refs.searchInput.select();
        },

        autoFocus(index) {
            this.$refs.input[index].focus();
        },
        /* eslint-disable */
        mouseenterHandler(index) {},

        // mouseenterHandler: throttle((index)=>{
        //    this.$refs.input[index].focus();
        // },1000).bind(this),

        reset(index) {
            this.$nextTick(() => {
                this.list[index].value = '';
                this.list[index].isOk = undefined;
            });
        },

        check(index, type) {
            const { events, value } = this.list[index];
            if ('' === value) this.reset(index);
            if (events[type]) {
                const { rule } = this.rules[index];
                const row = this.list[index];
                row.isOk = rule.test(row.value);
            }

            if ('blur' === type) {
                /* eslint-disable */
                _hmt.push(['_trackEvent', 'input框', this.rules[index].title, this.list[index].value]);
            }
        },
    },
};
</script>

<style lang="scss" scoped>
$primary: #42b983;
$danger: #ec5c51;

$radius: 4px;
@keyframes slide {
    from {
        top: 0;
    }
    to {
        top: 100px;
    }
}

@keyframes shrinkBorder {
    from {
        transform: translateY(-100%);
    }
    50% {
        width: 4px;
        opacity: 0.62;
    }

    to {
        left: 0;
        transform: translateY(0);
    }
}
main {
    font-family: 'Avenir', Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    max-width: 1000px;
    width: 100%;
    margin: auto;

    .fixed {
        position: fixed;
        z-index: 1986;
        right: 15px;
        bottom: 15px;
        > a {
            display: flex;
            border-radius: $radius;
            align-content: center;
            align-items: center;
            justify-content: center;
            justify-items: center;
            font-size: 16px;
            text-align: center;
            padding: 16px;
            box-shadow: 1px 2px 3px 1px rgba(0, 0, 0, 0.1);
            &:active {
                opacity: 0.6;
                box-shadow: none;
            }
            &:hover {
                opacity: 0.6;
            }
            &.github {
                background: rgba(#eee, 0.9);
                > span {
                    color: #000;
                    padding: 0 10px;
                }
            }
            &.message {
                background: rgba($primary, 0.9);
                color: #fff;
            }
        }
    }

    header {
        padding: 15px;
        position: sticky;
        top: 0;
        z-index: 99;
        background: linear-gradient(180deg, white 80%, transparent);
        > .search-input {
            display: block;
            margin-top: 15px;
            font-size: 16px;
            border: 1px solid #ddd;
            width: 100%;
            padding: 15px;
            border-radius: $radius;
            box-shadow: 1px 2px 2px rgba(0, 0, 0, 0.1);
        }

        // 标题
        > .github {
            display: inline-flex;
            align-items: center;
            color: #000;

            h1 {
                margin-left: 8px;
            }
        }
    }
    ul.list {
        padding: 15px;
        li {
            position: relative;
            overflow: hidden;
            border-radius: $radius;
            margin-bottom: 15px;
            padding: 15px;
            border-color: #eee;
            border-width: 1px;
            border-style: solid;
            box-shadow: 1px 2px 5px 1px rgba(0, 0, 0, 0.1);
            > .border {
                position: absolute;
                background: $primary;
                width: 4px;
                height: 100%;
                top: 0;
                left: -4px;
            }
            &:hover {
                background-color: #ddd;
                transition: all 600ms;
                border-radius: $radius;
                border-color: #eee;
                box-shadow: none;
                > .border {
                    animation: shrinkBorder 0.5s;
                    left: 0;
                }
            }
            > p.rule {
                margin-top: 15px;
                padding: 5px 15px;
                background: #eee;
                color: #000;
                border-radius: $radius;
                line-height: 2;
                > .btn-copy {
                    display: inline-block;
                    border-radius: $radius;
                    margin-right: 15px;
                    padding: 0 5px;
                    background: $primary;
                    color: #fff;
                    font-size: 12px;
                    cursor: pointer;
                    box-shadow: 1px 2px 3px $primary;
                    &.success {
                        &:after {
                            content: '复制成功';
                            border-radius: $radius;
                            display: block;
                            padding: 5px 15px;
                            background: rgba(0, 0, 0, 0.8);
                            color: #fff;
                            text-align: center;
                            position: absolute;
                        }
                    }
                    &:active {
                        opacity: 0.6;
                        box-shadow: none;
                    }

                    &:hover {
                        transition: all 0.3s;
                        color: rgba(255, 255, 255, 0.6)
                    }
                }

                > .btn-better {
                    @extend .btn-copy;
                    background-color: $danger;
                    box-shadow: 1px 2px 3px $danger;
                }

                > code {
                    word-break: break-word;
                }
            }

            > section.verification {
                margin-top: 15px;
                overflow: hidden;
                > label {
                    display: flex;
                    > input {
                        flex-grow: 1;
                        padding: 5px 15px;
                        border-radius: $radius;
                        border: 1px solid #ddd;
                        font-size: 16px;
                        & + .btn-clear {
                            cursor: pointer;
                            padding: 5px;
                            color: #000;
                            display: inline-block;
                            font-size: 14px;
                            &:active {
                                color: #ccc;
                            }
                            &:hover {
                                color: #666;
                            }
                        }
                    }
                }
                > .tip {
                    height: 24px;
                    padding: 5px;
                    > p {
                        font-size: 14px;
                        &.success {
                            color: #4caf50;
                        }

                        &.error {
                            color: #ff5722;
                        }
                    }
                }
            }

            > section.trigger {
                display: flex;
                align-items: center;
                align-content: center;
                h3 {
                    font-size: 14px;
                }
                > label {
                    padding: 0 10px;
                }
            }
        }
    }
}
</style>


================================================
FILE: packages/www/src/RULES.js
================================================
module.exports = [{
    title: '火车车次',
    rule: /^[GCDZTSPKXLY1-9]\d{1,4}$/,
    examples: ['G1868', 'D102', 'D9', 'Z5', 'Z24', 'Z17']
},
{
    title: '手机机身码(IMEI)',
    rule: /^\d{15,17}$/,
    examples: ['123456789012345', '1234567890123456', '12345678901234567']
},
{
    title: '必须带端口号的网址(或ip)',
    rule: /^((ht|f)tps?:\/\/)?[\w-]+(\.[\w-]+)+:\d{1,5}\/?$/,
    examples: ['https://www.qq.com:8080', '127.0.0.1:5050', 'baidu.com:8001', 'http://192.168.1.1:9090'],
    counterExamples: ['192.168.1.1', 'https://www.jd.com']
},
{
    // 参考: 
    // https://baike.baidu.com/item/%E9%A1%B6%E7%BA%A7%E5%9F%9F%E5%90%8D#4_1
    // https://baike.baidu.com/item/%E9%A1%B6%E7%BA%A7%E5%9F%9F%E5%90%8D#7
    // 也参考谷歌浏览器的地址栏, 如果输入非字母不会被识别为域名
    title: '网址(URL)',
    rule: /^(((ht|f)tps?):\/\/)?([^!@#$%^&*?.\s-]([^!@#$%^&*?.\s]{0,63}[^!@#$%^&*?.\s])?\.)+[a-z]{2,6}\/?/,
    examples: ['www.qq.com', 'https://vuejs.org/v2/api/#v-model', 'www.qq.99', '//www.qq.com', 'www.腾讯.cs', 'ftp://baidu.qq', 'http://baidu.com', 'https://www.amap.com/search?id=BV10060895&city=420111&geoobj=113.207951%7C29.992557%7C115.785782%7C31.204369&query_type=IDQ&query=%E5%85%89%E8%B0%B7%E5%B9%BF%E5%9C%BA(%E5%9C%B0%E9%93%81%E7%AB%99)&zoom=10.15', '360.com:8080/vue/#/a=1&b=2'],
    counterExamples: ['....']
},
{
    title: '统一社会信用代码',
    rule: /^[0-9A-HJ-NPQRTUWXY]{2}\d{6}[0-9A-HJ-NPQRTUWXY]{10}$/,
    examples: ['91230184MA1BUFLT44', '92371000MA3MXH0E3W'],
},
{
    title: '统一社会信用代码(宽松匹配)(15位/18位/20位数字/字母)',
    rule: /^(([0-9A-Za-z]{15})|([0-9A-Za-z]{18})|([0-9A-Za-z]{20}))$/,
    examples: ['91110108772551611J', '911101085923662400']
},
{
    title: '迅雷链接',
    rule: /^thunderx?:\/\/[a-zA-Z\d]+=$/,
    examples: ['thunder://QUEsICdtYWduZXQ6P3h0PXVybjpidGloOjBCQTE0RTUxRkUwNjU1RjE0Qzc4NjE4RjY4NDY0QjZFNTEyNjcyOUMnWlo='],
},

{
    title: 'ed2k链接(宽松匹配)',
    rule: /^ed2k:\/\/\|file\|.+\|\/$/,
    examples: ['ed2k://|file|%E5%AF%84%E7%94%9F%E8%99%AB.PARASITE.2019.HD-1080p.X264.AAC-UUMp4(ED2000.COM).mp4|2501554832|C0B93E0879C6071CBED732C20CE577A3|h=5HTKZPQFYRKORN52I3M7GQ4QQCIHFIBV|/'],
},

{
    title: '磁力链接(宽松匹配)',
    rule: /^magnet:\?xt=urn:btih:[0-9a-fA-F]{40,}.*$/,
    examples: ['magnet:?xt=urn:btih:40A89A6F4FB1498A98087109D012A9A851FBE0FC'],
},
{
    title: '子网掩码(不包含 0.0.0.0)',
    rule: /^(254|252|248|240|224|192|128)\.0\.0\.0|255\.(254|252|248|240|224|192|128|0)\.0\.0|255\.255\.(254|252|248|240|224|192|128|0)\.0|255\.255\.255\.(255|254|252|248|240|224|192|128|0)$/,
    examples: ['255.255.255.0', '255.255.255.255', '255.240.0.0']
},
{
    title: 'linux"隐藏文件"路径',
    rule: /^\/(?:[^/]+\/)*\.[^/]*/,
    examples: ['/usr/ad/.dd', '/root/.gitignore', '/.gitignore']
},
{
    title: 'linux文件夹路径',
    rule: /^\/(?:[^/]+\/)*$/,
    examples: ['/usr/ad/dd/', '/', '/root/', '/ a a / a / a a /']
},
{
    title: 'linux文件路径',
    rule: /^\/(?:[^/]+\/)*[^/]+$/,
    examples: ['/root/b.ts', '/root/abc']
},
{
    title: 'window"文件夹"路径',
    rule: /^[a-zA-Z]:\\(?:\w+\\?)*$/,
    examples: ['C:\\Users\\Administrator\\Desktop', 'e:\\m\\']
},
{
    title: 'window下"文件"路径',
    rule: /^[a-zA-Z]:\\(?:\w+\\)*\w+\.\w+$/,
    examples: ['C:\\Users\\Administrator\\Desktop\\qq.link', 'e:\\m\\vscode.exe']
},
{
    title: '股票代码(A股)',
    rule: /^(s[hz]|S[HZ])(000[\d]{3}|002[\d]{3}|300[\d]{3}|600[\d]{3}|60[\d]{4})$/,
    examples: ['sz000858', 'SZ002136', 'sz300675', 'SH600600', 'sh601155']
},
{
    title: '大于等于0, 小于等于150, 支持小数位出现5, 如145.5, 用于判断考卷分数',
    rule: /^150$|^(?:\d|[1-9]\d|1[0-4]\d)(?:\.5)?$/,
    examples: [150, 100.5]
},
{
    title: 'html注释',
    rule: /<!--[\s\S]*?-->/g,
    examples: ['<!--<div class="_bubble"></div>--><div>chenguzhen87</div><div class="_bubble"></div>-->']
},
{
    title: 'md5格式(32位)',
    rule: /^[a-fA-F0-9]{32}$/,
    examples: ['21fe181c5bfc16306a6828c1f7b762e8'],
},
{
    title: 'GUID/UUID',
    rule: /^[a-f\d]{4}(?:[a-f\d]{4}-){4}[a-f\d]{12}$/i,
    examples: ['e155518c-ca1b-443c-9be9-fe90fdab7345', '41E3DAF5-6E37-4BCC-9F8E-0D9521E2AA8D', '00000000-0000-0000-0000-000000000000'],
},
{
    title: '版本号(version)格式必须为X.Y.Z',
    rule: /^\d+(?:\.\d+){2}$/,
    examples: ['16.3.10']
},
{
    title: '视频(video)链接地址(视频格式可按需增删)',
    rule: /^https?:\/\/(.+\/)+.+(\.(swf|avi|flv|mpg|rm|mov|wav|asf|3gp|mkv|rmvb|mp4))$/i,
    examples: ['http://www.abc.com/video/wc.avi']
},
{
    title: '图片(image)链接地址(图片格式可按需增删)',
    rule: /^https?:\/\/(.+\/)+.+(\.(gif|png|jpg|jpeg|webp|svg|psd|bmp|tif))$/i,
    examples: ['https://www.abc.com/logo.png', 'http://www.abc.com/logo.png']
},
{
    title: '24小时制时间(HH:mm:ss)',
    rule: /^(?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/,
    examples: ['23:34:55']
},
{
    title: '12小时制时间(hh:mm:ss)',
    rule: /^(?:1[0-2]|0?[1-9]):[0-5]\d:[0-5]\d$/,
    examples: ['11:34:55'],
    counterExamples: ['23:34:55']
},
{
    title: 'base64格式',
    rule: /^\s*data:(?:[a-z]+\/[a-z0-9-+.]+(?:;[a-z-]+=[a-z0-9-]+)?)?(?:;base64)?,([a-z0-9!$&',()*+;=\-._~:@/?%\s]*?)\s*$/i,
    examples: ['data:image/gif;base64,xxxx==']
},
{
    title: '数字/货币金额(支持负数、千分位分隔符)',
    rule: /^-?\d{1,3}(,\d{3})*(\.\d{1,2})?$/ ,
    examples: [100, -0.99, 3, 234.32, -1, 900, 235.09, '12,345,678.90']
},
{
    title: '银行卡号(10到30位, 覆盖对公/私账户, 参考[微信支付](https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=22_1))',
    rule: /^[1-9]\d{9,29}$/,
    examples: [6234567890, 6222026006705354217]
},
{
    title: '中文姓名',
    rule: /^(?:[\u4e00-\u9fa5·]{2,16})$/,
    examples: ['葛二蛋', '凯文·杜兰特', '德克·维尔纳·诺维茨基']
},
{
    title: '英文姓名',
    rule: /(^[a-zA-Z][a-zA-Z\s]{0,20}[a-zA-Z]$)/,
    examples: ['James', 'Kevin Wayne Durant', 'Dirk Nowitzki']
},
{
    title: '车牌号(新能源)',
    rule: /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z](([DF]((?![IO])[a-zA-Z0-9](?![IO]))[0-9]{4})|([0-9]{5}[DF]))$/,
    examples: ['京AD92035', '甘G23459F', '京A19203D'],
},
{
    title: '车牌号(非新能源)',
    rule: /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]$/,
    examples: ['京A00599', '黑D23908']
},
{
    title: '车牌号(新能源+非新能源)',
    rule: /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{4,5}[A-HJ-NP-Z0-9挂学警港澳]$/,
    examples: ['京A12345D', '京A00599', '京AD92035', '甘G23459F', '京AA92035'],
    counterExamples: ['宁AD1234555555', '浙苏H6F681']
},
{
    title: '手机号(mobile phone)中国(严谨), 根据工信部最新公布的手机号段',
    rule: /^(?:(?:\+|00)86)?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[01256789]))\d{8}$/,
    examples: ['008618311006933', '+8617888829981', '19119255642', '19519255642']
},
{
    title: '手机号(mobile phone)中国(宽松), 只要是13,14,15,16,17,18,19开头即可',
    rule: /^(?:(?:\+|00)86)?1[3-9]\d{9}$/,
    examples: ['008618311006933', '+8617888829981', '19119255642']
},
{
    title: '手机号(mobile phone)中国(最宽松), 只要是1开头即可, 如果你的手机号是用来接收短信, 优先建议选择这一条',
    rule: /^(?:(?:\+|00)86)?1\d{10}$/,
    examples: ['008618311006933', '+8617888829981', '19119255642']
},
{
    title: '日期(宽松)',
    rule: /^\d{1,4}(-)(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31)$/,
    examples: ['1990-12-12', '1-1-1', '0000-1-1'],
    counterExamples: ['2020-00-01']
},

{
    title: '日期(严谨, 支持闰年判断)',
    rule: /^(([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29)$/,
    examples: ['1990-12-12', '2000-02-29'],
    counterExamples: ['2021-02-29']
},

{
    title: '中国省',
    rule: /^浙江|上海|北京|天津|重庆|黑龙江|吉林|辽宁|内蒙古|河北|新疆|甘肃|青海|陕西|宁夏|河南|山东|山西|安徽|湖北|湖南|江苏|四川|贵州|云南|广西|西藏|江西|广东|福建|台湾|海南|香港|澳门$/,
    examples: ['浙江', '台湾'],
    counterExamples: ['哈尔滨']
},

{
    title: '可以被moment转化成功的时间 YYYYMMDD HH:mm:ss',
    rule: /^\d{4}([/:-\S])(1[0-2]|0?[1-9])\1(0?[1-9]|[1-2]\d|30|31) (?:[01]\d|2[0-3]):[0-5]\d:[0-5]\d$/,
    examples: ['2020/01/01 23:59:59', '2020-01-01 00:00:00', '20200101 11:11:11'],
    counterExamples: ['2020/00/01 23:59:59', '2020-01/01 23:59:59', '2020-01-01 23:59:61', '2020-01-0100:00:00',]
},
{
    title: 'email(邮箱)',
    rule: /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
    examples: ['90203918@qq.com', 'nbilly@126.com', '汉字@qq.com']
},

{
    title: '座机(tel phone)电话(国内),如: 0341-86091234',
    rule: /^(?:(?:\d{3}-)?\d{8}|^(?:\d{4}-)?\d{7,8})(?:-\d+)?$/,
    examples: ['0936-4211235', '89076543', '010-12345678-1234']
},

{
    title: '身份证号(1代,15位数字)',
    rule: /^[1-9]\d{7}(?:0\d|10|11|12)(?:0[1-9]|[1-2][\d]|30|31)\d{3}$/,
    examples: ['123456991010193']
},
{
    title: '身份证号(2代,18位数字),最后一位是校验位,可能为数字或字符X',
    rule: /^[1-9]\d{5}(?:18|19|20)\d{2}(?:0[1-9]|10|11|12)(?:0[1-9]|[1-2]\d|30|31)\d{3}[\dXx]$/,
    examples: ['12345619991205131x']
},
{
    title: '身份证号, 支持1/2代(15位/18位数字)',
    rule: /^\d{6}((((((19|20)\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|(((19|20)\d{2})(0[13578]|1[02])31)|((19|20)\d{2})02(0[1-9]|1\d|2[0-8])|((((19|20)([13579][26]|[2468][048]|0[48]))|(2000))0229))\d{3})|((((\d{2})(0[13-9]|1[012])(0[1-9]|[12]\d|30))|((\d{2})(0[13578]|1[02])31)|((\d{2})02(0[1-9]|1\d|2[0-8]))|(([13579][26]|[2468][048]|0[048])0229))\d{2}))(\d|X|x)$/,
    examples: ['622223199912051311', '12345619991205131x', '123456991010193']
},
{
    title: '护照(包含香港、澳门)',
    rule: /(^[EeKkGgDdSsPpHh]\d{8}$)|(^(([Ee][a-fA-F])|([DdSsPp][Ee])|([Kk][Jj])|([Mm][Aa])|(1[45]))\d{7}$)/,
    examples: ['s28233515', '141234567', '159203084', 'MA1234567', 'K25345719']
},
{
    title: '帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线组合',
    rule: /^[a-zA-Z]\w{4,15}$/,
    examples: ['justin', 'justin1989', 'justin_666']
},
{
    title: '中文/汉字',
    // rule: /^[\u4E00-\u9FA5]+$/,
    rule: /^(?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])+$/,
    examples: ['正则', '前端']
},
{
    title: '小数(支持科学计数)',
    rule: /^[+-]?(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)$/,
    examples: ['0.0', '0.09','4E+4']
},
{
    title: '只包含数字',
    rule: /^\d+$/,
    examples: [12345678]
},
{
    title: 'html标签(宽松匹配)',
    rule: /<(\w+)[^>]*>(.*?<\/\1>)?/,
    examples: ['<div id="app"> 2333 </div>', '<input type="text">', '<br>']
},

{
    title: '匹配中文汉字和中文标点',
    rule: /[\u4e00-\u9fa5|\u3002|\uff1f|\uff01|\uff0c|\u3001|\uff1b|\uff1a|\u201c|\u201d|\u2018|\u2019|\uff08|\uff09|\u300a|\u300b|\u3008|\u3009|\u3010|\u3011|\u300e|\u300f|\u300c|\u300d|\ufe43|\ufe44|\u3014|\u3015|\u2026|\u2014|\uff5e|\ufe4f|\uffe5]/,
    examples: ["匹配中文汉字以及中文标点符号 。 ? ! , 、 ; : “ ” ‘ ' ( ) 《 》 〈 〉 【 】 『 』 「 」 ﹃ ﹄ 〔 〕 … — ~ ﹏ ¥"]
},

{
    title: 'qq号格式正确',
    rule: /^[1-9][0-9]{4,10}$/,
    examples: [903013545, 9020304]
},
{
    title: '数字和字母组成',
    rule: /^[A-Za-z0-9]+$/,
    examples: ['james666', 'haha233hi']
},
{
    title: '英文字母',
    rule: /^[a-zA-Z]+$/,
    examples: ['Russel']
},
{
    title: '小写英文字母组成',
    rule: /^[a-z]+$/,
    examples: ['russel']
},
{
    title: '大写英文字母',
    rule: /^[A-Z]+$/,
    examples: ['ABC', 'KD']
},
{
    title: '密码强度校验,最少6位,包括至少1个大写字母,1个小写字母,1个数字,1个特殊字符',
    rule: /^\S*(?=\S{6,})(?=\S*\d)(?=\S*[A-Z])(?=\S*[a-z])(?=\S*[!@#$%^&*? ])\S*$/,
    examples: ['Kd@curry666']
},
{
    title: '用户名校验,4到16位(字母,数字,下划线,减号)',
    rule: /^[\w-]{4,16}$/,
    examples: ['xiaohua_qq']
},
{
    title: 'ip-v4[:端口]',
    rule: /^((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.){3}(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])(?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$/,
    examples: ['172.16.0.0', '172.16.0.0:8080', '127.0.0.0', '127.0.0.0:998']
},
{
    title: 'ip-v6[:端口]',
    rule: /(^(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))$)|(^\[(?:(?:(?:[0-9A-Fa-f]{1,4}:){7}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}:[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){5}:([0-9A-Fa-f]{1,4}:)?[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){4}:([0-9A-Fa-f]{1,4}:){0,2}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){3}:([0-9A-Fa-f]{1,4}:){0,3}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){2}:([0-9A-Fa-f]{1,4}:){0,4}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){6}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(([0-9A-Fa-f]{1,4}:){0,5}:((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|(::([0-9A-Fa-f]{1,4}:){0,5}((\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b)\.){3}(\b((25[0-5])|(1\d{2})|(2[0-4]\d)|(\d{1,2}))\b))|([0-9A-Fa-f]{1,4}::([0-9A-Fa-f]{1,4}:){0,5}[0-9A-Fa-f]{1,4})|(::([0-9A-Fa-f]{1,4}:){0,6}[0-9A-Fa-f]{1,4})|(([0-9A-Fa-f]{1,4}:){1,7}:))\](?::(?:[0-9]|[1-9][0-9]{1,3}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5]))?$)/i,
    examples: ['2031:0000:130f:0000:0000:09c0:876a:130b', '[2031:0000:130f:0000:0000:09c0:876a:130b]:8080']
},
{
    title: '16进制颜色',
    rule: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3}|[a-fA-F0-9]{8}|[a-fA-F0-9]{4})$/,
    examples: ['#f00', '#F90', '#000', '#fe9de8', '#f8f8f8ff', '#f003']
},
{
    title: '微信号(wx),6至20位,以字母开头,字母,数字,减号,下划线',
    rule: /^[a-zA-Z][-_a-zA-Z0-9]{5,19}$/,
    examples: ['github666', 'kd_-666']
},
{
    title: '邮政编码(中国)',
    rule: /^(0[1-7]|1[0-356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[0-5]|8[013-6])\d{4}$/,
    examples: ['734500', '100101']
},
{
    title: '中文和数字',
    rule: /^((?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])|(\d))+$/,
    examples: ['哈哈哈', '你好6啊']
},
{
    title: '不能包含字母',
    rule: /^[^A-Za-z]*$/,
    examples: ['你好6啊', '@¥()!']
},
{
    title: 'java包名',
    rule: /^([a-zA-Z_]\w*)+([.][a-zA-Z_]\w*)+$/,
    examples: ['com.bbb.name']
},
{
    title: 'mac地址',
    rule: /^(([a-f0-9][0,2,4,6,8,a,c,e]:([a-f0-9]{2}:){4})|([a-f0-9][0,2,4,6,8,a,c,e]-([a-f0-9]{2}-){4}))[a-f0-9]{2}$/i,
    examples: ['38:f9:d3:4b:f5:51', '00-0C-29-CA-E4-66']
},
{
    title: '匹配连续重复的字符',
    rule: /(.)\1+/,
    examples: ['我我我', '112233', '11234']
},
{
    title: '数字和英文字母组成,并且同时含有数字和英文字母',
    rule: /^(?=.*[a-zA-Z])(?=.*\d).+$/,
    examples: ['我a我1我', 'a对1']
},
{
    title: '香港身份证 ',
    rule: /^[a-zA-Z]\d{6}\([\dA]\)$/,
    examples: ['K034169(1)']
},
{
    // 参考: 
    // https://baike.baidu.com/item/%E6%BE%B3%E9%97%A8%E5%B1%85%E6%B0%91%E8%BA%AB%E4%BB%BD%E8%AF%81/12509098?fr=aladdin#5
    title: '澳门身份证 ',
    rule: /^[1|5|7]\d{6}\(\d\)$/,
    examples: ['5686611(1)']
},
{
    title: '台湾身份证 ',
    rule: /^[a-zA-Z][0-9]{9}$/,
    examples: ['U193683453']
},
{
    title: '大写字母,小写字母,数字,特殊符号 `@#$%^&*`~()-+=` 中任意3项密码',
    rule: /^(?![a-zA-Z]+$)(?![A-Z0-9]+$)(?![A-Z\W_!@#$%^&*`~()-+=]+$)(?![a-z0-9]+$)(?![a-z\W_!@#$%^&*`~()-+=]+$)(?![0-9\W_!@#$%^&*`~()-+=]+$)[a-zA-Z0-9\W_!@#$%^&*`~()-+=]/,
    examples: ['a1@', 'A1@', 'Aa@']
},
{
    title: 'ASCII码表中的全部的特殊字符',
    rule: /[\x21-\x2F\x3A-\x40\x5B-\x60\x7B-\x7E]+/,
    examples: ["[", ".", "^", "&3%"]
},
{
    title: '正整数,不包含0',
    rule: /^\+?[1-9]\d*$/,
    examples: [1231]
},
{
    title: '负整数,不包含0',
    rule: /^-[1-9]\d*$/,
    examples: [-1231]
},
{
    title: '整数',
    rule: /^(?:0|(?:-?[1-9]\d*))$/,
    examples: [-1231, 123, 0],
    counterExamples: ['01']
},
{
    title: '浮点数',
    rule: /^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9]\d*|0\.0+)$/,
    examples: ["1.23", "-1.01", "0.00"]
    // allow "1.23", allow "-0.1", allow "0.00", ban "-0.00", ban "2.", allow "2.0"
},
{
    title: '浮点数(严格)',
    rule: /^(-?[1-9]\d*\.\d+|-?0\.\d*[1-9])$/,
    examples: ["1.23", "-1.01"]
    // allow "1.23", allow "-0.1", ban "2.", ban "2.0"
},
{
    title: 'email(支持中文邮箱)',
    rule: /^[A-Za-z0-9\u4e00-\u9fa5]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/,
    examples: ['90203918@qq.com', 'nbilly@126.com', '啦啦啦@126.com']
},

{
    title: '域名(非网址, 不包含协议)',
    rule: /^([0-9a-zA-Z-]{1,}\.)+([a-zA-Z]{2,})$/,
    examples: ['www.baidu.com',
        'baidu.com',
        'baidu.com.cn',
        'api.baidu.com',
        'nodejs.org',
        'nodejs.cn'],
    counterExamples: ['http://baidu.com', 'https://baidu.com', 'www.百度.com']
},

{
    title: '军官/士兵证',
    rule: /^[\u4E00-\u9FA5](字第)([0-9a-zA-Z]{4,8})(号?)$/,
    examples: ['军字第2001988号', '士字第P011816X号'],
},
{
    title: '户口薄',
    rule: /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/,
    examples: ['441421999707223115'],
},

];


================================================
FILE: packages/www/src/main.js
================================================
import Vue from 'vue'
import App from './App.vue'

Vue.config.productionTip = false

if ('serviceWorker' in navigator) {
    window.addEventListener('load', function() {
        navigator.serviceWorker.register('./sw.js');
    });
}

new Vue({
    render: h => h(App),
}).$mount('#app')

================================================
FILE: packages/www/vue.config.js
================================================
module.exports = {
  // publicPath: process.env.NODE_ENV === 'production'
  // ? '/any-rule/'
  // : '/'
}

================================================
FILE: scripts/genCommond.js
================================================
const RULES = require('../packages/www/src/RULES.js');
const pkg = require('../package.json');
const fs = require('fs');
const chalk = require('chalk');

pkg.activationEvents = ['*'];
pkg.contributes.commands = RULES.map((rule, index) => ({
    command: 'extension.rule' + index,
    title: `$(rocket) zz: ${rule.title}`
}));

pkg.contributes.commands.push({
    command: 'extension.rule.callByMenu',
    title: `🦕正则大全(${RULES.length}条)`
});

// console.log(JSON.stringify(pkg));
fs.writeFileSync('./package.json', JSON.stringify(pkg, null, 4), 'utf8');
console.log(chalk.green('🚀 pkg文件修改完毕, 请等待生成vsc包...'));

================================================
FILE: scripts/md.js
================================================
const fs = require('fs');
const chalk = require('chalk');
const json = require('../packages/www/src/RULES');
const VSC_URL = 'https://marketplace.visualstudio.com/items?itemName=russell.any-rule'
const badges = [
    // `![](https://img.shields.io/badge/状态-积极更新-673ab7.svg)`,

    `![已收录${json.length}条](https://img.shields.io/badge/已收录-${json.length}条-673ab7.svg)`,

    
    `[![版本](https://badgen.net/vs-marketplace/v/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule)`,

    `[![安装量](https://badgen.net/vs-marketplace/i/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule)`,

    `[![下载量](https://badgen.net/vs-marketplace/d/russell.any-rule)](https://marketplace.visualstudio.com/items?itemName=russell.any-rule)`,

    `![MIT](https://img.shields.io/badge/license-MIT-F44336.svg)`,

    `[![CircleCI](https://badgen.net/github/status/any86/any-rule/master/ci/circleci)](https://circleci.com/gh/any86/any-rule)`

    // vscode上传不让用svg
    // `[![Node CI](https://github.com/any86/any-rule/workflows/Node%20CI/badge.svg)](https://github.com/any86/any-rule/actions)`
];

let content = `# 正则大全  ${badges.join(' ')}

🦕支持**web** / **vscode** / **idea** / **Alfred Workflow**多平台

## :rocket:web版本
https://any-rule.vercel.app/

## 🍭vscode插件

### 安装
vscode应用商店中搜索"**any-rule**".

### 使用
**方式1:**

1. 按**F1**(mac下fn+F1)打开正则列表.
2. **输入关键词搜索**, 比如"手机".

![GIF](https://user-images.githubusercontent.com/8264787/146724787-888a8666-5d2a-4e5e-b383-aec7c53bd312.gif)

**方式2:**

右键选择"🦕正则大全".

![GIF](https://user-images.githubusercontent.com/8264787/146725447-4d92caed-2dd0-4f11-91d1-8da9cd8ff08b.gif)

**方式3:**

在代码任意位置输入"**@zz**".

![GIF](https://user-images.githubusercontent.com/8264787/146725402-30b34119-b709-4d49-adb2-af8dbb786d3b.gif)

## 👩‍🏫图解正则
<details>
<summary>查看详情</summary>
每次在any-rule中选择正则后会弹出提示, 可点击"🤖图解正则".

![image](https://user-images.githubusercontent.com/8264787/146726200-d97e48c3-df76-4531-8210-b6935fffb997.png)

点击后可以看到正则解析, 方便大家学习.

![image](https://user-images.githubusercontent.com/8264787/146726350-58166bf9-7f7f-4685-86aa-f055d0c0b914.png)

**注意**: 图解直接使用了https://regexper.com, 在此对作者表示敬意和感谢.
</details>

## 社区版本

社区版本非本人维护, 只是其他开发者使用了any-rule整理的正则内容, 如使用出现问题可直接与其开发者联系.

[idea版](https://github.com/zhoriya/idea-rule)

[Alfred Workflow版](https://github.com/cccyb/workflows)

[hyjs: 函数封装版](https://github.com/heiyehk/hyjs/tree/main/packages/utils)

[命令行版本](https://github.com/shenguanjiejie/workwork)

[uTools版本](https://github.com/trentlee0/utools-any-rule)

## :fire:关于PR
欢迎大家PR, 步骤如下:
1. **正则**请在**packages/www/src/RULES.js**中添加.
2. 运行\`npm run test:rules\`进行测试.
3. 运行\`npm run build:md\`更新**README.md**.
4. 请务必提交到**develop**分支.

在此感谢大家对**any-rule**做出的贡献! 

## 🍔正则
`;

json.forEach(({title, rule})=>{
    content+= `\r\n### ${title}\r\n`;
    content+= `\`\`\`javascript\r\n`;
    content+= `${rule}\r\n\`\`\`\r\n`;
});
fs.writeFileSync('./README.md',content,'utf-8');
console.log(chalk.green('生成完毕'));


================================================
FILE: src/extension.ts
================================================
// The module 'vscode' contains the VS Code extensibility API
// Import the module and reference it with the alias vscode in your code below
import {
	ExtensionContext
} from 'vscode';
const RULES: { title: string, rule: RegExp, examples: string[] }[] = require('../packages/www/src/RULES.js');
import useCommand from './useCommand';
import useQuickPick from './useQuickPick';
import useMenuCommand from './useMenuCommand';

export function activate(context: ExtensionContext) {
	useCommand(context, RULES);
	useQuickPick(context, RULES);
	useMenuCommand(context, RULES);
}

export function deactivate() { }


================================================
FILE: src/insertLog.ts
================================================
import axios from 'axios';
import {version ,env} from 'vscode';
import {getCodeLanguage,getExtensionVersion} from './shared';
const http = axios.create({
    baseURL: 'https://leancloud.cn:443/1.1/classes/',
    timeout: 1000,
    headers: {
        "X-LC-Id": "BKaqtaJScQuqKtkAyl5jeloo-gzGzoHsz",
        "X-LC-Key": "y41qiVPTwnzLIgbDcEzcwHit",
        "Content-Type": "application/json"
    }
});
/**
 * 插入日志
 */
export default function ({ rule, title, method }: { rule: string, title: string, method: string }) {
    const {language,machineId} = env;
    http.post('https://leancloud.cn:443/1.1/classes/Log', {
        vscodeVersion: version,
        codeLanguage: getCodeLanguage(),
        language,
        machineId,
        rule,
        title,
        extensionVersion:getExtensionVersion(),
        method
    });
};

================================================
FILE: src/interface.d.ts
================================================
export interface IRule {
    title: string;
    keywords?: string[];
    regex?: RegExp | string;
    rules?: IRule[];
    examples?: string[];
}

export interface Rule{
    title:string,
    rule:RegExp,
    examples:string[]
}

================================================
FILE: src/shared.ts
================================================
import { extensions, window} from 'vscode';

/**
 * 获取编程语言
 */
export function getCodeLanguage():string{
    return window.activeTextEditor ? window.activeTextEditor.document.languageId as string : '';
};

/**
 * 获取插件版本号
 */
export function getExtensionVersion():string|void {
    const e = extensions.getExtension('russell.any-rule');
    return e && e.packageJSON.version;
}

================================================
FILE: src/showResultMessage.ts
================================================
import { extensions, window, version, env, Uri, languages } from 'vscode';
import { getCodeLanguage, getExtensionVersion } from './shared'
import insertLog from './insertLog';

const BUTTON_FEEDBACK = '✋意见反馈';
const BUTTON_DIAGRAMMATIZE = '👩‍🏫图解正则';
const BUTTON_CANCEL = '关闭';

export default function (title: string, rule: string): void {
    // window.setStatusBarMessage(`已插入正则: "${title}", 点击查看更多🔥`)
    window.showInformationMessage(`已插入正则: "${title}"`, BUTTON_DIAGRAMMATIZE, BUTTON_FEEDBACK, BUTTON_CANCEL).then(value => {
        if (BUTTON_FEEDBACK === value) {
            insertLog({
                rule,
                title,
                method: BUTTON_FEEDBACK
            });
            const URL = Uri.parse(genGithubIssueURL(title));
            env.openExternal(URL);
        } else if (BUTTON_DIAGRAMMATIZE === value) {
            insertLog({
                rule,
                title,
                method: BUTTON_DIAGRAMMATIZE
            });
            const URL = Uri.parse(`https://regexper.com/#${rule}`);
            env.openExternal(URL);
        }
    });
}
// gihub issue模板
function genGithubIssueURL(title: string): string {
    const BASE_URL = 'https://github.com/any86/any-rule/issues/new';
    const TITLE = `title=[vscode feedback] ${title}`;
    //     const BODY = `body=### vscode version
    // ${version}    
    // ### extension version
    // ${getExtensionVersion()}
    // ### code language
    // ${getCodeLanguage()}
    // ### comment
    // 请留言...
    // `;
    return BASE_URL + '?' + TITLE;
}


================================================
FILE: src/test/runTest.ts
================================================
import * as path from 'path';

import { runTests } from 'vscode-test';

async function main() {
	try {
		// The folder containing the Extension Manifest package.json
		// Passed to `--extensionDevelopmentPath`
		const extensionDevelopmentPath = path.resolve(__dirname, '../../');

		// The path to test runner
		// Passed to --extensionTestsPath
		const extensionTestsPath = path.resolve(__dirname, './suite/index');

		// Download VS Code, unzip it and run the integration test
		await runTests({ extensionDevelopmentPath, extensionTestsPath });
	} catch (err) {
		console.error('Failed to run tests');
		process.exit(1);
	}
}

main();


================================================
FILE: src/test/suite/extension.test.ts
================================================
import * as assert from 'assert';
import { before } from 'mocha';

// You can import and use all API from the 'vscode' module
// as well as import your extension to test it
import * as vscode from 'vscode';
// import * as myExtension from '../extension';

suite('Extension Test Suite', () => {
	before(() => {
		vscode.window.showInformationMessage('Start all tests.');
	});

	test('Sample test', () => {
		assert.equal(-1, [1, 2, 3].indexOf(5));
		assert.equal(-1, [1, 2, 3].indexOf(0));
	});
});


================================================
FILE: src/test/suite/index.ts
================================================
import * as path from 'path';
import * as Mocha from 'mocha';
import * as glob from 'glob';

export function run(): Promise<void> {
	// Create the mocha test
	const mocha = new Mocha({
		ui: 'tdd',
	});
	mocha.useColors(true);

	const testsRoot = path.resolve(__dirname, '..');

	return new Promise((c, e) => {
		glob('**/**.test.js', { cwd: testsRoot }, (err, files) => {
			if (err) {
				return e(err);
			}

			// Add files to the test suite
			files.forEach(f => mocha.addFile(path.resolve(testsRoot, f)));

			try {
				// Run the mocha test
				mocha.run(failures => {
					if (failures > 0) {
						e(new Error(`${failures} tests failed.`));
					} else {
						c();
					}
				});
			} catch (err) {
				e(err);
			}
		});
	});
}


================================================
FILE: src/useCommand.ts
================================================
import { window, commands, Range, ExtensionContext } from "vscode";
import { Rule } from './interface';
import insertLog from './insertLog';
import showResultMessage from './showResultMessage';

export default function (context: ExtensionContext, RULES: Rule[]) {
    RULES.forEach(({ title, rule }, index) => {
        const ruleString = String(rule);
        const disposable = commands.registerCommand(`extension.rule${index}`, () => {
            const editor = window.activeTextEditor;
            if (editor) {
                const { selections } = editor;

                editor.edit(editBuilder => {
                    selections.forEach(selection => {
                        const { start, end } = selection;
                        const range = new Range(start, end);
                        editBuilder.replace(range, ruleString);
                    });
                });

                // 日志
                insertLog({
                    rule: ruleString,
                    title,
                    method: 'Command'
                });

                showResultMessage(title, ruleString);
            } else {
                window.showWarningMessage('any-rule: 只有在编辑文本的时候才可以使用!');
            }
        });
        context.subscriptions.push(disposable);
    });
}

================================================
FILE: src/useMenuCommand.ts
================================================
import { window, commands, Range, ExtensionContext } from "vscode";
import { Rule } from './interface';
import insertLog from './insertLog';
import showResultMessage from './showResultMessage';

export default function (context: ExtensionContext, RULES: Rule[]) {

    const disposable = commands.registerCommand(`extension.rule.callByMenu`, () => {
        // showQuickPick
        window.showQuickPick(RULES.map(({ examples, title, rule }) => {
            // const match = title.match(/\((.+)\)/);
            return {
                label: title,
                // description: null !== match ? match[1] : '',
                rule: String(rule), // 非标准字段, 仅仅为了传值
                detail: `例如: ${examples.join(' 或 ')}`
            };
        }), {
            placeHolder: '请输入关键词',
            // onDidSelectItem(item){
            // console.log(item)
            // }
        }).then(item => {
            if (!item) return

            const editor = window.activeTextEditor;
            if (editor) {
                const ruleString = String(item.rule);
                const title = item.label;
                const { selections } = editor;

                editor.edit(editBuilder => {
                    selections.forEach(selection => {
                        const { start, end } = selection;
                        const range = new Range(start, end);
                        editBuilder.replace(range, ruleString);
                    });
                });

                // 日志
                insertLog({
                    rule: ruleString,
                    title,
                    method: 'Menu'
                });

                showResultMessage(title, ruleString);
            }

        });


    });
    context.subscriptions.push(disposable);
}

================================================
FILE: src/useQuickPick.ts
================================================
import { ExtensionContext, workspace, languages, window, TextDocument, Position, Range, Selection } from "vscode";
import { Rule } from './interface';
// import { slugify } from 'transliteration';
import insertLog from './insertLog';
import showResultMessage from './showResultMessage';

export default function (context: ExtensionContext, RULES: Rule[]) {
    // commands.registerCommand('functions.insertRegex', insertRule);
    // 不确定是不是都兼容"*", 保守    
    let { supportedLanguages, triggerStringEnd } = getConfig();
    workspace.onDidChangeConfiguration(() => {
        const config = getConfig();
        supportedLanguages = config.supportedLanguages;
        triggerStringEnd = config.triggerStringEnd;
    });

    const disposable = languages.registerCompletionItemProvider(supportedLanguages.split(','), {
        provideCompletionItems(document, position) {
            const { triggerString } = getConfig();
            // 如果为空表示关闭
            if (!triggerString) return [];

            const linePrefix = document.lineAt(position).text.substr(0, position.character);
            if (!linePrefix.endsWith(triggerString)) return [];

            // 滞后执行
            setTimeout(() => {
                // showQuickPick
                window.showQuickPick(RULES.map(({ examples, title, rule }) => {
                    // const match = title.match(/\((.+)\)/);
                    return {
                        label: title,
                        // description: null !== match ? match[1] : '',
                        rule: String(rule), // 非标准字段, 仅仅为了传值
                        detail: `例如: ${examples.join(' 或 ')}`
                    };
                }), {
                    placeHolder: '请输入关键词',
                    // onDidSelectItem(item){
                    // console.log(item)
                    // }
                }).then(item => {
                    if (!item) return
                    insertRule(document, position, item.rule);

                    // 日志
                    insertLog({
                        rule: item.rule,
                        title: item.label,
                        method: 'QuickPick'
                    });
                    showResultMessage(item.label, item.rule);
                });
            }, 10)
            return [];
        },

        resolveCompletionItem(item) {
            return item;
        }
    }, triggerStringEnd);
    context.subscriptions.push(disposable);
}


function insertRule(document: TextDocument, position: Position, ruleString: string) {
    const { triggerString } = getConfig();

    const editor = window.activeTextEditor;
    if (void 0 === editor) return;
    editor.edit(editBuilder => {
        const line = document.lineAt(position);

        // 起始, "zz."前面的位置
        const startPostion = position.translate(0, -triggerString.length);

        editBuilder.replace(new Range(startPostion, position), ruleString);

        setTimeout(() => {
            // 全选正则字符串
            const endPostion = new Position(line.lineNumber, startPostion.character + ruleString.length);
            editor.selection = new Selection(startPostion, endPostion);
        }, 0);
    });
}

// 获取配置
function getConfig() {
    const configuration = workspace.getConfiguration();
    const { triggerString, supportedLanguages } = configuration['any-rule'];
    const { length } = triggerString;
    const triggerStringStart = triggerString.substr(0, length - 1);
    const triggerStringEnd = triggerString.substr(-1);
    console.log(supportedLanguages);
    return {
        triggerStringStart,
        triggerStringEnd,
        triggerString,
        // 预留
        supportedLanguages
    }
}


================================================
FILE: tsconfig.json
================================================
{
	"compilerOptions": {
		"module": "commonjs",
		"target": "es6",
		"outDir": "out",
		"lib": [
			"es6"
		],
		"sourceMap": true,
		"rootDir": "src",
		"strict": true   /* enable all strict type-checking options */
		/* Additional Checks */
		// "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */
		// "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */
		// "noUnusedParameters": true,  /* Report errors on unused parameters. */
	},
	"exclude": [
		"node_modules",
		".vscode-test"
	]
}


================================================
FILE: tslint.json
================================================
{
	"rules": {
		"no-string-throw": true,
		"no-unused-expression": true,
		"no-duplicate-variable": true,
		"curly": true,
		"class-name": true,
		"semicolon": [
			true,
			"always"
		],
		"triple-equals": true
	},
	"defaultSeverity": "warning"
}


================================================
FILE: webpack.config.js
================================================
// @ts-check

'use strict';

const path = require('path');

/**@type {import('webpack').Configuration}*/
const config = {
    target: 'node', // vscode extensions run in a Node.js-context 📖 -> https://webpack.js.org/configuration/node/

    entry: './src/extension.ts', // the entry point of this extension, 📖 -> https://webpack.js.org/configuration/entry-context/
    output: {
        // the bundle is stored in the 'dist' folder (check package.json), 📖 -> https://webpack.js.org/configuration/output/
        path: path.resolve(__dirname, 'out'),
        filename: 'extension.js',
        libraryTarget: 'commonjs2',
        devtoolModuleFilenameTemplate: '../[resource-path]'
    },
    devtool: 'source-map',
    externals: {
        vscode: 'commonjs vscode' // the vscode-module is created on-the-fly and must be excluded. Add other modules that cannot be webpack'ed, 📖 -> https://webpack.js.org/configuration/externals/
    },
    resolve: {
        // support reading TypeScript and JavaScript files, 📖 -> https://github.com/TypeStrong/ts-loader
        extensions: ['.ts', '.js']
    },
    module: {
        rules: [
            {
                test: /\.ts$/,
                exclude: /node_modules/,
                use: [
                    {
                        loader: 'ts-loader'
                    }
                ]
            }
        ]
    }
};

module.exports = config;
Download .txt
gitextract_h_p5umc3/

├── .circleci/
│   └── config.yml
├── .gitattributes
├── .github/
│   └── workflows/
│       └── nodejs.yml
├── .gitignore
├── .vscodeignore
├── CHANGELOG.md
├── LICENSE
├── README.md
├── __test__/
│   └── rule.js
├── package.json
├── packages/
│   └── www/
│       ├── .gitignore
│       ├── LICENSE
│       ├── babel.config.js
│       ├── package.json
│       ├── prettier.config.js
│       ├── public/
│       │   ├── index.html
│       │   ├── manifest.json
│       │   └── sw.js
│       ├── scripts/
│       │   └── demo.js
│       ├── src/
│       │   ├── App.vue
│       │   ├── RULES.js
│       │   └── main.js
│       └── vue.config.js
├── scripts/
│   ├── genCommond.js
│   └── md.js
├── src/
│   ├── extension.ts
│   ├── insertLog.ts
│   ├── interface.d.ts
│   ├── shared.ts
│   ├── showResultMessage.ts
│   ├── test/
│   │   ├── runTest.ts
│   │   └── suite/
│   │       ├── extension.test.ts
│   │       └── index.ts
│   ├── useCommand.ts
│   ├── useMenuCommand.ts
│   └── useQuickPick.ts
├── tsconfig.json
├── tslint.json
└── webpack.config.js
Download .txt
SYMBOL INDEX (21 symbols across 10 files)

FILE: __test__/rule.js
  constant RULES (line 2) | const RULES = require('../packages/www/src/RULES');
  function testOne (line 11) | function testOne(one) {

FILE: scripts/genCommond.js
  constant RULES (line 1) | const RULES = require('../packages/www/src/RULES.js');

FILE: scripts/md.js
  constant VSC_URL (line 4) | const VSC_URL = 'https://marketplace.visualstudio.com/items?itemName=rus...

FILE: src/extension.ts
  constant RULES (line 6) | const RULES: { title: string, rule: RegExp, examples: string[] }[] = req...
  function activate (line 11) | function activate(context: ExtensionContext) {
  function deactivate (line 17) | function deactivate() { }

FILE: src/interface.d.ts
  type IRule (line 1) | interface IRule {
  type Rule (line 9) | interface Rule{

FILE: src/shared.ts
  function getCodeLanguage (line 6) | function getCodeLanguage():string{
  function getExtensionVersion (line 13) | function getExtensionVersion():string|void {

FILE: src/showResultMessage.ts
  constant BUTTON_FEEDBACK (line 5) | const BUTTON_FEEDBACK = '✋意见反馈';
  constant BUTTON_DIAGRAMMATIZE (line 6) | const BUTTON_DIAGRAMMATIZE = '👩‍🏫图解正则';
  constant BUTTON_CANCEL (line 7) | const BUTTON_CANCEL = '关闭';
  function genGithubIssueURL (line 32) | function genGithubIssueURL(title: string): string {

FILE: src/test/runTest.ts
  function main (line 5) | async function main() {

FILE: src/test/suite/index.ts
  function run (line 5) | function run(): Promise<void> {

FILE: src/useQuickPick.ts
  method provideCompletionItems (line 18) | provideCompletionItems(document, position) {
  method resolveCompletionItem (line 58) | resolveCompletionItem(item) {
  function insertRule (line 66) | function insertRule(document: TextDocument, position: Position, ruleStri...
  function getConfig (line 88) | function getConfig() {
Condensed preview — 39 files, each showing path, character count, and a content snippet. Download the .json file or copy for the full structured content (98K chars).
[
  {
    "path": ".circleci/config.yml",
    "chars": 1135,
    "preview": "# Javascript Node CircleCI 2.0 configuration file\n#\n# Check https://circleci.com/docs/2.0/language-javascript/ for more "
  },
  {
    "path": ".gitattributes",
    "chars": 31,
    "preview": "packages/*/** linguist-vendored"
  },
  {
    "path": ".github/workflows/nodejs.yml",
    "chars": 290,
    "preview": "name: Node CI\n\non: [push]\n\njobs:\n  test:\n\n    runs-on: ubuntu-latest\n\n    steps:\n    - uses: actions/checkout@master\n   "
  },
  {
    "path": ".gitignore",
    "chars": 115,
    "preview": "out\nnode_modules\ncoverage\n.nyc_output\n.vscode-test/\n.idea\n.vscode\n.DS_Store\n*.vsix\nyarn-error.log\n.rpt2_cache\ndist\n"
  },
  {
    "path": ".vscodeignore",
    "chars": 149,
    "preview": ".vscode/**\n.vscode-test/**\nout/test/**\nsrc/**\n.gitignore\nvsc-extension-quickstart.md\n**/tsconfig.json\n**/tslint.json\n**/"
  },
  {
    "path": "CHANGELOG.md",
    "chars": 2325,
    "preview": "# 更新日志\n🚀 [提交问题](https://github.com/any86/any-rule/issues/new)\n\n### 0.3.18(2022-11-07)\n\n- 优化数字/货币金额(支持负数、千分位分隔符)\n- 优化小数(支"
  },
  {
    "path": "LICENSE",
    "chars": 1064,
    "preview": "MIT License\n\nCopyright (c) 2021 Russell\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof"
  },
  {
    "path": "README.md",
    "chars": 12951,
    "preview": "# 正则大全  ![已收录84条](https://img.shields.io/badge/已收录-84条-673ab7.svg) [![版本](https://badgen.net/vs-marketplace/v/russell.an"
  },
  {
    "path": "__test__/rule.js",
    "chars": 1364,
    "preview": "const chalk = require('chalk');\nconst RULES = require('../packages/www/src/RULES');\nlet failGroup = [];\n\n\nRULES.forEach("
  },
  {
    "path": "package.json",
    "chars": 14233,
    "preview": "{\n    \"name\": \"any-rule\",\n    \"publisher\": \"russell\",\n    \"displayName\": \"any-rule\",\n    \"description\": \"你要的\\\"正则\\\"都在这!\","
  },
  {
    "path": "packages/www/.gitignore",
    "chars": 214,
    "preview": ".DS_Store\nnode_modules\n/dist\n\n# local env files\n.env.local\n.env.*.local\n\n# Log files\nnpm-debug.log*\nyarn-debug.log*\nyarn"
  },
  {
    "path": "packages/www/LICENSE",
    "chars": 1062,
    "preview": "MIT License\n\nCopyright (c) 2019 any86\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof t"
  },
  {
    "path": "packages/www/babel.config.js",
    "chars": 53,
    "preview": "module.exports = {\n  presets: [\n    '@vue/app'\n  ]\n}\n"
  },
  {
    "path": "packages/www/package.json",
    "chars": 1116,
    "preview": "{\n  \"name\": \"any-rule\",\n  \"version\": \"0.1.0\",\n  \"private\": true,\n  \"scripts\": {\n    \"serve\": \"vue-cli-service serve\",\n  "
  },
  {
    "path": "packages/www/prettier.config.js",
    "chars": 164,
    "preview": "// prettier.config.js or .prettierrc.js\nmodule.exports = {\n    tabWidth: 4,\n    semi: true,\n    singleQuote: true,\n    a"
  },
  {
    "path": "packages/www/public/index.html",
    "chars": 2394,
    "preview": "<!DOCTYPE html>\n<html lang=\"en\">\n\n<head>\n    <meta charset=\"utf-8\">\n    <meta http-equiv=\"X-UA-Compatible\" content=\"IE=e"
  },
  {
    "path": "packages/www/public/manifest.json",
    "chars": 323,
    "preview": "{\n    \"short_name\": \"any-rule\",\n    \"name\": \"正则大全\",\n    \"icons\": [\n        {\n            \"src\": \"/any-rule/icon.png\",\n  "
  },
  {
    "path": "packages/www/public/sw.js",
    "chars": 0,
    "preview": ""
  },
  {
    "path": "packages/www/scripts/demo.js",
    "chars": 329,
    "preview": "var ghpages = require('gh-pages');\nconst shell = require('shelljs');\nconst chalk = require('chalk');\n\n// 发布\nghpages.publ"
  },
  {
    "path": "packages/www/src/App.vue",
    "chars": 15544,
    "preview": "<template>\n    <main>\n        <article class=\"fixed\">\n            <a\n                onclick=\"_hmt.push(['_trackEvent', "
  },
  {
    "path": "packages/www/src/RULES.js",
    "chars": 17396,
    "preview": "module.exports = [{\n    title: '火车车次',\n    rule: /^[GCDZTSPKXLY1-9]\\d{1,4}$/,\n    examples: ['G1868', 'D102', 'D9', 'Z5'"
  },
  {
    "path": "packages/www/src/main.js",
    "chars": 286,
    "preview": "import Vue from 'vue'\nimport App from './App.vue'\n\nVue.config.productionTip = false\n\nif ('serviceWorker' in navigator) {"
  },
  {
    "path": "packages/www/vue.config.js",
    "chars": 106,
    "preview": "module.exports = {\n  // publicPath: process.env.NODE_ENV === 'production'\n  // ? '/any-rule/'\n  // : '/'\n}"
  },
  {
    "path": "scripts/genCommond.js",
    "chars": 608,
    "preview": "const RULES = require('../packages/www/src/RULES.js');\nconst pkg = require('../package.json');\nconst fs = require('fs');"
  },
  {
    "path": "scripts/md.js",
    "chars": 2998,
    "preview": "const fs = require('fs');\nconst chalk = require('chalk');\nconst json = require('../packages/www/src/RULES');\nconst VSC_U"
  },
  {
    "path": "src/extension.ts",
    "chars": 608,
    "preview": "// The module 'vscode' contains the VS Code extensibility API\n// Import the module and reference it with the alias vscod"
  },
  {
    "path": "src/insertLog.ts",
    "chars": 826,
    "preview": "import axios from 'axios';\nimport {version ,env} from 'vscode';\nimport {getCodeLanguage,getExtensionVersion} from './sha"
  },
  {
    "path": "src/interface.d.ts",
    "chars": 228,
    "preview": "export interface IRule {\n    title: string;\n    keywords?: string[];\n    regex?: RegExp | string;\n    rules?: IRule[];\n "
  },
  {
    "path": "src/shared.ts",
    "chars": 376,
    "preview": "import { extensions, window} from 'vscode';\n\n/**\n * 获取编程语言\n */\nexport function getCodeLanguage():string{\n    return wind"
  },
  {
    "path": "src/showResultMessage.ts",
    "chars": 1555,
    "preview": "import { extensions, window, version, env, Uri, languages } from 'vscode';\nimport { getCodeLanguage, getExtensionVersion"
  },
  {
    "path": "src/test/runTest.ts",
    "chars": 637,
    "preview": "import * as path from 'path';\n\nimport { runTests } from 'vscode-test';\n\nasync function main() {\n\ttry {\n\t\t// The folder c"
  },
  {
    "path": "src/test/suite/extension.test.ts",
    "chars": 498,
    "preview": "import * as assert from 'assert';\nimport { before } from 'mocha';\n\n// You can import and use all API from the 'vscode' m"
  },
  {
    "path": "src/test/suite/index.ts",
    "chars": 739,
    "preview": "import * as path from 'path';\nimport * as Mocha from 'mocha';\nimport * as glob from 'glob';\n\nexport function run(): Prom"
  },
  {
    "path": "src/useCommand.ts",
    "chars": 1297,
    "preview": "import { window, commands, Range, ExtensionContext } from \"vscode\";\nimport { Rule } from './interface';\nimport insertLog"
  },
  {
    "path": "src/useMenuCommand.ts",
    "chars": 1788,
    "preview": "import { window, commands, Range, ExtensionContext } from \"vscode\";\nimport { Rule } from './interface';\nimport insertLog"
  },
  {
    "path": "src/useQuickPick.ts",
    "chars": 3688,
    "preview": "import { ExtensionContext, workspace, languages, window, TextDocument, Position, Range, Selection } from \"vscode\";\nimpor"
  },
  {
    "path": "tsconfig.json",
    "chars": 584,
    "preview": "{\n\t\"compilerOptions\": {\n\t\t\"module\": \"commonjs\",\n\t\t\"target\": \"es6\",\n\t\t\"outDir\": \"out\",\n\t\t\"lib\": [\n\t\t\t\"es6\"\n\t\t],\n\t\t\"source"
  },
  {
    "path": "tslint.json",
    "chars": 248,
    "preview": "{\n\t\"rules\": {\n\t\t\"no-string-throw\": true,\n\t\t\"no-unused-expression\": true,\n\t\t\"no-duplicate-variable\": true,\n\t\t\"curly\": tru"
  },
  {
    "path": "webpack.config.js",
    "chars": 1402,
    "preview": "// @ts-check\n\n'use strict';\n\nconst path = require('path');\n\n/**@type {import('webpack').Configuration}*/\nconst config = "
  }
]

About this extraction

This page contains the full source code of the any86/any-rule GitHub repository, extracted and formatted as plain text for AI agents and large language models (LLMs). The extraction includes 39 files (88.6 KB), approximately 33.4k tokens, and a symbol index with 21 extracted functions, classes, methods, constants, and types. Use this with OpenClaw, Claude, ChatGPT, Cursor, Windsurf, or any other AI tool that accepts text input. You can copy the full output to your clipboard or download it as a .txt file.

Extracted by GitExtract — free GitHub repo to text converter for AI. Built by Nikandr Surkov.

Copied to clipboard!