Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* Copyright 2016-2023 DiffPlug
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.diffplug.gradle.spotless;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import javax.inject.Inject;
import com.diffplug.spotless.FormatterStep;
import com.diffplug.spotless.json.JacksonJsonConfig;
import com.diffplug.spotless.json.JacksonJsonStep;
import com.diffplug.spotless.json.JsonPatchStep;
import com.diffplug.spotless.json.JsonSimpleStep;
import com.diffplug.spotless.json.gson.GsonStep;
import com.diffplug.spotless.rome.BiomeFlavor;
public class JsonExtension extends FormatExtension {
private static final int DEFAULT_INDENTATION = 4;
private static final String DEFAULT_GSON_VERSION = "2.10.1";
private static final String DEFAULT_ZJSONPATCH_VERSION = "0.4.14";
static final String NAME = "json";
@Inject
public JsonExtension(SpotlessExtension spotless) {
super(spotless);
}
@Override
protected void setupTask(SpotlessTask task) {
if (target == null) {
throw noDefaultTargetException();
}
super.setupTask(task);
}
public SimpleConfig simple() {
return new SimpleConfig(DEFAULT_INDENTATION);
}
public GsonConfig gson() {
return new GsonConfig();
}
public JacksonJsonGradleConfig jackson() {
return new JacksonJsonGradleConfig(this);
}
/**
* Defaults to downloading the default Biome version from the network. To work
* offline, you can specify the path to the Biome executable via
* {@code biome().pathToExe(...)}.
*/
public BiomeJson biome() {
return biome(null);
}
/** Downloads the given Biome version from the network. */
public BiomeJson biome(String version) {
var biomeConfig = new BiomeJson(version);
addStep(biomeConfig.createStep());
return biomeConfig;
}
/**
* Defaults to downloading the default Rome version from the network. To work
* offline, you can specify the path to the Rome executable via
* {@code rome().pathToExe(...)}.
*
* @deprecated Use {@link #biome()}.
*/
@Deprecated
public RomeJson rome() {
return rome(null);
}
/**
* Downloads the given Rome version from the network.
*
* @deprecated Use {@link #biome(String)}.
*/
@Deprecated
public RomeJson rome(String version) {
var romeConfig = new RomeJson(version);
addStep(romeConfig.createStep());
return romeConfig;
}
public JsonPatchConfig jsonPatch(List