-
使用 bintray-release上传某一个
module
gradlew clean build module:bintrayUpload -PbintrayUser=why8n -PbintrayKey=BINTRAY_KEY -PdryRun=false -
查看
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
-
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:
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 % %表示当前文件
' ——上一次跳转前的位置
" ——上一次退出文件时的位置
[ ——上一次修改的开始处
] ——上一次修改的结尾处
我们所输入过的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个或多个非字符开头,一直到行结尾
网友评论