使用swagger-codegen-plugin时避免生成build.gradle

问题描述 投票:1回答:1

我们正在使用gradle.plugin.org.detoeuf:swagger-codegen-plugin。我们要在输出目录中更改build.gradle文件的内容。

[我们将gradle.build文件添加到.swagger-codegen-ignore,但是每次调用swagger任务时,都会重新创建.swagger-codegen-ignore文件和gradle.build文件。

我们的招摇部分看起来像这样

swagger {
    inputSpec = "${project.projectDir}/swagger/backoffice-service-api-swagger.json"
    outputDir = file("${project.projectDir}/../backoffice-service-api-client/")
    lang = 'java'
    additionalProperties = [
            'invokerPackage'         : 'com.aaa.bbb.backoffice.service',
            'modelPackage'           : 'com.aaa.bbb.backoffice.service.model',
            'apiPackage'             : 'com.aaa.bbb.backoffice.service.api',
            'dateLibrary'            : 'joda',
            'groupId'                : 'com.aaa.bbb',
            'artifactId'             : 'backoffice-service-api-client',
            'artifactVersion'        : '1.0.0',
            'hideGenerationTimestamp': 'true',
            'dateLibrary'            : 'java8'
    ]
    systemProperties = ["apiTests" : "false"]
}

。swagger-codegen-ignore文件看起来像这样-

# Swagger Codegen Ignore
# Generated by swagger-codegen https://github.com/swagger-api/swagger-codegen

# Use this file to prevent files from being overwritten by the generator.
# The patterns follow closely to .gitignore or .dockerignore.

# As an example, the C# client generator defines ApiClient.cs.
# You can make changes and tell Swagger Codgen to ignore just this file by uncommenting the following line:
#ApiClient.cs

# You can match any string of characters against a directory, file or extension with a single asterisk (*):
#foo/*/qux
# The above matches foo/bar/qux and foo/baz/qux, but not foo/bar/baz/qux

# You can recursively match patterns against a directory, file or extension with a double asterisk (**):
#foo/**/qux
# This matches foo/bar/qux, foo/baz/qux, and foo/bar/baz/qux

# You can also negate patterns with an exclamation (!).
# For example, you can ignore all files in a docs folder with the file extension .md:
#docs/*.md
# Then explicitly reverse the ignore rule for a single file:
#!docs/README.md
build.gradle

build.gradle swagger-codegen
1个回答
0
投票

您可以在附加属性中添加ignoreFileOverride选项,如下所示。 ignoreFileOverride选项中提供的文件在项目中不存在,然后swagger-codegen将生成它们,如果项目中存在文件,则swagger-codegen将忽略它们。

swagger {
    inputSpec = "${project.projectDir}/swagger/backoffice-service-api-swagger.json"
    outputDir = file("${project.projectDir}/../backoffice-service-api-client/")
    lang = 'java'
    additionalProperties = [
            'invokerPackage'         : 'com.aaa.bbb.backoffice.service',
            'modelPackage'           : 'com.aaa.bbb.backoffice.service.model',
            'apiPackage'             : 'com.aaa.bbb.backoffice.service.api',
            'dateLibrary'            : 'joda',
            'groupId'                : 'com.aaa.bbb',
            'artifactId'             : 'backoffice-service-api-client',
            'artifactVersion'        : '1.0.0',
            'hideGenerationTimestamp': 'true',
            'dateLibrary'            : 'java8',
            'ignoreFileOverride'     : '.swagger-codegen-ignore,build.gradle'
    ]
    systemProperties = ["apiTests" : "false"]
}
© www.soinside.com 2019 - 2024. All rights reserved.