GIT
- 查看
git
被追踪的所有文件:From
-
master
分支
git ls-tree -r master --name-only
- 当前分支
git ls-tree -r HEAD --name-only
- git仓库clone默认只下载
master
分支,如果要抓取远程仓库其他分支,使用如下命令:
//抓取远程仓库dev分支代码
git check -b dev origin/dev
- git推送到远程仓库origin
//推送本地master到远程仓库origin/master
git push origin master
//推送本地dev到远程仓库origin/dev
git push origin dev
//删除远程分支关联
git remote rm origin
//关联远程分支
git remote add origin git@github.com:?????/????
有时候git add xxx
无法生肖,可能是.gitignore写得有问题,需要找出来到底哪个规则写错了,可以用git check-ignore命令检查:
$ git check-ignore -v App.class
.gitignore:3:*.class App.class
- git 撤销本地修改
- 如果本地修改未暂存:
git checkout -- file
- 如果本地修改已提交到暂存区:
//把暂存区的修改撤销掉(unstage),即回退到工作区
git reset HEAD file
//撤销工作区修改
git checkout -- file
Gradle
- 使用 bintray-release上传某一个
module
gradlew clean build module:bintrayUpload -PbintrayUser=why8n -PbintrayKey=BINTRAY_KEY -PdryRun=false
- 依赖方式
/* 单个依赖 */
compile group:'log4j', name:'log4j', version:'1.2.17'
// 简写 => compile 'log4j:log4j:1.2.17'
/* 以数组形式添加多个依赖*/
compile 'joda-time:joda-time:2.9.2', 'log4j:log4j:1.2.17'
/* 闭包形式,以添加额外配置*/
compile (group:'log4j', name:'log4j', version:'1.2.17'){
// ... 额外配置
}
/* 等价于 */
compile ('log4j:log4j:1.2.17'){
// ... 额外配置
}
-
annotationProcessor
只在编译的时候执行依赖的库,但是库最终不打包到apk中,
编译库中的代码没有直接使用的意义,也没有提供开放的api调用,最终的目的是得到编译库中生成的文件,供我们调用。
annotationProcessor 'com.whyn:injectmanifest-compiler:1.0.0'
-
provided,Android studio3.0中替换为 compileOnly
虽然也是编译时执行,最终不会打包到apk中,但是跟provided
apt/annotationProcessor
有着根本的不同。
- A 、B、C都是Library。
- A依赖了C,B也依赖了C
- App需要同时使用A和B
- 那么其中A(或者B)可以修改与C的依赖关系为Provided
A 这个 Library 实际上还是要用到 C 的,只不过它知道 B 那里也有一个 C,自己再带一个就显得多余了,等app开始运行的时候,A 就可以通过B 得到 C,也就是两人公用这个 C。所以自己就在和 B 汇合之前,假设自己有 C。如果运行的时候没有 C,肯定就要崩溃了。
总结一下, 是间接的得到了依赖的Library,运行的时候必须要保证这个Library的存在,否则就会崩溃,起到了避免依赖重复资源的作用。provided
-
compileOnly
compileOnly
跟annotationProcessor
和provided
差不多,也是只在编译期进行依赖,只是compileOnly
是用于 Java 项目(Java 插件默认集成这个功能),而annotationProcessor
和provided
是用于 Android 项目。
//annotation processor module: build.gradle
compileOnly project(':injectmanifest-annotations') //only runs in compile time
//app: build.gradle
annotationProcessor project(':injectmanifest-compiler')
provided project(':injectmanifest-annotations') //assume app compile module injectmanifest-annotations,because module injectmanifest-compiler already compile injectmanifest-annotations
更多依赖配置信息,请查看:
Android Studio3.x新的依赖方式(implementation、api、compileOnly)
Vim
vim:
dt) -- 删除到)(不包含))
df) -- 删除到)(包含))
查找文件
.vimrc --> set path+=**
:find xxx
查看当前文件名:
:echo expand("%") or <Ctrl>+g
补全
^x^n -- auto complete in this file
^x^f -- for filename
^x^] -- for tag only
^n -- for anything specified by the "complete" option
: % 起始和结束范围是整个文件
:%d 删除掉整个文件内容,d是delete简写
:!javac % %表示当前文件
'
——上一次跳转前的位置
"
——上一次退出文件时的位置
.
—— 上一次修改的位置
[
——上一次修改的开始处
]
——上一次修改的结尾处
normal 模式下,在路径处,输入gf
就会跳转到对应文件内,<C-o> 回退到原先文件,<C-i> 回到前一个文件。
我们所输入过的EX命令,vim都会自动的保存下来,在普通模式下输入 q:
:help key-notation 查看 key mapping
不允许修改文件(只读模式)::set nomodifiable
== set noma
可以修改文件(读写模式):set modifiable
== set ma
vim编码涉及的基本概念
encoding变量:该选项使用于缓冲的文本(你正在编辑的文件)、寄存器、Vim脚本文件等等。你可以把 ‘encoding’ 选项当作是对 Vim 内部运行机制的设定。
encoding变量的默认值与系统当前locale相同。
fileencoding变量:该选项是vim写入文件时采用的编码类型。
vim打开文件时自动辨认其编码,fileencoding就为辨认的值。为空则保存文件时采用encoding的编码,如果没有修改encoding,那值就是系统当前locale了。
termencoding变量:该选项代表输出到客户终端(Term)采用的编码类型。
默认空值,也就是输出到终端不进行编码转换。
vim:
删除空行:g:/^\s*$/d
解释:^ 行开头
\s: 非字符
*: 0个或多个
$: 行结尾
综合:0个或多个非字符开头,一直到行结尾
vim command模式执行normal模式命令:
:execute "normal! mqA;<esc>`q"
vim command 模式执行函数:
:echo has('gui_running')
如果写脚本时,有重要的消息要显示给用户,需要使用 echomsg 或者 echoerr 这个两个命令。它们显示的消息都会记录在 message-history 里面。前者用于普通消息,后者用于错误。
那么想要完整显示信息,则输入::message
不退出编辑界面就可以在只读模式下强制将当前内容以管理员权限输入到当前文件::w !sudo tee %
删除 DOS 的换行符 ^M::%s/\r//g
了解 vim script 的基本语法( vim 里输入 :help usr_41.txt )。