Update workflow and make the checkstyle less strict

This commit is contained in:
Braydon 2023-12-16 17:47:22 -05:00
parent 3119173d87
commit caebbc59a0
4 changed files with 55 additions and 24 deletions

View File

@ -1,14 +1,15 @@
name: Publish Release
name: Maven Build
on:
push:
branches: [master]
branches: [master, develop]
tags:
- '*'
jobs:
publish:
name: Publish Release
# Maven Build Job
build:
name: Maven Build
strategy:
matrix:
arch: [ubuntu-latest]
@ -60,6 +61,18 @@ jobs:
- name: Publish to Maven
run: mvn deploy -Pgen-javadocs -B -Dstyle.color=always --update-snapshots -T6C -e
# Publish Job
publish:
name: Maven Build
strategy:
matrix:
arch: [ ubuntu-latest ]
java-version: [ 8 ]
maven-version: [ 3.9.4 ]
runs-on: ${{ matrix.arch }}
# Steps
steps:
# Generate changelog
- name: Generate Changelog
id: changelog

View File

@ -91,9 +91,6 @@
<!-- See: https://checkstyle.org/checks/javadoc/javadocmissingwhitespaceafterasterisk.html#JavadocMissingWhitespaceAfterAsterisk -->
<module name="JavadocMissingWhitespaceAfterAsterisk" />
<!-- See: https://checkstyle.org/checks/javadoc/javadocparagraph.html#JavadocParagraph -->
<module name="JavadocParagraph" />
<!-- See: https://checkstyle.org/checks/javadoc/javadocstyle.html#JavadocStyle -->
<module name="JavadocStyle" />
@ -215,11 +212,6 @@
<!-- See: https://checkstyle.org/checks/javadoc/singlelinejavadoc.html#SingleLineJavadoc -->
<module name="SingleLineJavadoc" />
<!-- See: https://checkstyle.org/checks/javadoc/requireemptylinebeforeblocktaggroup.html#RequireEmptyLineBeforeBlockTagGroup -->
<module name="RequireEmptyLineBeforeBlockTagGroup">
<property name="violateExecutionOnNonTightHtml" value="true" />
</module>
<!-- See: https://checkstyle.org/checks/whitespace/singlespaceseparator.html#SingleSpaceSeparator -->
<module name="SingleSpaceSeparator" />

View File

@ -0,0 +1,20 @@
/*
* Copyright (c) 2023 Braydon (Rainnny). All rights reserved.
*
* For inquiries, please contact braydonrainnny@gmail.com
*/
package me.braydon.feather.annotation;
import java.lang.annotation.*;
/**
* {@link Field}'s tagged with this annotation
* will be set to the raw data from the document
* it is in.
*
* @author Braydon
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
@Documented @Inherited
public @interface RawData { }

View File

@ -7,10 +7,12 @@ package me.braydon.feather.data;
import lombok.Getter;
import lombok.NonNull;
import lombok.SneakyThrows;
import lombok.ToString;
import me.braydon.feather.FeatherSettings;
import me.braydon.feather.annotation.Field;
import me.braydon.feather.annotation.Id;
import me.braydon.feather.annotation.RawData;
import me.braydon.feather.annotation.Serializable;
import me.braydon.feather.common.FieldUtils;
import me.braydon.feather.common.Tuple;
@ -55,15 +57,20 @@ public class Document<V> {
*/
private final Map<String, Tuple<java.lang.reflect.Field, V>> mappedData = Collections.synchronizedMap(new LinkedHashMap<>());
@SneakyThrows
public Document(@NonNull Object element) {
Class<?> clazz = element.getClass(); // Get the element class
String idKey = null; // The key for the id field
java.lang.reflect.Field rawDataField = null;
for (java.lang.reflect.Field field : clazz.getDeclaredFields()) {
// Field is missing the @Field annotation, skip it
if (!field.isAnnotationPresent(Field.class)) {
continue;
}
field.setAccessible(true); // Make our field accessible
if (field.isAnnotationPresent(RawData.class)) { // Raw data field, save it for later
rawDataField = field;
}
String key = FieldUtils.extractKey(field); // The key of the database field
// The field is annotated with @Id, save it for later
@ -71,21 +78,20 @@ public class Document<V> {
idKey = key;
}
Class<?> fieldType = field.getType(); // The type of the field
try {
Object value = field.get(element); // The value of the field
if (field.isAnnotationPresent(Serializable.class)) { // Serialize the field if @Serializable is present
value = FeatherSettings.getGson().toJson(field.get(element));
} else if (fieldType == UUID.class) { // Convert UUIDs into strings
value = value.toString();
}
mappedData.put(key, new Tuple<>(field, (V) value)); // Store in our map
} catch (IllegalAccessException ex) {
throw new RuntimeException(ex);
Object value = field.get(element); // The value of the field
if (field.isAnnotationPresent(Serializable.class)) { // Serialize the field if @Serializable is present
value = FeatherSettings.getGson().toJson(field.get(element));
} else if (fieldType == UUID.class) { // Convert UUIDs into strings
value = value.toString();
}
mappedData.put(key, new Tuple<>(field, (V) value)); // Store in our map
}
assert idKey != null; // We need an id key
if (rawDataField != null) { // We have a raw data field, set it
rawDataField.set(element, mappedData);
}
this.idKey = idKey; // Set our id key
Tuple<java.lang.reflect.Field, V> key = mappedData.get(idKey); // Get the id from the data map