breaking:
use:
- FILE
lint:
use: - DEFAULT
name
代表了这个工程的名字,deps
则表示了他依赖的proto的工程名。基于这份yaml
内容,我们就可以大概确定一个proto工程编译需要的基础条件。然后我们只需要一个工具或者插件来帮助我们生成对应的工程就够了。
模板工程
现在我们基本已经有了一个单一的proto
工程的输入模型了,其中包含工程名依赖的工程还有对应文件夹下的proto
文件。然后我们就可以基于这部分输入的模型,生成出第一个模板工程。
plugins {
id ‘java-library’
id ‘org.jetbrains.kotlin.jvm’
id ‘com.google.protobuf’
}
java {
sourceCompatibility = JavaVersion.VERSION_1_8
targetCompatibility = JavaVersion.VERSION_1_8
}
sourceSets {
def dirs = new ArrayList()
dirs.add(“src/main/proto”)
main.proto.srcDirs = dirs
}
protobuf {
protoc {
if (System.getProperty(“os.arch”).compareTo(“aarch64”) == 0) {
artifact = “com.google.protobuf:protoc:KaTeX parse error: Expected 'EOF', got '}' at position 40: …c:osx-x86\_64" }̲ else { artifac…version_protobuf_protoc”
}
}
plugins {
grpc {
if (System.getProperty(“os.arch”).compareTo(“aarch64”) == 0) {
artifact = ‘io.grpc:protoc-gen-grpc-java:1.36.1:osx-x86_64’
} else {
artifact = ‘io.grpc:protoc-gen-grpc-java:1.36.1’
}
}
}
generateProtoTasks {
all().each { task ->
task.generateDescriptorSet = true
task.builtins {
// In most cases you don’t need the full Java output
// if you use the lite output.
java {
}
}
task.plugins {
grpc { option ‘lite’ }
}
}
}
}
afterEvaluate {
project.tasks.findByName(“compileJava”).dependsOn(tasks.findByName(“generateProto”))
project.tasks.findByName(“compileKotlin”).dependsOn(tasks.findByName(“generateProto”))
}
dependencies {
implementation “org.glassfish:javax.annotation:10.0-b28”
def grpcJava = ‘1.36.1’
compileOnly “io.grpc:grpc-protobuf-lite:
g
r
p
c
J
a
v
a
"
c
o
m
p
i
l
e
O
n
l
y
"
i
o
.
g
r
p
c
:
g
r
p
c
−
s
t
u
b
:
{grpcJava}" compileOnly "io.grpc:grpc-stub:
grpcJava"compileOnly"io.grpc:grpc−stub:{grpcJava}”
compileOnly “io.grpc:grpc-core:${grpcJava}”
File file = new File(projectDir, “depend.txt”)
if (!file.exists()) {
return
}
def lines = file.readLines()
if (lines.isEmpty()) {
return
}
lines.forEach {
logger.lifecycle(“project:” + name + " implementation: " + it)
implementation(it)
}
}
如果需要将proto
编译成java代码,就需要依赖于com.google.protobuf
插件,依赖于上面的build.gradle
基本就可以将一个proto
输入编译成一个jar
工程。
另外我们需要把所有的proto
文件拷贝到这个壳工程的src/main/proto
文件夹下,最后我们会将buf.yaml
中的name: buf.xxx.co/xxx/xxxxxx
的/xxx/xxxxxx
转化成工程名,去除掉一些无法识别的字符。
我们生成的模板工程如下:
其中proto.version
会记录proto
内的gitsha
值还有文件的lastModified
时间,如果输入发生变更则会重新进行一次文件拷贝操作,避免重复覆盖的风险。
input.txt
则包含了所有proto
文件路径,方便我们进行开发调试。
deps 转化
由于proto
之间存在依赖,没有依赖则会导致无法将proto
转化成java
。所以这里我讲buf.yaml
中读取出的deps
转化成了一个depend.txt
.
com.xxxx.api:google-protobuf:7.7.7
depend.txt
内会逐行写入当前模块的依赖,我们会对name进行一次转化,变成一个可读的gradle
工程名。其中7.7.7
的版本只是一个缺省而已,并没有实际的价值。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数HarmonyOS鸿蒙开发工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年HarmonyOS鸿蒙开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上HarmonyOS鸿蒙开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注鸿蒙获取)
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-Ic5EY0i2-1712692900688)]
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!