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: on:
push: push:
branches: [master] branches: [master, develop]
tags: tags:
- '*' - '*'
jobs: jobs:
publish: # Maven Build Job
name: Publish Release build:
name: Maven Build
strategy: strategy:
matrix: matrix:
arch: [ubuntu-latest] arch: [ubuntu-latest]
@ -60,6 +61,18 @@ jobs:
- name: Publish to Maven - name: Publish to Maven
run: mvn deploy -Pgen-javadocs -B -Dstyle.color=always --update-snapshots -T6C -e 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 # Generate changelog
- name: Generate Changelog - name: Generate Changelog
id: changelog id: changelog

View File

@ -91,9 +91,6 @@
<!-- See: https://checkstyle.org/checks/javadoc/javadocmissingwhitespaceafterasterisk.html#JavadocMissingWhitespaceAfterAsterisk --> <!-- See: https://checkstyle.org/checks/javadoc/javadocmissingwhitespaceafterasterisk.html#JavadocMissingWhitespaceAfterAsterisk -->
<module name="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 --> <!-- See: https://checkstyle.org/checks/javadoc/javadocstyle.html#JavadocStyle -->
<module name="JavadocStyle" /> <module name="JavadocStyle" />
@ -215,11 +212,6 @@
<!-- See: https://checkstyle.org/checks/javadoc/singlelinejavadoc.html#SingleLineJavadoc --> <!-- See: https://checkstyle.org/checks/javadoc/singlelinejavadoc.html#SingleLineJavadoc -->
<module name="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 --> <!-- See: https://checkstyle.org/checks/whitespace/singlespaceseparator.html#SingleSpaceSeparator -->
<module name="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.Getter;
import lombok.NonNull; import lombok.NonNull;
import lombok.SneakyThrows;
import lombok.ToString; import lombok.ToString;
import me.braydon.feather.FeatherSettings; import me.braydon.feather.FeatherSettings;
import me.braydon.feather.annotation.Field; import me.braydon.feather.annotation.Field;
import me.braydon.feather.annotation.Id; import me.braydon.feather.annotation.Id;
import me.braydon.feather.annotation.RawData;
import me.braydon.feather.annotation.Serializable; import me.braydon.feather.annotation.Serializable;
import me.braydon.feather.common.FieldUtils; import me.braydon.feather.common.FieldUtils;
import me.braydon.feather.common.Tuple; 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<>()); private final Map<String, Tuple<java.lang.reflect.Field, V>> mappedData = Collections.synchronizedMap(new LinkedHashMap<>());
@SneakyThrows
public Document(@NonNull Object element) { public Document(@NonNull Object element) {
Class<?> clazz = element.getClass(); // Get the element class Class<?> clazz = element.getClass(); // Get the element class
String idKey = null; // The key for the id field String idKey = null; // The key for the id field
java.lang.reflect.Field rawDataField = null;
for (java.lang.reflect.Field field : clazz.getDeclaredFields()) { for (java.lang.reflect.Field field : clazz.getDeclaredFields()) {
// Field is missing the @Field annotation, skip it // Field is missing the @Field annotation, skip it
if (!field.isAnnotationPresent(Field.class)) { if (!field.isAnnotationPresent(Field.class)) {
continue; continue;
} }
field.setAccessible(true); // Make our field accessible 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 String key = FieldUtils.extractKey(field); // The key of the database field
// The field is annotated with @Id, save it for later // The field is annotated with @Id, save it for later
@ -71,7 +78,6 @@ public class Document<V> {
idKey = key; idKey = key;
} }
Class<?> fieldType = field.getType(); // The type of the field Class<?> fieldType = field.getType(); // The type of the field
try {
Object value = field.get(element); // The value of the field Object value = field.get(element); // The value of the field
if (field.isAnnotationPresent(Serializable.class)) { // Serialize the field if @Serializable is present if (field.isAnnotationPresent(Serializable.class)) { // Serialize the field if @Serializable is present
@ -81,11 +87,11 @@ public class Document<V> {
} }
mappedData.put(key, new Tuple<>(field, (V) value)); // Store in our map mappedData.put(key, new Tuple<>(field, (V) value)); // Store in our map
} catch (IllegalAccessException ex) {
throw new RuntimeException(ex);
}
} }
assert idKey != null; // We need an id key 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 this.idKey = idKey; // Set our id key
Tuple<java.lang.reflect.Field, V> key = mappedData.get(idKey); // Get the id from the data map Tuple<java.lang.reflect.Field, V> key = mappedData.get(idKey); // Get the id from the data map