From 2ff31dbb12e6327918eea305676dd21433f3a618 Mon Sep 17 00:00:00 2001 From: Chia-Ping Tsai Date: Sat, 6 May 2023 20:27:59 +0800 Subject: [PATCH] [METRICS] rewrite BeanQuery by java 17 record --- .../org/astraea/common/metrics/BeanQuery.java | 41 ++++--------------- 1 file changed, 9 insertions(+), 32 deletions(-) diff --git a/common/src/main/java/org/astraea/common/metrics/BeanQuery.java b/common/src/main/java/org/astraea/common/metrics/BeanQuery.java index 2ccb686847..cb98efa16d 100644 --- a/common/src/main/java/org/astraea/common/metrics/BeanQuery.java +++ b/common/src/main/java/org/astraea/common/metrics/BeanQuery.java @@ -53,7 +53,7 @@ * BeanQuery.all("java.*") * } */ -public interface BeanQuery { +public record BeanQuery(String domainName, Map properties, ObjectName objectName) { static BeanQuery fromObjectName(ObjectName objectName) { return BeanQuery.builder() @@ -63,7 +63,7 @@ static BeanQuery fromObjectName(ObjectName objectName) { .build(); } - static Builder builder() { + public static Builder builder() { return new Builder(); } @@ -72,7 +72,7 @@ static Builder builder() { * * @return a {@link BeanQuery} object that target all MBeans under every domain name */ - static BeanQuery all() { + public static BeanQuery all() { return builder().propertyListPattern(true).build(); } @@ -82,17 +82,11 @@ static BeanQuery all() { * @param domainName the domain name to query * @return a {@link BeanQuery} object that target all MBeans under specific domain name */ - static BeanQuery all(String domainName) { + public static BeanQuery all(String domainName) { return builder().domainName(domainName).propertyListPattern(true).build(); } - String domainName(); - - Map properties(); - - ObjectName objectName(); - - class Builder { + public static class Builder { private String domainName = "*"; private final Map properties = new HashMap<>(); @@ -162,9 +156,9 @@ public Builder propertyListPattern(boolean propertyListPattern) { * previous calling to {@link Builder#property(String, String)}. */ public BeanQuery build() { - var domainName = Objects.requireNonNull(this.domainName); - var properties = Map.copyOf(Objects.requireNonNull(this.properties)); - var objectName = + return new BeanQuery( + Objects.requireNonNull(domainName), + Map.copyOf(Objects.requireNonNull(properties)), Utils.packException( () -> { if (propertyListPattern) { @@ -176,24 +170,7 @@ public BeanQuery build() { domainName + ":" + propertyList + ((properties.isEmpty()) ? "*" : ",*")); } return ObjectName.getInstance(domainName, new Hashtable<>(this.properties)); - }); - return new BeanQuery() { - - @Override - public String domainName() { - return domainName; - } - - @Override - public Map properties() { - return properties; - } - - @Override - public ObjectName objectName() { - return objectName; - } - }; + })); } } }