{ git }

  • 关于git提示"warning LF will be replaced by CRLF"终极解答

    | /

    一、发现问题

    windows平台下使用git add,git deploy 文件时经常出现“warning: LF will be replaced by CRLF” 的提示。

    网上很多解决办法提到:

    设置core.autocrlf=false,windows也用LF换行。
    除了记事本,其他编辑器都可以正常编辑。
    而没有给出具体原因和分析,现在加以补充。

    二、分析问题

    格式化与多余的空白字符,特别是在跨平台情况下,有时候是一个令人发指的问题。由于编辑器的不同或者文件行尾的换行符在 Windows 下被替换了,一些细微的空格变化会不经意地混入提交,造成麻烦。虽然这是小问题,但它会极大地扰乱跨平台协作。
    其实,这是因为在文本处理中,CRCarriageReturn),LFLineFeed),CR/LF是不同操作系统上使用的换行符,具体如下:

    换行符‘\n’和回车符‘\r’
    • 回车符就是回到一行的开头,用符号r表示,十进制ASCII代码是13,十六进制代码为0x0D,回车(return);
    • 换行符就是另起一行,用n符号表示,ASCII代码是10,十六制为0x0A, 换行(newline)。

    所以我们平时编写文件的回车符应该确切来说叫做回车换行符。

  • git删除所有Commits提交历史记录,变为全新仓库

    | /

    个人感觉一般两个情况下,会想有这个需要:

    • 一个是:需要把旧项目提交到Git上,但是原来的某版历史记录中可能会有项目密码等敏感信息。这时候需要删除这些历史记录,形成一个全新的仓库,并且希望保持代码不变。

    • 另一个是:处女座!隔三差五看到过往的Commits心烦,没有原因。

    1. Checkout

    新建一个branch

    1
    git checkout --orphan latest_branch

    2. Add all the files

    1
    git add -A

    3. Commit the changes