Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
为满足所写的代码能同时运行于server环境和web环境,而不需手动修改,所以做了个转换方法,使得几者之间的模块能够互相等价转化。
需要注意的是AMD模块的写法应遵守文件和模块一对一的原则。
ranma取自同名动漫人物乱马,意指同一个事物的不同形式。
npm install ranma
ranma.cjsify(code:String):String
将代码转换为CommonJS
对于AMD和CMD,会将define的factory提取,改写return为module.exports并删除define,如果define父语句有if判断也会删除
对于普通文件,会将全局声明的变量作为exports,全局使用的未声明变量作为require
ranma.amdify(code:String):String
将代码转换为AMD
在cjsify的基础上进行define包裹
如果代码是CMD不做修改,因为AMD兼容这种写法
ranma.cmdify(code:String):String
将代码转换为CMD
在cjsify的基础上进行define包裹
如果code是AMD类型,会进行依赖转化——即将factory的参数改为CMD的require, exports, module固定参数,同时依赖变为require变量声明
ranma.type.isCommonJS(code:String):Boolean
code是否是CommonJS
ranma.type.isAMD(code:String):Boolean
code是否是AMD
ranma.type.isCMD(code:String):Boolean
code是否是CMD
[MIT License]
FAQs
A converter between CommonJS/AMD/CMD/other
The npm package ranma receives a total of 2 weekly downloads. As such, ranma popularity was classified as not popular.
We found that ranma demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.