npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

vve-statsvn

v2.2.7

Published

node state svn

Downloads

18

Readme

vve-statsvn-cli

npm NPM downloads

统计svn项目新增代码行数

特性

  • 支持集成进由npm管理的项目
  • 支持根据时间范围统计
  • 支持指定代码提交者
  • 支持多个svn项目统计, 支持本地检出目录或线上地址
  • 支持单项目多个SVN路径统计
  • 支持指定SVN线上地址统计,无需检出项目

安装

先确保系统已安装svn,可以在终端上输入以下命令确认是否安装成功

svn help

使用npm安装:

$ npm install vve-statsvn

使用

在package.json添加

"scripts": {
  "statsvn": "vve-statsvn-cli"
}

然后 npm run statsvn

参数

命令行指定参数


program
  .version(require('../package.json').version)
  .option("--cwd <path>", "工作目录")
  .option(
    "--svn-url <path>",
    "如果配置,则svn log 和 svn diff 则取的svn路径是以此路径为准"
  )
  .option(
    "--svn-username <name>",
    "svn用户名,为空表示如果不需要认证或者使用系统认证缓存信息"
  )
  .option(
    "--svn-password <password>",
    "svn密码,为空表示如果不需要认证或者使用系统认证缓存信息"
  )
  .option(
    "--disable-auth-cache",
    "是否缓存认证信息,如果为true,当前机器将不缓存当前用户信息"
  )
  .option(
    "--sub-path <path>",
    "在配置svnUrl生效,配置subPath,则在cwd目录创建subPath目录,在此目录下,存放statsvnTmp等缓存文件"
  )
  .option(
    "--auto-sub-path",
    "在配置svnUrl生效,是否根据svnUrl自动在cwd目录下创建目录,创建目录名根据url生成,存放statsvnTmp等文件,如果为true,则subPath失效"
  )
  .option(
    "--svn-project-paths <items>",
    "多项目svn的完整路径,用逗号隔开",
    commaSeparatedList
  )
  .option(
    "--sub-svn-paths <items>",
    "单项目多SVN路径,使用相对路径,用逗号隔开",
    commaSeparatedList
  )
  .option(
    "--ingore-paths <items>",
    "忽略的路径,满足minimatch规范,用逗号隔开",
    commaSeparatedList
  )
  .option(
    "--author <name>",
    "作者"
  )
  .option(
    "--svn-revision-arg <name>",
    "svn log -r 参数(优先于svnStartDayTime和svnEndDayTime使用)"
  )
  .option(
    "--svn-start-day-time <name>",
    "svn log -r {}:{} 开始时间"
  )
  .option(
    "--svn-end-day-time <name>",
    "svn log -r {}:{} 结束时间"
  )
  .option(
    "--max-line-threshold <number>",
    "最大行数阈值,如果一个文件超过最大行数,则不处理他的新增行数信息 0代表不限制"
  )
  .option(
    "--del-tmp-after-run-single",
    "统计完一个svn项目的删除临时目录"
  )
  .option(
    "--disable-cache-for-some-cmd",
    "某些命令不缓存,比如svn log和svn info, 因为这些命令在相同参数下随着时间推移返回的结果会不一样"
  )
  .option("--debug", "是否开启debug")
  .option("--out-dir <path>", "输出目录")
  .option("--out-csv", "是否输出csv")
  .option(
    "--config <path>",
    "配置文件的路径,没有配置,默认路径是在${cwd}/vve-statsvn-cli.config.js"
  )
  .option("--disable-config-file", "是否取配置文件")
  .parse(process.argv);

配置文件指定参数

默认配置文件在${cwd}/vve-statsvn-cli.config.js,样例内容如下所示

module.exports = {
  outDir: '.'
}

默认值


const config = {
  // 工作目录
  cwd: ".",
  // 配置文件的路径,没有配置,默认路径是在${cwd}/vve-statsvn-cli.config.js
  config: undefined,
  // 是否取配置文件
  disableConfigFile: false,
  // 输出的目录
  outDir: '',
  // 是否输出csv文件
  outCsv: false,
  // 是否开启debug
  debug: false,
  // 如果配置,则svn log 和 svn diff 则取的svn路径是以此路径为准
  svnUrl: '',
  // svn用户名,为空表示如果不需要认证或者使用系统认证缓存信息
  svnUsername: '',
   // svn密码,为空表示如果不需要认证或者使用系统认证缓存信息
  svnPassword: '',
  // 是否缓存认证信息,如果为true,当前机器将不缓存当前用户信息
  disableAuthCache: false,
  // 在配置svnUrl生效,配置subPath,则在cwd目录创建subPath目录,在此目录下,存放statsvnTmp等缓存文件
  subPath: '',
  // 在配置svnUrl生效,是否根据svnUrl自动在cwd目录下创建目录,创建目录名根据url生成,存放statsvnTmp等文件,如果为true,则subPath失效
  autoSubPath: false, 
  // svn项目,如果传数组,则优先级比cwd和subSvnPaths更高,则不统计当前svn目录${cwd}/${rootDir}
  svnProjectPaths: [],
  // 仅统计项目下subSvnPaths指定的svn目录
  subSvnPaths: [],
  // 忽略的路径
  ingorePaths: [
    'npm-shrinkwrap.json',
    '**/dist/**',
    'dist/**',
    '**/node_module/**',
    'node_module/**',
    '*.gz',
    '**/*.gz',
    '**/*.jpg', '**/*.jpeg', '**/*.png', '**/*.svg', '**/*.eot', '**/*.ttf', '**/*.woff', '**/*.woff2', '**/*.gif',
    '*.jpg', '*.jpeg', '*.png', '*.svg', '*.eot', '*.ttf', '*.woff', '*.woff2', '*.gif',
  ],
  // author 作者
  author: '',
  // svn log -r 参数(优先于svnStartDayTime和svnEndDayTime使用)
  svnRevisionARG: '',
  // svn log -r {}:{} 开始时间
  svnStartDayTime: undefined, // moment().format("YYYY-MM-DD 00:00:00"), // 默认当天开始时间
  // svn log -r {}:{} 结束时间
  svnEndDayTime: undefined, // moment().format("YYYY-MM-DD 23:59:59"), // 默认当天结束时间
  // 最大行数阈值,如果一个文件超过最大行数,则不处理他的新增行数信息 0代表不限制
  maxLineThreshold: 0,
  // 统计完一个svn项目的删除临时目录
  delTmpAfterRunSingle: false,
  // 如果为true, 某些命令不缓存,比如svn log和svn info, 因为这些命令在相同参数下随着时间推移返回的结果会不一样
  disableCacheForSomeCmd: false,
}

开发

  • node >= 10
npm i // 安装依赖
npm test // 测试
npm run release // 发布
git push --follow-tags origin master && npm publish // npm 发布

捐赠

如果你觉得它有用,你可以给我买一杯奶茶。

关于生成的缓存文件

执行npm run statsvn 后,会在项目目录下生成一些缓存文件,请将以下内容添加至svn忽略文件中。如果svn和git混用,可将以下内容一并加入.gitignore文件中。

statsvn-debug-return-log.json
statsvn-output.txt
statsvn-output.csv
statsvnTmp/

统计原理介绍

纯新增代码,如:

+void foo() {
+    ... ...
+}

纯删除代码,如:

-void foo() {
-    ... ...
-}

修改的代码,如:

-void foo(void);
+void foo(int);

我们所要统计的所谓有效代码更多是指纯新增的代码和修改的代码,纯删除的代码可忽略不计。这样一来实际有效代码行数 = 纯新增代码行数 + 修改代码行数;而修改的代码在svn diff结果中体现为一减一加,实际修改行数是等于其+的行数的。也就是说有效代码行数就是svn diff结果中所有前缀为+的行的行数。再配合svn log查询出历史提交的每一次的版本的文件,叠加每个版本每个文件经过svn diff计算出的有效代码行数即为最终的新增代码函数。