mirror of
https://github.com/HighCapable/SweetProperty.git
synced 2025-09-08 03:24:06 +08:00
Compare commits
58 Commits
Author | SHA1 | Date | |
---|---|---|---|
d04a57c549
|
|||
308f1618ab
|
|||
36c7af3c52
|
|||
34b11eb5b7
|
|||
72037d6f08
|
|||
cf4b59db1a
|
|||
74da386f49
|
|||
ceccd2e2cf
|
|||
|
22b0a1be2c | ||
|
a16da731cf | ||
99a6e02d1d
|
|||
9e7d5ec574
|
|||
f00c6e718c
|
|||
1e513489c8
|
|||
fdab590578
|
|||
dd85954691
|
|||
37644fcd8d
|
|||
341a7497ec
|
|||
138551dd44
|
|||
d54aebefca
|
|||
7b24cd442e
|
|||
77c374d6b6
|
|||
f2bdbb8124
|
|||
21d4857d5c
|
|||
f5ab29e6b6
|
|||
255bd4035e
|
|||
98ca5dbc29
|
|||
91cfa2f30a
|
|||
68bfcc9b5a
|
|||
3481495626
|
|||
7acba690fb
|
|||
c7ec2ab836
|
|||
89626aeca7
|
|||
59453292f3
|
|||
c12e55dbc1
|
|||
192d3c9a5e
|
|||
e5e5915618
|
|||
e28c9feb20
|
|||
595e3768f7
|
|||
179462c0ae
|
|||
90f36ac825
|
|||
8a71e739c0
|
|||
4eaaf82430
|
|||
ef19ea07a5
|
|||
c98dfb6b3d
|
|||
a978baa1fe
|
|||
93c8107e76
|
|||
5d5c3af69a
|
|||
87143b99c4
|
|||
ec03595552
|
|||
33abb4bafa
|
|||
2337d5710b
|
|||
1bf1a030dc
|
|||
6c5835bc72
|
|||
d9c8c5dc84
|
|||
d2aed2120e
|
|||
67c79a591c
|
|||
fe1c8594c8
|
@@ -10,6 +10,24 @@ ktlint_standard_argument-list-wrapping = disabled
|
|||||||
ktlint_standard_parameter-list-wrapping = disabled
|
ktlint_standard_parameter-list-wrapping = disabled
|
||||||
ktlint_standard_trailing-comma-on-declaration-site = disabled
|
ktlint_standard_trailing-comma-on-declaration-site = disabled
|
||||||
ktlint_function_signature_body_expression_wrapping = multiline
|
ktlint_function_signature_body_expression_wrapping = multiline
|
||||||
|
ktlint_standard_string-template-indent = disabled
|
||||||
|
ktlint_standard_function-signature = disabled
|
||||||
|
ktlint_standard_trailing-comma-on-call-site = disabled
|
||||||
|
ktlint_standard_multiline-expression-wrapping = disabled
|
||||||
|
ktlint_standard_no-empty-first-line-in-class-body = disabled
|
||||||
|
ktlint_standard_if-else-wrapping = disabled
|
||||||
|
ktlint_standard_if-else-bracing = disabled
|
||||||
|
ktlint_standard_statement-wrapping = disabled
|
||||||
|
ktlint_standard_blank-line-before-declaration = disabled
|
||||||
|
ktlint_standard_no-empty-file = disabled
|
||||||
|
ktlint_standard_property-naming = disabled
|
||||||
|
ktlint_standard_function-naming = disabled
|
||||||
|
ktlint_standard_chain-method-continuation = disabled
|
||||||
|
ktlint_standard_class-signature = disabled
|
||||||
|
ktlint_standard_condition-wrapping = disabled
|
||||||
|
ktlint_standard_class-signature = disabled
|
||||||
|
ktlint_standard_no-trailing-spaces = disabled
|
||||||
|
ktlint_standard_multiline-loop = disabled
|
||||||
ij_continuation_indent_size = 2
|
ij_continuation_indent_size = 2
|
||||||
indent_size = 4
|
indent_size = 4
|
||||||
indent_style = space
|
indent_style = space
|
||||||
|
117
.gitignore
vendored
117
.gitignore
vendored
@@ -1,13 +1,110 @@
|
|||||||
|
## Fully .gtignore for IntelliJ, Android Studio and Gradle based Java projects
|
||||||
|
## References:
|
||||||
|
## - https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore
|
||||||
|
## - https://github.com/android/platform-samples/blob/main/.gitignore
|
||||||
|
|
||||||
|
# User-specific stuff
|
||||||
|
.idea/**/workspace.xml
|
||||||
|
.idea/**/tasks.xml
|
||||||
|
.idea/**/usage.statistics.xml
|
||||||
|
.idea/**/dictionaries
|
||||||
|
.idea/**/shelf
|
||||||
|
|
||||||
|
# AWS User-specific
|
||||||
|
.idea/**/aws.xml
|
||||||
|
|
||||||
|
# Generated files
|
||||||
|
.idea/**/contentModel.xml
|
||||||
|
|
||||||
|
# Sensitive or high-churn files
|
||||||
|
.idea/**/dataSources/
|
||||||
|
.idea/**/dataSources.ids
|
||||||
|
.idea/**/dataSources.local.xml
|
||||||
|
.idea/**/sqlDataSources.xml
|
||||||
|
.idea/**/dynamic.xml
|
||||||
|
.idea/**/uiDesigner.xml
|
||||||
|
.idea/**/dbnavigator.xml
|
||||||
|
|
||||||
|
# Gradle
|
||||||
|
.idea/**/gradle.xml
|
||||||
|
.idea/**/libraries
|
||||||
|
|
||||||
|
# Gradle and Maven with auto-import
|
||||||
|
.idea/.name
|
||||||
|
.idea/artifacts
|
||||||
|
.idea/compiler.xml
|
||||||
|
.idea/jarRepositories.xml
|
||||||
|
.idea/modules.xml
|
||||||
|
.idea/*.iml
|
||||||
|
.idea/modules
|
||||||
|
.idea/caches
|
||||||
|
.idea/material_theme**
|
||||||
|
.idea/other.xml
|
||||||
*.iml
|
*.iml
|
||||||
.gradle
|
*.ipr
|
||||||
/.idea/caches
|
|
||||||
/.idea/libraries
|
# Kotlin
|
||||||
/.idea/modules.xml
|
.kotlin
|
||||||
/.idea/workspace.xml
|
|
||||||
/.idea/navEditor.xml
|
# Misc
|
||||||
/.idea/assetWizardSettings.xml
|
.idea/misc.xml
|
||||||
.DS_Store
|
|
||||||
/build
|
# CMake
|
||||||
|
cmake-build-*/
|
||||||
|
|
||||||
|
# Mongo Explorer plugin
|
||||||
|
.idea/**/mongoSettings.xml
|
||||||
|
|
||||||
|
# File-based project format
|
||||||
|
*.iws
|
||||||
|
|
||||||
|
# IntelliJ
|
||||||
|
out/
|
||||||
|
|
||||||
|
# mpeltonen/sbt-idea plugin
|
||||||
|
.idea_modules/
|
||||||
|
|
||||||
|
# JIRA plugin
|
||||||
|
atlassian-ide-plugin.xml
|
||||||
|
|
||||||
|
# Cursive Clojure plugin
|
||||||
|
.idea/replstate.xml
|
||||||
|
|
||||||
|
# SonarLint plugin
|
||||||
|
.idea/sonarlint/
|
||||||
|
|
||||||
|
# Crashlytics plugin (for Android Studio and IntelliJ)
|
||||||
|
com_crashlytics_export_strings.xml
|
||||||
|
crashlytics.properties
|
||||||
|
crashlytics-build.properties
|
||||||
|
fabric.properties
|
||||||
|
|
||||||
|
# Editor-based Rest Client
|
||||||
|
.idea/httpRequests
|
||||||
|
|
||||||
|
# Android studio 3.1+ serialized cache file
|
||||||
|
.idea/caches/build_file_checksums.ser
|
||||||
|
|
||||||
|
# Android studio 3.1+ additional
|
||||||
|
.idea/deployment*.xml
|
||||||
|
.idea/assetWizardSettings.xml
|
||||||
|
.idea/androidTestResultsUserPreferences.xml
|
||||||
|
|
||||||
|
# Android projects
|
||||||
|
**/local.properties
|
||||||
/captures
|
/captures
|
||||||
.externalNativeBuild
|
.externalNativeBuild
|
||||||
.cxx
|
.cxx
|
||||||
|
|
||||||
|
# Gradle projects
|
||||||
|
.gradle
|
||||||
|
build/
|
||||||
|
|
||||||
|
# Mkdocs temporary serving folder
|
||||||
|
docs-gen
|
||||||
|
site
|
||||||
|
*.bak
|
||||||
|
.idea/appInsightsSettings.xml
|
||||||
|
|
||||||
|
# Mac OS
|
||||||
|
.DS_Store
|
10
.idea/.gitignore
generated
vendored
10
.idea/.gitignore
generated
vendored
@@ -1,10 +0,0 @@
|
|||||||
# Default ignored files
|
|
||||||
/shelf/
|
|
||||||
/workspace.xml
|
|
||||||
/gradle.xml
|
|
||||||
/misc.xml
|
|
||||||
# Editor-based HTTP Client requests
|
|
||||||
/httpRequests/
|
|
||||||
# Datasource local storage ignored files
|
|
||||||
/dataSources/
|
|
||||||
/dataSources.local.xml
|
|
6
.idea/compiler.xml
generated
6
.idea/compiler.xml
generated
@@ -1,6 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="CompilerConfiguration">
|
|
||||||
<bytecodeTargetLevel target="17" />
|
|
||||||
</component>
|
|
||||||
</project>
|
|
1
.idea/inspectionProfiles/Project_Default.xml
generated
1
.idea/inspectionProfiles/Project_Default.xml
generated
@@ -1,6 +1,7 @@
|
|||||||
<component name="InspectionProjectProfileManager">
|
<component name="InspectionProjectProfileManager">
|
||||||
<profile version="1.0">
|
<profile version="1.0">
|
||||||
<option name="myName" value="Project Default" />
|
<option name="myName" value="Project Default" />
|
||||||
|
<inspection_tool class="CheckImageSize" enabled="false" level="WARNING" enabled_by_default="false" />
|
||||||
<inspection_tool class="ReplaceUntilWithRangeUntil" enabled="true" level="WEAK WARNING" enabled_by_default="true" />
|
<inspection_tool class="ReplaceUntilWithRangeUntil" enabled="true" level="WEAK WARNING" enabled_by_default="true" />
|
||||||
<inspection_tool class="SpellCheckingInspection" enabled="false" level="TYPO" enabled_by_default="false">
|
<inspection_tool class="SpellCheckingInspection" enabled="false" level="TYPO" enabled_by_default="false">
|
||||||
<option name="processCode" value="true" />
|
<option name="processCode" value="true" />
|
||||||
|
20
.idea/jarRepositories.xml
generated
20
.idea/jarRepositories.xml
generated
@@ -1,20 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="RemoteRepositoriesConfiguration">
|
|
||||||
<remote-repository>
|
|
||||||
<option name="id" value="central" />
|
|
||||||
<option name="name" value="Maven Central repository" />
|
|
||||||
<option name="url" value="https://repo1.maven.org/maven2" />
|
|
||||||
</remote-repository>
|
|
||||||
<remote-repository>
|
|
||||||
<option name="id" value="jboss.community" />
|
|
||||||
<option name="name" value="JBoss Community repository" />
|
|
||||||
<option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" />
|
|
||||||
</remote-repository>
|
|
||||||
<remote-repository>
|
|
||||||
<option name="id" value="MavenRepo" />
|
|
||||||
<option name="name" value="MavenRepo" />
|
|
||||||
<option name="url" value="https://repo.maven.apache.org/maven2/" />
|
|
||||||
</remote-repository>
|
|
||||||
</component>
|
|
||||||
</project>
|
|
2
.idea/kotlinc.xml
generated
2
.idea/kotlinc.xml
generated
@@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project version="4">
|
<project version="4">
|
||||||
<component name="KotlinJpsPluginSettings">
|
<component name="KotlinJpsPluginSettings">
|
||||||
<option name="version" value="1.9.10" />
|
<option name="version" value="2.1.10" />
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
7
.idea/ktlint-plugin.xml
generated
Normal file
7
.idea/ktlint-plugin.xml
generated
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="KtLint plugin">
|
||||||
|
<ktlintMode>MANUAL</ktlintMode>
|
||||||
|
<formatOnSave>false</formatOnSave>
|
||||||
|
</component>
|
||||||
|
</project>
|
6
.idea/markdown.xml
generated
Normal file
6
.idea/markdown.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="MarkdownSettings">
|
||||||
|
<option name="showProblemsInCodeBlocks" value="false" />
|
||||||
|
</component>
|
||||||
|
</project>
|
124
.idea/uiDesigner.xml
generated
124
.idea/uiDesigner.xml
generated
@@ -1,124 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<project version="4">
|
|
||||||
<component name="Palette2">
|
|
||||||
<group name="Swing">
|
|
||||||
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
|
||||||
</item>
|
|
||||||
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.svg" removable="false" auto-create-binding="false" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
|
||||||
<initial-values>
|
|
||||||
<property name="text" value="Button" />
|
|
||||||
</initial-values>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
|
||||||
<initial-values>
|
|
||||||
<property name="text" value="RadioButton" />
|
|
||||||
</initial-values>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
|
||||||
<initial-values>
|
|
||||||
<property name="text" value="CheckBox" />
|
|
||||||
</initial-values>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
|
||||||
<initial-values>
|
|
||||||
<property name="text" value="Label" />
|
|
||||||
</initial-values>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
|
||||||
<preferred-size width="150" height="-1" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
|
||||||
<preferred-size width="150" height="-1" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
|
||||||
<preferred-size width="150" height="-1" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
|
||||||
<preferred-size width="150" height="50" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
|
||||||
<preferred-size width="150" height="50" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
|
||||||
<preferred-size width="150" height="50" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
|
||||||
<preferred-size width="150" height="50" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
|
||||||
<preferred-size width="150" height="50" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
|
||||||
<preferred-size width="150" height="50" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
|
||||||
<preferred-size width="200" height="200" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
|
||||||
<preferred-size width="200" height="200" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
|
||||||
<preferred-size width="-1" height="20" />
|
|
||||||
</default-constraints>
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
|
||||||
</item>
|
|
||||||
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
|
||||||
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
|
||||||
</item>
|
|
||||||
</group>
|
|
||||||
</component>
|
|
||||||
</project>
|
|
@@ -1,14 +1,20 @@
|
|||||||
# Sweet Property
|
# Sweet Property
|
||||||
|
|
||||||
[](https://github.com/HighCapable/SweetProperty/blob/master/LICENSE)
|
[](https://github.com/HighCapable/SweetProperty/blob/master/LICENSE)
|
||||||
[](https://github.com/HighCapable/SweetProperty/releases)
|
[](https://github.com/HighCapable/SweetProperty/releases)
|
||||||
[](https://t.me/HighCapable_Dev)
|
[](https://t.me/HighCapable_Dev)
|
||||||
|
[](https://qm.qq.com/cgi-bin/qm/qr?k=Pnsc5RY6N2mBKFjOLPiYldbAbprAU3V7&jump_from=webapi&authKey=X5EsOVzLXt1dRunge8ryTxDRrh9/IiW1Pua75eDLh9RE3KXE+bwXIYF5cWri/9lf)
|
||||||
|
|
||||||
<img src="https://github.com/HighCapable/SweetProperty/blob/master/img-src/icon.png?raw=true" width = "100" height = "100" alt="LOGO"/>
|
<img src="img-src/icon.png" width = "100" height = "100" alt="LOGO"/>
|
||||||
|
|
||||||
一个轻松在任意地方获取项目属性的 Gradle 插件。
|
一个轻松在任意地方获取项目属性的 Gradle 插件。
|
||||||
|
|
||||||
[English](https://github.com/HighCapable/SweetProperty/blob/master/README.md) | 简体中文
|
[English](README.md) | 简体中文
|
||||||
|
|
||||||
|
| <img src="https://github.com/HighCapable/.github/blob/main/img-src/logo.jpg?raw=true" width = "30" height = "30" alt="LOGO"/> | [HighCapable](https://github.com/HighCapable) |
|
||||||
|
|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|
||||||
|
|
||||||
|
这个项目属于上述组织,**点击上方链接关注这个组织**,发现更多好项目。
|
||||||
|
|
||||||
## 这是什么
|
## 这是什么
|
||||||
|
|
||||||
@@ -38,11 +44,11 @@
|
|||||||
|
|
||||||
## 开始使用
|
## 开始使用
|
||||||
|
|
||||||
- [点击这里](https://github.com/HighCapable/SweetProperty/blob/master/docs/guide-zh-CN.md) 查看使用文档
|
- [点击这里](docs/guide-zh-CN.md) 查看使用文档
|
||||||
|
|
||||||
## 更新日志
|
## 更新日志
|
||||||
|
|
||||||
- [点击这里](https://github.com/HighCapable/SweetProperty/blob/master/docs/changelog-zh-CN.md) 查看历史更新日志
|
- [点击这里](docs/changelog-zh-CN.md) 查看历史更新日志
|
||||||
|
|
||||||
## 项目推广
|
## 项目推广
|
||||||
|
|
||||||
@@ -50,11 +56,14 @@
|
|||||||
|
|
||||||
本项目同样使用了 **SweetDependency**。
|
本项目同样使用了 **SweetDependency**。
|
||||||
|
|
||||||
## 捐赠支持
|
<!--suppress HtmlDeprecatedAttribute -->
|
||||||
|
<div align="center">
|
||||||
工作不易,无意外情况此项目将继续维护下去,提供更多可能,欢迎打赏。
|
<h2>嘿,还请君留步!👋</h2>
|
||||||
|
<h3>这里有 Android 开发工具、UI 设计、Gradle 插件、Xposed 模块和实用软件等相关项目。</h3>
|
||||||
<img src="https://github.com/fankes/fankes/blob/main/img-src/payment_code.jpg?raw=true" width = "500" alt="Payment Code"/>
|
<h3>如果下方的项目能为你提供帮助,不妨为我点个 star 吧!</h3>
|
||||||
|
<h3>所有项目免费、开源,遵循对应开源许可协议。</h3>
|
||||||
|
<h1><a href="https://github.com/fankes/fankes/blob/main/project-promote/README-zh-CN.md">→ 查看更多关于我的项目,请点击这里 ←</a></h1>
|
||||||
|
</div>
|
||||||
|
|
||||||
## Star History
|
## Star History
|
||||||
|
|
||||||
@@ -67,7 +76,7 @@
|
|||||||
```
|
```
|
||||||
Apache License Version 2.0
|
Apache License Version 2.0
|
||||||
|
|
||||||
Copyright (C) 2019-2023 HighCapable
|
Copyright (C) 2019 HighCapable
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
@@ -82,4 +91,4 @@ See the License for the specific language governing permissions and
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
```
|
```
|
||||||
|
|
||||||
版权所有 © 2019-2023 HighCapable
|
版权所有 © 2019 HighCapable
|
33
README.md
33
README.md
@@ -1,14 +1,20 @@
|
|||||||
# Sweet Property
|
# Sweet Property
|
||||||
|
|
||||||
[](https://github.com/HighCapable/SweetProperty/blob/master/LICENSE)
|
[](https://github.com/HighCapable/SweetProperty/blob/master/LICENSE)
|
||||||
[](https://github.com/HighCapable/SweetProperty/releases)
|
[](https://github.com/HighCapable/SweetProperty/releases)
|
||||||
[](https://t.me/HighCapable_Dev)
|
[](https://t.me/HighCapable_Dev)
|
||||||
|
[](https://qm.qq.com/cgi-bin/qm/qr?k=Pnsc5RY6N2mBKFjOLPiYldbAbprAU3V7&jump_from=webapi&authKey=X5EsOVzLXt1dRunge8ryTxDRrh9/IiW1Pua75eDLh9RE3KXE+bwXIYF5cWri/9lf)
|
||||||
|
|
||||||
<img src="https://github.com/HighCapable/SweetProperty/blob/master/img-src/icon.png?raw=true" width = "100" height = "100" alt="LOGO"/>
|
<img src="img-src/icon.png" width = "100" height = "100" alt="LOGO"/>
|
||||||
|
|
||||||
An easy get project properties anywhere Gradle plugin.
|
An easy get project properties anywhere Gradle plugin.
|
||||||
|
|
||||||
English | [简体中文](https://github.com/HighCapable/SweetProperty/blob/master/README-zh-CN.md)
|
English | [简体中文](README-zh-CN.md)
|
||||||
|
|
||||||
|
| <img src="https://github.com/HighCapable/.github/blob/main/img-src/logo.jpg?raw=true" width = "30" height = "30" alt="LOGO"/> | [HighCapable](https://github.com/HighCapable) |
|
||||||
|
|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|
||||||
|
|
||||||
|
This project belongs to the above-mentioned organization, **click the link above to follow this organization** and discover more good projects.
|
||||||
|
|
||||||
## What's this
|
## What's this
|
||||||
|
|
||||||
@@ -43,11 +49,11 @@ Some functions may be incompatible, support will be gradually dropped in the fut
|
|||||||
|
|
||||||
## Get Started
|
## Get Started
|
||||||
|
|
||||||
- [Click here](https://github.com/HighCapable/SweetProperty/blob/master/docs/guide.md) to view the documentation
|
- [Click here](docs/guide.md) to view the documentation
|
||||||
|
|
||||||
## Changelog
|
## Changelog
|
||||||
|
|
||||||
- [Click here](https://github.com/HighCapable/SweetProperty/blob/master/docs/changelog.md) to view the historical changelog
|
- [Click here](docs/changelog.md) to view the historical changelog
|
||||||
|
|
||||||
## Promotion
|
## Promotion
|
||||||
|
|
||||||
@@ -56,6 +62,15 @@ you can check out the [SweetDependency](https://github.com/HighCapable/SweetDepe
|
|||||||
|
|
||||||
This project also uses **SweetDependency**.
|
This project also uses **SweetDependency**.
|
||||||
|
|
||||||
|
<!--suppress HtmlDeprecatedAttribute -->
|
||||||
|
<div align="center">
|
||||||
|
<h2>Hey, please stay! 👋</h2>
|
||||||
|
<h3>Here are related projects such as Android development tools, UI design, Gradle plugins, Xposed Modules and practical software. </h3>
|
||||||
|
<h3>If the project below can help you, please give me a star! </h3>
|
||||||
|
<h3>All projects are free, open source, and follow the corresponding open source license agreement. </h3>
|
||||||
|
<h1><a href="https://github.com/fankes/fankes/blob/main/project-promote/README.md">→ To see more about my projects, please click here ←</a></h1>
|
||||||
|
</div>
|
||||||
|
|
||||||
## Star History
|
## Star History
|
||||||
|
|
||||||

|

|
||||||
@@ -67,7 +82,7 @@ This project also uses **SweetDependency**.
|
|||||||
```
|
```
|
||||||
Apache License Version 2.0
|
Apache License Version 2.0
|
||||||
|
|
||||||
Copyright (C) 2019-2023 HighCapable
|
Copyright (C) 2019 HighCapable
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
@@ -82,4 +97,4 @@ See the License for the specific language governing permissions and
|
|||||||
limitations under the License.
|
limitations under the License.
|
||||||
```
|
```
|
||||||
|
|
||||||
Copyright © 2019-2023 HighCapable
|
Copyright © 2019 HighCapable
|
@@ -1,16 +1,4 @@
|
|||||||
plugins {
|
plugins {
|
||||||
autowire(libs.plugins.kotlin.jvm) apply false
|
autowire(libs.plugins.kotlin.jvm) apply false
|
||||||
}
|
autowire(libs.plugins.maven.publish) apply false
|
||||||
|
|
||||||
allprojects {
|
|
||||||
tasks.withType<org.jetbrains.kotlin.gradle.tasks.KotlinCompile>().configureEach {
|
|
||||||
kotlinOptions {
|
|
||||||
jvmTarget = "17"
|
|
||||||
freeCompilerArgs = listOf(
|
|
||||||
"-Xno-param-assertions",
|
|
||||||
"-Xno-call-assertions",
|
|
||||||
"-Xno-receiver-assertions"
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
@@ -26,4 +26,25 @@
|
|||||||
- 修复在全局配置中使用过其它配置方法后,子项目的 `all` 方法失效问题
|
- 修复在全局配置中使用过其它配置方法后,子项目的 `all` 方法失效问题
|
||||||
- 改进并采用 Gradle 项目命名规范
|
- 改进并采用 Gradle 项目命名规范
|
||||||
- 新增插件自身检查更新功能
|
- 新增插件自身检查更新功能
|
||||||
- 一些其它功能性的改进
|
- 一些其它功能性的改进
|
||||||
|
|
||||||
|
## 1.0.4 | 2023.11.04
|
||||||
|
|
||||||
|
- 修复类似 `a=some` 和 `a_b=some` 的属性键值名称会造成重复方法名称的问题
|
||||||
|
- 修复使用 `${...}` 生成的插值内容依然会携带字符串类型引号问题
|
||||||
|
- 生成的代码使用 `@Nonnull` 标记以使其能够在 Kotlin DSL 脚本中识别为非空返回值类型
|
||||||
|
- 新增 `project(...)` 配置方法支持同时配置多个项目
|
||||||
|
- 一些其它功能性的改进
|
||||||
|
|
||||||
|
## 1.0.5 | 2023.11.08
|
||||||
|
|
||||||
|
- 修复遇到特殊字符和重复键值名称造成代码生成失败的严重问题
|
||||||
|
|
||||||
|
## 1.0.8 | 2025.08.19
|
||||||
|
|
||||||
|
- 修复在新版 Android Gradle Plugin 及 Android Studio/IDEA 中部署源码路径时的错误
|
||||||
|
`removeContentEntry: removed content entry url 'build/generated/sweet-property' still exists after removing`
|
||||||
|
- 新增 `sourceSetName` 方法,允许自定义要部署的源集名称
|
||||||
|
- 修复在类型自动转换过程中某些 `commit id` 和 Hash 可能被识别为数值类型的问题
|
||||||
|
- 合并 [#1](https://github.com/HighCapable/SweetProperty/pull/1) 并重新发布版本 (1.0.6)
|
||||||
|
- 修复由于 OSS 存储库被弃用导致重复提示检查更新的问题 (1.0.7)
|
@@ -27,4 +27,25 @@
|
|||||||
- Fix `all` function of the sub-project fails after using other configuration functions in the global configuration
|
- Fix `all` function of the sub-project fails after using other configuration functions in the global configuration
|
||||||
- Improve and adopt Gradle project naming convention
|
- Improve and adopt Gradle project naming convention
|
||||||
- Added plugin own update function
|
- Added plugin own update function
|
||||||
- Some other functional improvements
|
- Some other functional improvements
|
||||||
|
|
||||||
|
## 1.0.4 | 2023.11.04
|
||||||
|
|
||||||
|
- Fix the issue where attribute key value names like `a=some` and `a_b=some` would cause duplicate method names
|
||||||
|
- Fix the problem that the interpolation content generated using `${...}` still carries string type quotes
|
||||||
|
- Generated code is marked with `@Nonnull` to make it recognized as a non-null return type in Kotlin DSL scripts
|
||||||
|
- Added `project(...)` configuration method to support configuring multiple projects at the same time
|
||||||
|
- Some other functional improvements
|
||||||
|
|
||||||
|
## 1.0.5 | 2023.11.08
|
||||||
|
|
||||||
|
- Fix a serious issue that caused code generation failure when encountering special characters and duplicate key-value names
|
||||||
|
|
||||||
|
## 1.0.8 | 2025.08.19
|
||||||
|
|
||||||
|
- Fix errors when deploying source code paths in the new version of Android Gradle Plugin and Android Studio/IDEA
|
||||||
|
`removeContentEntry: removed content entry url 'build/generated/sweet-property' still exists after removing`
|
||||||
|
- Added the `sourceSetName` method to allow customization of the source set name to be deployed
|
||||||
|
- Fix an issue where some `commit id` and Hash might be recognized as numeric types during the automatic type conversion process
|
||||||
|
- Merge [#1](https://github.com/HighCapable/SweetProperty/pull/1) and re-release version (1.0.6)
|
||||||
|
- Fix a duplicate prompt for updates due to deprecating the OSS repository (1.0.7)
|
@@ -155,6 +155,10 @@ sweetProperty {
|
|||||||
// 默认为 "build/generated/sweet-property"
|
// 默认为 "build/generated/sweet-property"
|
||||||
// 建议将生成的代码放置于 "build" 目录下,因为生成的代码不建议去修改它
|
// 建议将生成的代码放置于 "build" 目录下,因为生成的代码不建议去修改它
|
||||||
generateDirPath = "build/generated/sweet-property"
|
generateDirPath = "build/generated/sweet-property"
|
||||||
|
// 自定义部署的 `sourceSet` 名称
|
||||||
|
// 如果你的项目源码部署名称不是默认值,可以在这里自定义
|
||||||
|
// 默认为 "main"
|
||||||
|
sourceSetName = "main"
|
||||||
// 自定义生成的包名
|
// 自定义生成的包名
|
||||||
// Android 项目默认使用 "android" 配置方法块中的 "namespace"
|
// Android 项目默认使用 "android" 配置方法块中的 "namespace"
|
||||||
// 普通的 Kotlin on Jvm 项目默认使用项目设置的 "project.group"
|
// 普通的 Kotlin on Jvm 项目默认使用项目设置的 "project.group"
|
||||||
@@ -213,6 +217,19 @@ sweetProperty {
|
|||||||
// 配置 "buildScript"
|
// 配置 "buildScript"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// 同时进行多个项目与子项目配置
|
||||||
|
// 在方法参数中填入需要配置的项目完整名称数组来配置每个对应的项目
|
||||||
|
project(":modules:library1", ":modules:library2") {
|
||||||
|
all {
|
||||||
|
// 配置 "all"
|
||||||
|
}
|
||||||
|
sourcesCode {
|
||||||
|
// 配置 "sourcesCode"
|
||||||
|
}
|
||||||
|
buildScript {
|
||||||
|
// 配置 "buildScript"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@@ -168,6 +168,10 @@ sweetProperty {
|
|||||||
// It is recommended to place the generated code in the "build" directory,
|
// It is recommended to place the generated code in the "build" directory,
|
||||||
// because the generated code is not recommended to be modified
|
// because the generated code is not recommended to be modified
|
||||||
generateDirPath = "build/generated/sweet-property"
|
generateDirPath = "build/generated/sweet-property"
|
||||||
|
// Custom deployed `sourceSet` name
|
||||||
|
// If your project source code deployment name is not the default value, you can customize it here
|
||||||
|
// Defaults to "main"
|
||||||
|
sourceSetName = "main"
|
||||||
// Custom generated package name
|
// Custom generated package name
|
||||||
// Android projects use the "namespace" in the "android" configuration method block by default
|
// Android projects use the "namespace" in the "android" configuration method block by default
|
||||||
// Ordinary Kotlin on Jvm projects use the "project.group" of the project settings by default
|
// Ordinary Kotlin on Jvm projects use the "project.group" of the project settings by default
|
||||||
@@ -227,7 +231,20 @@ sweetProperty {
|
|||||||
// Configure "buildScript"
|
// Configure "buildScript"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
// Configure multiple projects and sub-projects at the same time
|
||||||
|
// Fill in the method parameters with the array of complete names of the projects that need to be configured
|
||||||
|
// to configure each corresponding project
|
||||||
|
project(":modules:library1", ":modules:library2") {
|
||||||
|
all {
|
||||||
|
// Configure "all"
|
||||||
|
}
|
||||||
|
sourcesCode {
|
||||||
|
// Configure "sourcesCode"
|
||||||
|
}
|
||||||
|
buildScript {
|
||||||
|
// Configure "buildScript"
|
||||||
|
}
|
||||||
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
If you want to use it in Groovy DSL, please change the `=` of all variables to spaces, delete the `is` in front of `Enable` and lowercase `E`.
|
If you want to use it in Groovy DSL, please change the `=` of all variables to spaces, delete the `is` in front of `Enable` and lowercase `E`.
|
||||||
|
@@ -1,19 +1,27 @@
|
|||||||
# Project Configuration
|
# Project Configuration
|
||||||
project.name=SweetProperty
|
project.name=SweetProperty
|
||||||
project.description=An easy get project properties anywhere Gradle plugin.
|
|
||||||
project.url=https://github.com/HighCapable/SweetProperty
|
project.url=https://github.com/HighCapable/SweetProperty
|
||||||
project.groupName=com.highcapable.sweetproperty
|
project.groupName=com.highcapable.sweetproperty
|
||||||
project.moduleName=sweet-property
|
project.moduleName=sweet-property
|
||||||
project.version=1.0.3
|
project.version=1.0.8
|
||||||
project.licence.name=Apache License 2.0
|
|
||||||
project.licence.url=https://github.com/HighCapable/SweetProperty/blob/master/LICENSE
|
|
||||||
project.developer.id="0"
|
|
||||||
project.developer.name=fankes
|
|
||||||
project.developer.email=qzmmcn@163.com
|
|
||||||
# Gradle Plugin Configuration
|
# Gradle Plugin Configuration
|
||||||
gradle.plugin.moduleName=${project.groupName}.gradle.plugin
|
gradle.plugin.moduleName=${project.groupName}.gradle.plugin
|
||||||
gradle.plugin.implementationClass=${project.groupName}.plugin.SweetPropertyPlugin
|
gradle.plugin.implementationClass=${project.groupName}.plugin.SweetPropertyPlugin
|
||||||
# Maven Publish Configuration
|
# Maven Publish Configuration
|
||||||
maven.publish.scm.connection=scm:git:git://github.com/HighCapable/SweetProperty
|
SONATYPE_HOST=CENTRAL_PORTAL
|
||||||
maven.publish.scm.developerConnection=scm:git:ssh://github.com/HighCapable/SweetProperty
|
RELEASE_SIGNING_ENABLED=true
|
||||||
maven.publish.scm.url=https://github.com/HighCapable/SweetProperty
|
# Maven POM Configuration
|
||||||
|
POM_NAME=SweetProperty
|
||||||
|
POM_ARTIFACT_ID=sweet-property
|
||||||
|
POM_DESCRIPTION=An easy get project properties anywhere Gradle plugin.
|
||||||
|
POM_URL=https://github.com/HighCapable/SweetProperty
|
||||||
|
POM_LICENSE_NAME=Apache License 2.0
|
||||||
|
POM_LICENSE_URL=https://github.com/HighCapable/SweetProperty/blob/master/LICENSE
|
||||||
|
POM_LICENSE_DIST=repo
|
||||||
|
POM_SCM_URL=https://github.com/HighCapable/SweetProperty
|
||||||
|
POM_SCM_CONNECTION=scm:git:git://github.com/HighCapable/SweetProperty
|
||||||
|
POM_SCM_DEV_CONNECTION=scm:git:ssh://github.com/HighCapable/SweetProperty
|
||||||
|
POM_DEVELOPER_ID=0
|
||||||
|
POM_DEVELOPER_NAME=fankes
|
||||||
|
POM_DEVELOPER_EMAIL=qzmmcn@163.com
|
||||||
|
POM_DEVELOPER_URL=https://github.com/fankes
|
@@ -12,18 +12,18 @@ repositories:
|
|||||||
plugins:
|
plugins:
|
||||||
org.jetbrains.kotlin.jvm:
|
org.jetbrains.kotlin.jvm:
|
||||||
alias: kotlin-jvm
|
alias: kotlin-jvm
|
||||||
version: 1.9.10
|
version: 2.1.10
|
||||||
com.vanniktech.maven.publish:
|
com.vanniktech.maven.publish:
|
||||||
alias: maven-publish
|
alias: maven-publish
|
||||||
version: 0.25.3
|
version: 0.31.0
|
||||||
|
|
||||||
libraries:
|
libraries:
|
||||||
com.squareup.okhttp3:
|
com.squareup.okhttp3:
|
||||||
okhttp:
|
okhttp:
|
||||||
version: 4.11.0
|
version: 4.12.0
|
||||||
com.squareup:
|
com.squareup:
|
||||||
kotlinpoet:
|
kotlinpoet:
|
||||||
version: 1.14.2
|
version: 2.1.0
|
||||||
javapoet:
|
javapoet:
|
||||||
version: 1.13.0
|
version: 1.13.0
|
||||||
net.lingala.zip4j:
|
net.lingala.zip4j:
|
||||||
|
2
gradle/wrapper/gradle-wrapper.properties
vendored
2
gradle/wrapper/gradle-wrapper.properties
vendored
@@ -1,5 +1,5 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.3-bin.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-bin.zip
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
@@ -7,8 +7,8 @@ pluginManagement {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
plugins {
|
plugins {
|
||||||
id("com.highcapable.sweetdependency") version "1.0.2"
|
id("com.highcapable.sweetdependency") version "1.0.4"
|
||||||
id("com.highcapable.sweetproperty") version "1.0.3"
|
id("com.highcapable.sweetproperty") version "1.0.8"
|
||||||
}
|
}
|
||||||
sweetDependency {
|
sweetDependency {
|
||||||
isEnableVerboseMode = false
|
isEnableVerboseMode = false
|
||||||
@@ -17,6 +17,10 @@ sweetProperty {
|
|||||||
global {
|
global {
|
||||||
sourcesCode {
|
sourcesCode {
|
||||||
className = rootProject.name
|
className = rootProject.name
|
||||||
|
includeKeys(
|
||||||
|
"^project\\..*\$".toRegex(),
|
||||||
|
"^gradle\\..*\$".toRegex()
|
||||||
|
)
|
||||||
isEnableRestrictedAccess = true
|
isEnableRestrictedAccess = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
2
sweetproperty-gradle-plugin/.gitignore
vendored
2
sweetproperty-gradle-plugin/.gitignore
vendored
@@ -1,2 +0,0 @@
|
|||||||
.gradle
|
|
||||||
build/
|
|
@@ -4,20 +4,25 @@ plugins {
|
|||||||
autowire(libs.plugins.maven.publish)
|
autowire(libs.plugins.maven.publish)
|
||||||
}
|
}
|
||||||
|
|
||||||
allprojects {
|
group = property.project.groupName
|
||||||
group = property.project.groupName
|
version = property.project.version
|
||||||
version = property.project.version
|
|
||||||
}
|
|
||||||
|
|
||||||
java {
|
java {
|
||||||
sourceCompatibility = JavaVersion.VERSION_17
|
sourceCompatibility = JavaVersion.VERSION_21
|
||||||
targetCompatibility = JavaVersion.VERSION_17
|
targetCompatibility = JavaVersion.VERSION_21
|
||||||
withSourcesJar()
|
withSourcesJar()
|
||||||
}
|
}
|
||||||
|
|
||||||
kotlin {
|
kotlin {
|
||||||
jvmToolchain(17)
|
jvmToolchain(21)
|
||||||
sourceSets.all { languageSettings { languageVersion = "2.0" } }
|
sourceSets.all { languageSettings { languageVersion = "2.0" } }
|
||||||
|
compilerOptions {
|
||||||
|
freeCompilerArgs = listOf(
|
||||||
|
"-Xno-param-assertions",
|
||||||
|
"-Xno-call-assertions",
|
||||||
|
"-Xno-receiver-assertions"
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
@@ -34,34 +39,4 @@ gradlePlugin {
|
|||||||
implementationClass = property.gradle.plugin.implementationClass
|
implementationClass = property.gradle.plugin.implementationClass
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
mavenPublishing {
|
|
||||||
coordinates(property.project.groupName, property.project.moduleName, property.project.version)
|
|
||||||
pom {
|
|
||||||
name = property.project.name
|
|
||||||
description = property.project.description
|
|
||||||
url = property.project.url
|
|
||||||
licenses {
|
|
||||||
license {
|
|
||||||
name = property.project.licence.name
|
|
||||||
url = property.project.licence.url
|
|
||||||
distribution = property.project.licence.url
|
|
||||||
}
|
|
||||||
}
|
|
||||||
developers {
|
|
||||||
developer {
|
|
||||||
id = property.project.developer.id
|
|
||||||
name = property.project.developer.name
|
|
||||||
email = property.project.developer.email
|
|
||||||
}
|
|
||||||
}
|
|
||||||
scm {
|
|
||||||
url = property.maven.publish.scm.url
|
|
||||||
connection = property.maven.publish.scm.connection
|
|
||||||
developerConnection = property.maven.publish.scm.developerConnection
|
|
||||||
}
|
|
||||||
}
|
|
||||||
publishToMavenCentral(com.vanniktech.maven.publish.SonatypeHost.S01)
|
|
||||||
signAllPublications()
|
|
||||||
}
|
}
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -48,7 +48,7 @@ internal class ProjectDescriptor private constructor() {
|
|||||||
it.type = Type.SETTINGS
|
it.type = Type.SETTINGS
|
||||||
it.name = name.noBlank() ?: settings.rootProject.name
|
it.name = name.noBlank() ?: settings.rootProject.name
|
||||||
it.currentDir = (if (isRootProject) settings.rootProject else settings.findProject(name))?.projectDir
|
it.currentDir = (if (isRootProject) settings.rootProject else settings.findProject(name))?.projectDir
|
||||||
?: SError.make("Project \"$name\" not found${if (name.startsWith(":").not()) ", $subProjectNotice" else ""}")
|
?: SError.make("Project \"$name\" not found${if (!name.startsWith(":")) ", $subProjectNotice" else ""}")
|
||||||
it.rootDir = settings.rootDir
|
it.rootDir = settings.rootDir
|
||||||
it.homeDir = settings.gradle.gradleUserHomeDir
|
it.homeDir = settings.gradle.gradleUserHomeDir
|
||||||
}
|
}
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -37,7 +37,7 @@ import org.gradle.api.plugins.ExtensionAware
|
|||||||
*/
|
*/
|
||||||
internal fun ExtensionAware.getOrCreate(name: String, clazz: Class<*>, vararg args: Any?) = name.toSafeExtName().let { sName ->
|
internal fun ExtensionAware.getOrCreate(name: String, clazz: Class<*>, vararg args: Any?) = name.toSafeExtName().let { sName ->
|
||||||
runCatching { extensions.create(sName, clazz, *args).asExtension() }.getOrElse {
|
runCatching { extensions.create(sName, clazz, *args).asExtension() }.getOrElse {
|
||||||
if ((it is IllegalArgumentException && it.message?.startsWith("Cannot add extension with name") == true).not()) throw it
|
if (!(it is IllegalArgumentException && it.message?.startsWith("Cannot add extension with name") == true)) throw it
|
||||||
runCatching { extensions.getByName(sName).asExtension() }.getOrNull() ?: SError.make("Create or get extension failed with name \"$sName\"")
|
runCatching { extensions.getByName(sName).asExtension() }.getOrNull() ?: SError.make("Create or get extension failed with name \"$sName\"")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -50,7 +50,7 @@ internal fun ExtensionAware.getOrCreate(name: String, clazz: Class<*>, vararg ar
|
|||||||
*/
|
*/
|
||||||
internal inline fun <reified T> ExtensionAware.getOrCreate(name: String, vararg args: Any?) = name.toSafeExtName().let { sName ->
|
internal inline fun <reified T> ExtensionAware.getOrCreate(name: String, vararg args: Any?) = name.toSafeExtName().let { sName ->
|
||||||
runCatching { extensions.create(sName, T::class.java, *args) as T }.getOrElse {
|
runCatching { extensions.create(sName, T::class.java, *args) as T }.getOrElse {
|
||||||
if ((it is IllegalArgumentException && it.message?.startsWith("Cannot add extension with name") == true).not()) throw it
|
if (!(it is IllegalArgumentException && it.message?.startsWith("Cannot add extension with name") == true)) throw it
|
||||||
runCatching { extensions.getByName(sName) as? T? }.getOrNull() ?: SError.make("Create or get extension failed with name \"$sName\"")
|
runCatching { extensions.getByName(sName) as? T? }.getOrNull() ?: SError.make("Create or get extension failed with name \"$sName\"")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -44,7 +44,7 @@ internal fun Project.fullName(isUseColon: Boolean = true): String {
|
|||||||
project.parent?.also { if (it != it.rootProject) fetchChild(it) }
|
project.parent?.also { if (it != it.rootProject) fetchChild(it) }
|
||||||
baseNames.add(project.name)
|
baseNames.add(project.name)
|
||||||
}; fetchChild(project = this)
|
}; fetchChild(project = this)
|
||||||
return buildString { baseNames.onEach { append(":$it") }.clear() }.let { if (isUseColon && isRoot.not()) it else it.drop(1) }
|
return buildString { baseNames.onEach { append(":$it") }.clear() }.let { if (isUseColon && !isRoot) it else it.drop(1) }
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -56,6 +56,7 @@ internal object DefaultConfigs {
|
|||||||
) = object : ISweetPropertyConfigs.ISourcesCodeGenerateConfigs {
|
) = object : ISweetPropertyConfigs.ISourcesCodeGenerateConfigs {
|
||||||
override val name get() = name
|
override val name get() = name
|
||||||
override val generateDirPath get() = ISweetPropertyConfigs.DEFAULT_GENERATE_DIR_PATH
|
override val generateDirPath get() = ISweetPropertyConfigs.DEFAULT_GENERATE_DIR_PATH
|
||||||
|
override val sourceSetName get() = ISweetPropertyConfigs.DEFAULT_SOURCE_SET_NAME
|
||||||
override val packageName get() = ""
|
override val packageName get() = ""
|
||||||
override val className get() = ""
|
override val className get() = ""
|
||||||
override val isEnableRestrictedAccess get() = false
|
override val isEnableRestrictedAccess get() = false
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -74,6 +74,10 @@ private fun SweetPropertyConfigureExtension.SourcesCodeGenerateConfigureExtensio
|
|||||||
get() = this@create.generateDirPath.noBlank()
|
get() = this@create.generateDirPath.noBlank()
|
||||||
?: global?.generateDirPath?.noBlank()
|
?: global?.generateDirPath?.noBlank()
|
||||||
?: DefaultConfigs.sourcesCodeGenerateConfigs(name, selfBase, globalBase).generateDirPath
|
?: DefaultConfigs.sourcesCodeGenerateConfigs(name, selfBase, globalBase).generateDirPath
|
||||||
|
override val sourceSetName
|
||||||
|
get() = this@create.sourceSetName.noBlank()
|
||||||
|
?: global?.sourceSetName?.noBlank()
|
||||||
|
?: DefaultConfigs.sourcesCodeGenerateConfigs(name, selfBase, globalBase).sourceSetName
|
||||||
override val packageName
|
override val packageName
|
||||||
get() = this@create.packageName.noBlank()
|
get() = this@create.packageName.noBlank()
|
||||||
?: global?.packageName?.noBlank()
|
?: global?.packageName?.noBlank()
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -40,6 +40,11 @@ internal interface ISweetPropertyConfigs {
|
|||||||
*/
|
*/
|
||||||
internal const val DEFAULT_GENERATE_DIR_PATH = "build/generated/${SweetPropertyProperties.PROJECT_MODULE_NAME}"
|
internal const val DEFAULT_GENERATE_DIR_PATH = "build/generated/${SweetPropertyProperties.PROJECT_MODULE_NAME}"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 默认的部署 `sourceSet` 名称
|
||||||
|
*/
|
||||||
|
internal const val DEFAULT_SOURCE_SET_NAME = "main"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 默认的属性配置文件名称
|
* 默认的属性配置文件名称
|
||||||
*
|
*
|
||||||
@@ -91,6 +96,9 @@ internal interface ISweetPropertyConfigs {
|
|||||||
/** 自定义生成的目录路径 */
|
/** 自定义生成的目录路径 */
|
||||||
val generateDirPath: String
|
val generateDirPath: String
|
||||||
|
|
||||||
|
/** 自定义部署的 `sourceSet` 名称 */
|
||||||
|
val sourceSetName: String
|
||||||
|
|
||||||
/** 自定义生成的包名 */
|
/** 自定义生成的包名 */
|
||||||
val packageName: String
|
val packageName: String
|
||||||
|
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -95,11 +95,11 @@ open class SweetPropertyConfigureExtension internal constructor() {
|
|||||||
fun rootProject(action: Action<SubConfigureExtension>) = configureProject(ROOT_PROJECT_TAG, action)
|
fun rootProject(action: Action<SubConfigureExtension>) = configureProject(ROOT_PROJECT_TAG, action)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置指定项目
|
* 配置指定项目 (数组)
|
||||||
* @param name 项目完整名称
|
* @param names 项目完整名称 (数组)
|
||||||
* @param action 配置方法体
|
* @param action 配置方法体
|
||||||
*/
|
*/
|
||||||
fun project(name: String, action: Action<SubConfigureExtension>) = configureProject(name, action)
|
fun project(vararg names: String, action: Action<SubConfigureExtension>) = names.forEach { configureProject(it, action) }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置项目
|
* 配置项目
|
||||||
@@ -173,6 +173,16 @@ open class SweetPropertyConfigureExtension internal constructor() {
|
|||||||
var generateDirPath = ""
|
var generateDirPath = ""
|
||||||
@JvmName("generateDirPath") set
|
@JvmName("generateDirPath") set
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 自定义部署的 `sourceSet` 名称
|
||||||
|
*
|
||||||
|
* 如果你的项目源码部署名称不是默认值 - 可以在这里自定义
|
||||||
|
*
|
||||||
|
* 默认为 [ISweetPropertyConfigs.DEFAULT_SOURCE_SET_NAME]
|
||||||
|
*/
|
||||||
|
var sourceSetName = ""
|
||||||
|
@JvmName("sourceSetName") set
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义生成的包名
|
* 自定义生成的包名
|
||||||
*
|
*
|
||||||
@@ -474,13 +484,13 @@ open class SweetPropertyConfigureExtension internal constructor() {
|
|||||||
|
|
||||||
/** 检查合法包名 */
|
/** 检查合法包名 */
|
||||||
fun String.checkingValidPackageName() {
|
fun String.checkingValidPackageName() {
|
||||||
if (isNotBlank() && matches("^[a-zA-Z_][a-zA-Z0-9_]*(\\.[a-zA-Z_][a-zA-Z0-9_]*)*$".toRegex()).not())
|
if (isNotBlank() && !matches("^[a-zA-Z_][a-zA-Z0-9_]*(\\.[a-zA-Z_][a-zA-Z0-9_]*)*$".toRegex()))
|
||||||
SError.make("Invalid package name \"$this\"")
|
SError.make("Invalid package name \"$this\"")
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 检查合法类名 */
|
/** 检查合法类名 */
|
||||||
fun String.checkingValidClassName() {
|
fun String.checkingValidClassName() {
|
||||||
if (isNotBlank() && matches("^[a-zA-Z][a-zA-Z0-9_]*$".toRegex()).not())
|
if (isNotBlank() && !matches("^[a-zA-Z][a-zA-Z0-9_]*$".toRegex()))
|
||||||
SError.make("Invalid class name \"$this\"")
|
SError.make("Invalid class name \"$this\"")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -27,6 +27,7 @@ import com.highcapable.sweetproperty.plugin.config.proxy.ISweetPropertyConfigs
|
|||||||
import com.highcapable.sweetproperty.plugin.extension.accessors.proxy.IExtensionAccessors
|
import com.highcapable.sweetproperty.plugin.extension.accessors.proxy.IExtensionAccessors
|
||||||
import com.highcapable.sweetproperty.plugin.generator.factory.PropertyMap
|
import com.highcapable.sweetproperty.plugin.generator.factory.PropertyMap
|
||||||
import com.highcapable.sweetproperty.plugin.generator.factory.parseTypedValue
|
import com.highcapable.sweetproperty.plugin.generator.factory.parseTypedValue
|
||||||
|
import com.highcapable.sweetproperty.plugin.generator.factory.toOptimize
|
||||||
import com.highcapable.sweetproperty.utils.capitalize
|
import com.highcapable.sweetproperty.utils.capitalize
|
||||||
import com.highcapable.sweetproperty.utils.debug.SError
|
import com.highcapable.sweetproperty.utils.debug.SError
|
||||||
import com.highcapable.sweetproperty.utils.firstNumberToLetter
|
import com.highcapable.sweetproperty.utils.firstNumberToLetter
|
||||||
@@ -40,6 +41,7 @@ import com.squareup.javapoet.MethodSpec
|
|||||||
import com.squareup.javapoet.TypeSpec
|
import com.squareup.javapoet.TypeSpec
|
||||||
import java.text.SimpleDateFormat
|
import java.text.SimpleDateFormat
|
||||||
import java.util.*
|
import java.util.*
|
||||||
|
import javax.annotation.Nonnull
|
||||||
import javax.lang.model.element.Modifier
|
import javax.lang.model.element.Modifier
|
||||||
import kotlin.properties.Delegates
|
import kotlin.properties.Delegates
|
||||||
|
|
||||||
@@ -84,6 +86,9 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
/** 生成的属性键值连续名称重复次数数组 */
|
/** 生成的属性键值连续名称重复次数数组 */
|
||||||
private val grandSuccessiveDuplicateIndexs = mutableMapOf<String, Int>()
|
private val grandSuccessiveDuplicateIndexs = mutableMapOf<String, Int>()
|
||||||
|
|
||||||
|
/** 生成的属性键值不重复调用方法数组 */
|
||||||
|
private val usedSuccessiveMethods = mutableMapOf<String, MutableList<String>>()
|
||||||
|
|
||||||
/** 生成的属性键值不重复 TAG 数组 */
|
/** 生成的属性键值不重复 TAG 数组 */
|
||||||
private val usedSuccessiveTags = mutableSetOf<String>()
|
private val usedSuccessiveTags = mutableSetOf<String>()
|
||||||
|
|
||||||
@@ -94,7 +99,7 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
*/
|
*/
|
||||||
private inline fun noRepeated(vararg tags: String, block: () -> Unit) {
|
private inline fun noRepeated(vararg tags: String, block: () -> Unit) {
|
||||||
val allTag = tags.joinToString("-")
|
val allTag = tags.joinToString("-")
|
||||||
if (usedSuccessiveTags.contains(allTag).not()) block()
|
if (!usedSuccessiveTags.contains(allTag)) block()
|
||||||
usedSuccessiveTags.add(allTag)
|
usedSuccessiveTags.add(allTag)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -177,9 +182,10 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
*/
|
*/
|
||||||
private fun TypeSpec.Builder.addSuccessiveMethod(accessorsName: String, methodName: String, className: String) =
|
private fun TypeSpec.Builder.addSuccessiveMethod(accessorsName: String, methodName: String, className: String) =
|
||||||
addMethod(
|
addMethod(
|
||||||
MethodSpec.methodBuilder("get${methodName.capitalize()}")
|
MethodSpec.methodBuilder("get${getOrCreateUsedSuccessiveMethodName(methodName, className).capitalize()}")
|
||||||
.addJavadoc("Resolve the \"$accessorsName\" accessors")
|
.addJavadoc("Resolve the \"$accessorsName\" accessors")
|
||||||
.addModifiers(Modifier.PUBLIC, Modifier.FINAL)
|
.addModifiers(Modifier.PUBLIC, Modifier.FINAL)
|
||||||
|
.addAnnotation(Nonnull::class.java)
|
||||||
.returns(className.capitalized().asClassType())
|
.returns(className.capitalized().asClassType())
|
||||||
.addStatement("return ${className.uncapitalized()}")
|
.addStatement("return ${className.uncapitalized()}")
|
||||||
.build()
|
.build()
|
||||||
@@ -189,17 +195,20 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
* 向通用构建器描述类添加最终键值方法
|
* 向通用构建器描述类添加最终键值方法
|
||||||
* @param accessorsName 接续名
|
* @param accessorsName 接续名
|
||||||
* @param methodName 方法名
|
* @param methodName 方法名
|
||||||
|
* @param className 类名
|
||||||
* @param value 键值内容
|
* @param value 键值内容
|
||||||
* @return [TypeSpec.Builder]
|
* @return [TypeSpec.Builder]
|
||||||
*/
|
*/
|
||||||
private fun TypeSpec.Builder.addFinalValueMethod(accessorsName: String, methodName: String, value: Any) =
|
private fun TypeSpec.Builder.addFinalValueMethod(accessorsName: String, methodName: String, className: String, value: Any) =
|
||||||
addMethod(
|
addMethod(
|
||||||
MethodSpec.methodBuilder("get${methodName.capitalize()}").apply {
|
MethodSpec.methodBuilder("get${getOrCreateUsedSuccessiveMethodName(methodName, className).capitalize()}").apply {
|
||||||
val typedValue = value.parseTypedValue(configs.isEnableTypeAutoConversion)
|
val typedValue = value.parseTypedValue(configs.isEnableTypeAutoConversion)
|
||||||
addJavadoc("Resolve the \"$accessorsName\" value ${typedValue.second}")
|
val safeValueForJavadoc = typedValue.second.replace("$", "$$")
|
||||||
|
addJavadoc("Resolve the \"$accessorsName\" value $safeValueForJavadoc")
|
||||||
addModifiers(Modifier.PUBLIC, Modifier.FINAL)
|
addModifiers(Modifier.PUBLIC, Modifier.FINAL)
|
||||||
|
.addAnnotation(Nonnull::class.java)
|
||||||
.returns(typedValue.first.java)
|
.returns(typedValue.first.java)
|
||||||
.addStatement("return ${typedValue.second}")
|
.addStatement("return $safeValueForJavadoc")
|
||||||
}.build()
|
}.build()
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -211,6 +220,20 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
private fun MethodSpec.Builder.addSuccessiveStatement(className: String) =
|
private fun MethodSpec.Builder.addSuccessiveStatement(className: String) =
|
||||||
addStatement("${className.uncapitalized()} = new ${className.capitalized()}()")
|
addStatement("${className.uncapitalized()} = new ${className.capitalized()}()")
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取不重复调用方法名称
|
||||||
|
* @param methodName 方法名
|
||||||
|
* @param className 类名
|
||||||
|
* @return [String]
|
||||||
|
*/
|
||||||
|
private fun getOrCreateUsedSuccessiveMethodName(methodName: String, className: String): String {
|
||||||
|
if (usedSuccessiveMethods[className] == null) usedSuccessiveMethods[className] = mutableListOf()
|
||||||
|
val methods = usedSuccessiveMethods[className]!!
|
||||||
|
val finalName = if (methods.contains(methodName)) "$methodName${methods.filter { it == methodName }.size + 1}" else methodName
|
||||||
|
methods.add(methodName)
|
||||||
|
return finalName
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取、创建通用构建器描述类
|
* 获取、创建通用构建器描述类
|
||||||
* @param name 名称
|
* @param name 名称
|
||||||
@@ -234,9 +257,10 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
*
|
*
|
||||||
* 解析完成后需要调用 [releaseParseTypeSpec] 完成解析
|
* 解析完成后需要调用 [releaseParseTypeSpec] 完成解析
|
||||||
* @param successiveName 连续的名称
|
* @param successiveName 连续的名称
|
||||||
|
* @param key 键值名称 (原始名称)
|
||||||
* @param value 键值内容
|
* @param value 键值内容
|
||||||
*/
|
*/
|
||||||
private fun parseTypeSpec(successiveName: String, value: Any) {
|
private fun parseTypeSpec(successiveName: String, key: String, value: Any) {
|
||||||
/**
|
/**
|
||||||
* 获取生成的属性键值连续名称重复次数
|
* 获取生成的属性键值连续名称重复次数
|
||||||
* @return [Int]
|
* @return [Int]
|
||||||
@@ -258,10 +282,7 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
var grandAcccessorsName = ""
|
var grandAcccessorsName = ""
|
||||||
var grandSuccessiveName = ""
|
var grandSuccessiveName = ""
|
||||||
val successiveNames = mutableListOf<Triple<String, String, String>>()
|
val successiveNames = mutableListOf<Triple<String, String, String>>()
|
||||||
val splitNames = replace(".", "|").replace("-", "|")
|
val splitNames = split("_").dropWhile { it.isBlank() }.ifEmpty { listOf(this) }
|
||||||
.replace("_", "|").replace(" ", "_")
|
|
||||||
.split("|").dropWhile { it.isBlank() }
|
|
||||||
.ifEmpty { listOf(this) }
|
|
||||||
splitNames.forEach { eachName ->
|
splitNames.forEach { eachName ->
|
||||||
val name = eachName.capitalize().toNonJavaName().firstNumberToLetter()
|
val name = eachName.capitalize().toNonJavaName().firstNumberToLetter()
|
||||||
grandAcccessorsName += if (grandAcccessorsName.isNotBlank()) ".$eachName" else eachName
|
grandAcccessorsName += if (grandAcccessorsName.isNotBlank()) ".$eachName" else eachName
|
||||||
@@ -279,9 +300,10 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
val nextAccessorsName = nextItem?.first ?: ""
|
val nextAccessorsName = nextItem?.first ?: ""
|
||||||
val nextClassName = nextItem?.second ?: ""
|
val nextClassName = nextItem?.second ?: ""
|
||||||
val nextMethodName = nextItem?.third ?: ""
|
val nextMethodName = nextItem?.third ?: ""
|
||||||
|
val lastClassName = lastItem?.second ?: ""
|
||||||
val lastMethodName = lastItem?.third ?: ""
|
val lastMethodName = lastItem?.third ?: ""
|
||||||
val isPreLastIndex = index == successiveNames.lastIndex - 1
|
val isPreLastIndex = index == successiveNames.lastIndex - 1
|
||||||
if (successiveNames.size == 1) getOrCreateClassSpec(TOP_SUCCESSIVE_NAME).addFinalValueMethod(successiveName, methodName, value)
|
if (successiveNames.size == 1) getOrCreateClassSpec(TOP_SUCCESSIVE_NAME).addFinalValueMethod(key, methodName, className, value)
|
||||||
if (index == successiveNames.lastIndex) return@forEachIndexed
|
if (index == successiveNames.lastIndex) return@forEachIndexed
|
||||||
if (index == 0) noRepeated(TOP_SUCCESSIVE_NAME, methodName, className) {
|
if (index == 0) noRepeated(TOP_SUCCESSIVE_NAME, methodName, className) {
|
||||||
getOrCreateClassSpec(TOP_SUCCESSIVE_NAME, accessorsName)
|
getOrCreateClassSpec(TOP_SUCCESSIVE_NAME, accessorsName)
|
||||||
@@ -291,12 +313,12 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
}
|
}
|
||||||
noRepeated(className, nextMethodName, nextClassName) {
|
noRepeated(className, nextMethodName, nextClassName) {
|
||||||
getOrCreateClassSpec(className, accessorsName).apply {
|
getOrCreateClassSpec(className, accessorsName).apply {
|
||||||
if (isPreLastIndex.not()) {
|
if (!isPreLastIndex) {
|
||||||
addSuccessiveField(nextAccessorsName, nextClassName)
|
addSuccessiveField(nextAccessorsName, nextClassName)
|
||||||
addSuccessiveMethod(nextAccessorsName, nextMethodName, nextClassName)
|
addSuccessiveMethod(nextAccessorsName, nextMethodName, nextClassName)
|
||||||
} else addFinalValueMethod(successiveName, lastMethodName, value)
|
} else addFinalValueMethod(key, lastMethodName, lastClassName, value)
|
||||||
}
|
}
|
||||||
if (isPreLastIndex.not()) preAddConstructorSpecNames.add(className to nextClassName)
|
if (!isPreLastIndex) preAddConstructorSpecNames.add(className to nextClassName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -342,6 +364,7 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
preAddConstructorSpecNames.clear()
|
preAddConstructorSpecNames.clear()
|
||||||
grandSuccessiveNames.clear()
|
grandSuccessiveNames.clear()
|
||||||
grandSuccessiveDuplicateIndexs.clear()
|
grandSuccessiveDuplicateIndexs.clear()
|
||||||
|
usedSuccessiveMethods.clear()
|
||||||
usedSuccessiveTags.clear()
|
usedSuccessiveTags.clear()
|
||||||
if (isClearAll) memoryExtensionClasses.clear()
|
if (isClearAll) memoryExtensionClasses.clear()
|
||||||
}
|
}
|
||||||
@@ -367,8 +390,8 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
val keyValues = allKeyValues[index]
|
val keyValues = allKeyValues[index]
|
||||||
clearGeneratedData()
|
clearGeneratedData()
|
||||||
createTopClassSpec(configs)
|
createTopClassSpec(configs)
|
||||||
keyValues.forEach { (key, value) ->
|
keyValues.toOptimize().forEach { (key, value) ->
|
||||||
parseTypeSpec(key, value)
|
parseTypeSpec(key, value.first, value.second)
|
||||||
releaseParseTypeSpec()
|
releaseParseTypeSpec()
|
||||||
}; files.add(buildTypeSpec().createJavaFile(ACCESSORS_PACKAGE_NAME))
|
}; files.add(buildTypeSpec().createJavaFile(ACCESSORS_PACKAGE_NAME))
|
||||||
}; files
|
}; files
|
||||||
@@ -380,10 +403,15 @@ internal class PropertiesAccessorsGenerator {
|
|||||||
*/
|
*/
|
||||||
internal val compileStubFiles get(): List<JavaFile> {
|
internal val compileStubFiles get(): List<JavaFile> {
|
||||||
val stubFiles = mutableListOf<JavaFile>()
|
val stubFiles = mutableListOf<JavaFile>()
|
||||||
|
val nonnullFile =
|
||||||
|
TypeSpec.annotationBuilder(Nonnull::class.java.simpleName)
|
||||||
|
.addModifiers(Modifier.PUBLIC)
|
||||||
|
.build().createJavaFile(Nonnull::class.java.packageName)
|
||||||
val iExtensionAccessorsFile =
|
val iExtensionAccessorsFile =
|
||||||
TypeSpec.interfaceBuilder(IExtensionAccessors::class.java.simpleName)
|
TypeSpec.interfaceBuilder(IExtensionAccessors::class.java.simpleName)
|
||||||
.addModifiers(Modifier.PUBLIC)
|
.addModifiers(Modifier.PUBLIC)
|
||||||
.build().createJavaFile(IExtensionAccessors::class.java.packageName)
|
.build().createJavaFile(IExtensionAccessors::class.java.packageName)
|
||||||
|
stubFiles.add(nonnullFile)
|
||||||
stubFiles.add(iExtensionAccessorsFile)
|
stubFiles.add(iExtensionAccessorsFile)
|
||||||
return stubFiles
|
return stubFiles
|
||||||
}
|
}
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -25,9 +25,10 @@ import com.highcapable.sweetproperty.SweetProperty
|
|||||||
import com.highcapable.sweetproperty.plugin.config.proxy.ISweetPropertyConfigs
|
import com.highcapable.sweetproperty.plugin.config.proxy.ISweetPropertyConfigs
|
||||||
import com.highcapable.sweetproperty.plugin.generator.factory.PropertyMap
|
import com.highcapable.sweetproperty.plugin.generator.factory.PropertyMap
|
||||||
import com.highcapable.sweetproperty.plugin.generator.factory.parseTypedValue
|
import com.highcapable.sweetproperty.plugin.generator.factory.parseTypedValue
|
||||||
|
import com.highcapable.sweetproperty.plugin.generator.factory.toOptimize
|
||||||
|
import com.highcapable.sweetproperty.plugin.generator.factory.toUnderscores
|
||||||
import com.highcapable.sweetproperty.utils.debug.SError
|
import com.highcapable.sweetproperty.utils.debug.SError
|
||||||
import com.highcapable.sweetproperty.utils.firstNumberToLetter
|
import com.highcapable.sweetproperty.utils.firstNumberToLetter
|
||||||
import com.highcapable.sweetproperty.utils.underscore
|
|
||||||
import com.squareup.kotlinpoet.FileSpec
|
import com.squareup.kotlinpoet.FileSpec
|
||||||
import com.squareup.kotlinpoet.KModifier
|
import com.squareup.kotlinpoet.KModifier
|
||||||
import com.squareup.kotlinpoet.PropertySpec
|
import com.squareup.kotlinpoet.PropertySpec
|
||||||
@@ -67,13 +68,13 @@ internal class PropertiesSourcesGenerator {
|
|||||||
""".trimIndent()
|
""".trimIndent()
|
||||||
)
|
)
|
||||||
if (configs.isEnableRestrictedAccess) addModifiers(KModifier.INTERNAL)
|
if (configs.isEnableRestrictedAccess) addModifiers(KModifier.INTERNAL)
|
||||||
keyValues.forEach { (key, value) ->
|
keyValues.toOptimize().toUnderscores().forEach { (key, value) ->
|
||||||
val typedValue = value.parseTypedValue(configs.isEnableTypeAutoConversion)
|
val typedValue = value.second.parseTypedValue(configs.isEnableTypeAutoConversion)
|
||||||
addProperty(PropertySpec.builder(key.firstNumberToLetter().underscore(), typedValue.first).apply {
|
addProperty(PropertySpec.builder(key.firstNumberToLetter(), typedValue.first).apply {
|
||||||
addKdoc("Resolve the \"$key\" value ${typedValue.second}")
|
addKdoc("Resolve the \"${value.first.toKotlinPoetNoEscape()}\" value ${typedValue.second.toKotlinPoetNoEscape()}")
|
||||||
if (configs.isEnableRestrictedAccess) addModifiers(KModifier.INTERNAL)
|
if (configs.isEnableRestrictedAccess) addModifiers(KModifier.INTERNAL)
|
||||||
addModifiers(KModifier.CONST)
|
addModifiers(KModifier.CONST)
|
||||||
initializer(typedValue.second.toKotlinPoetSpace())
|
initializer(typedValue.second.toKotlinPoetNoEscape().toKotlinPoetSpace())
|
||||||
}.build())
|
}.build())
|
||||||
}
|
}
|
||||||
}.build())
|
}.build())
|
||||||
@@ -85,4 +86,10 @@ internal class PropertiesSourcesGenerator {
|
|||||||
* @return [String]
|
* @return [String]
|
||||||
*/
|
*/
|
||||||
private fun String.toKotlinPoetSpace() = replace(" ", "·")
|
private fun String.toKotlinPoetSpace() = replace(" ", "·")
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 转换到 KotlinPoet 非转义字符内容
|
||||||
|
* @return [String]
|
||||||
|
*/
|
||||||
|
private fun String.toKotlinPoetNoEscape() = replace("%", "%%")
|
||||||
}
|
}
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -21,14 +21,24 @@
|
|||||||
*/
|
*/
|
||||||
package com.highcapable.sweetproperty.plugin.generator.factory
|
package com.highcapable.sweetproperty.plugin.generator.factory
|
||||||
|
|
||||||
|
import com.highcapable.sweetproperty.utils.underscore
|
||||||
import kotlin.reflect.KClass
|
import kotlin.reflect.KClass
|
||||||
|
|
||||||
/** 属性键值数组类型定义 */
|
/** 属性键值数组类型定义 */
|
||||||
internal typealias PropertyMap = MutableMap<String, Any>
|
internal typealias PropertyMap = MutableMap<String, Any>
|
||||||
|
|
||||||
|
/** 属性键值优化数组类型定义 */
|
||||||
|
internal typealias PropertyOptimizeMap = MutableMap<String, Pair<String, Any>>
|
||||||
|
|
||||||
/** 属性键值规则类型定义 */
|
/** 属性键值规则类型定义 */
|
||||||
internal typealias PropertyValueRule = (value: String) -> String
|
internal typealias PropertyValueRule = (value: String) -> String
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 移除键值内容自动转换类型的引号
|
||||||
|
* @return [String]
|
||||||
|
*/
|
||||||
|
internal fun String.removeAutoConversion() = removeSurrounding("\"").removeSurrounding("'")
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 解析到键值内容类型
|
* 解析到键值内容类型
|
||||||
* @param isAutoConversion 是否自动转换类型
|
* @param isAutoConversion 是否自动转换类型
|
||||||
@@ -46,16 +56,50 @@ internal fun Any.parseTypedValue(isAutoConversion: Boolean): Pair<KClass<*>, Str
|
|||||||
it.drop(1).dropLast(1)
|
it.drop(1).dropLast(1)
|
||||||
} else it.replace("\"", "\\\"")
|
} else it.replace("\"", "\\\"")
|
||||||
}
|
}
|
||||||
if (isAutoConversion.not()) return Pair(String::class, "\"$valueString\"")
|
if (!isAutoConversion) return Pair(String::class, "\"$valueString\"")
|
||||||
|
val trimmed = valueString.trim()
|
||||||
val typeSpec = when {
|
val typeSpec = when {
|
||||||
isStringType -> String::class
|
isStringType || trimmed.any { !it.isDigit() && it != '.' && it != '-' } -> String::class
|
||||||
valueString.trim().toIntOrNull() != null -> Int::class
|
trimmed.toIntOrNull() != null -> Int::class
|
||||||
valueString.trim().toLongOrNull() != null -> Long::class
|
trimmed.toLongOrNull() != null -> Long::class
|
||||||
valueString.trim().toDoubleOrNull() != null -> Double::class
|
trimmed.toDoubleOrNull() != null -> Double::class
|
||||||
valueString.trim().toFloatOrNull() != null -> Float::class
|
trimmed.toFloatOrNull() != null -> Float::class
|
||||||
valueString.trim() == "true" || valueString.trim() == "false" -> Boolean::class
|
trimmed == "true" || trimmed == "false" -> Boolean::class
|
||||||
else -> String::class
|
else -> String::class
|
||||||
}; return Pair(typeSpec, if (typeSpec == String::class) "\"$valueString\"" else valueString.let {
|
}
|
||||||
if (typeSpec == Long::class && it.endsWith("L").not()) "${it}L" else it
|
val finalValue = when (typeSpec) {
|
||||||
})
|
String::class -> "\"$valueString\""
|
||||||
|
Long::class -> if (trimmed.endsWith("L")) trimmed else "${trimmed}L"
|
||||||
|
else -> trimmed
|
||||||
|
}; return typeSpec to finalValue
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* [PropertyMap] 转换到 [PropertyOptimizeMap]
|
||||||
|
*
|
||||||
|
* 替换可能的键值名称特殊字符内容并保留原始键值名称
|
||||||
|
* @return [PropertyOptimizeMap]
|
||||||
|
*/
|
||||||
|
internal fun PropertyMap.toOptimize(): PropertyOptimizeMap {
|
||||||
|
val newMap: PropertyOptimizeMap = mutableMapOf()
|
||||||
|
var uniqueNumber = 1
|
||||||
|
forEach { (key, value) ->
|
||||||
|
var newKey = key.replace("\\W".toRegex(), "_")
|
||||||
|
while (newMap.containsKey(newKey)) newKey = "$newKey${++uniqueNumber}"
|
||||||
|
newMap[newKey] = key to value
|
||||||
|
}; return newMap
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* [PropertyOptimizeMap] 转换为大写下划线命名
|
||||||
|
* @return [PropertyOptimizeMap]
|
||||||
|
*/
|
||||||
|
internal fun PropertyOptimizeMap.toUnderscores(): PropertyOptimizeMap {
|
||||||
|
val newMap: PropertyOptimizeMap = mutableMapOf()
|
||||||
|
var uniqueNumber = 1
|
||||||
|
forEach { (key, value) ->
|
||||||
|
var newKey = key.underscore()
|
||||||
|
while (newMap.containsKey(newKey)) newKey = "$newKey${++uniqueNumber}"
|
||||||
|
newMap[newKey] = value.first to value.second
|
||||||
|
}; return newMap
|
||||||
}
|
}
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -35,8 +35,8 @@ import javax.xml.parsers.DocumentBuilderFactory
|
|||||||
*/
|
*/
|
||||||
internal object PluginUpdateHelper {
|
internal object PluginUpdateHelper {
|
||||||
|
|
||||||
/** OSS Release URL 地址 */
|
/** Maven Central Release URL 地址 */
|
||||||
private const val SONATYPE_OSS_RELEASES_URL = "https://s01.oss.sonatype.org/content/repositories/releases"
|
private const val SONATYPE_OSS_RELEASES_URL = "https://repo1.maven.org/maven2"
|
||||||
|
|
||||||
/** 依赖配置文件名 */
|
/** 依赖配置文件名 */
|
||||||
private const val METADATA_FILE_NAME = "maven-metadata.xml"
|
private const val METADATA_FILE_NAME = "maven-metadata.xml"
|
||||||
@@ -73,7 +73,7 @@ internal object PluginUpdateHelper {
|
|||||||
* @return [String]
|
* @return [String]
|
||||||
*/
|
*/
|
||||||
private fun String.findLatest() = runCatching {
|
private fun String.findLatest() = runCatching {
|
||||||
if ((contains("<metadata ") || contains("<metadata>")).not() || endsWith("</metadata>").not()) return@runCatching ""
|
if (!(contains("<metadata ") || contains("<metadata>")) || !endsWith("</metadata>")) return@runCatching ""
|
||||||
DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(InputSource(StringReader(this))).let { document ->
|
DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(InputSource(StringReader(this))).let { document ->
|
||||||
document.getElementsByTagName("latest")?.let { if (it.length > 0) it.item(0)?.textContent ?: "" else "" }
|
document.getElementsByTagName("latest")?.let { if (it.length > 0) it.item(0)?.textContent ?: "" else "" }
|
||||||
}
|
}
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -36,10 +36,12 @@ import com.highcapable.sweetproperty.plugin.config.type.GenerateLocationType
|
|||||||
import com.highcapable.sweetproperty.plugin.generator.PropertiesAccessorsGenerator
|
import com.highcapable.sweetproperty.plugin.generator.PropertiesAccessorsGenerator
|
||||||
import com.highcapable.sweetproperty.plugin.generator.PropertiesSourcesGenerator
|
import com.highcapable.sweetproperty.plugin.generator.PropertiesSourcesGenerator
|
||||||
import com.highcapable.sweetproperty.plugin.generator.factory.PropertyMap
|
import com.highcapable.sweetproperty.plugin.generator.factory.PropertyMap
|
||||||
|
import com.highcapable.sweetproperty.plugin.generator.factory.removeAutoConversion
|
||||||
import com.highcapable.sweetproperty.utils.camelcase
|
import com.highcapable.sweetproperty.utils.camelcase
|
||||||
import com.highcapable.sweetproperty.utils.code.entity.MavenPomData
|
import com.highcapable.sweetproperty.utils.code.entity.MavenPomData
|
||||||
import com.highcapable.sweetproperty.utils.code.factory.compile
|
import com.highcapable.sweetproperty.utils.code.factory.compile
|
||||||
import com.highcapable.sweetproperty.utils.debug.SError
|
import com.highcapable.sweetproperty.utils.debug.SError
|
||||||
|
import com.highcapable.sweetproperty.utils.debug.SLog
|
||||||
import com.highcapable.sweetproperty.utils.flatted
|
import com.highcapable.sweetproperty.utils.flatted
|
||||||
import com.highcapable.sweetproperty.utils.hasInterpolation
|
import com.highcapable.sweetproperty.utils.hasInterpolation
|
||||||
import com.highcapable.sweetproperty.utils.isEmpty
|
import com.highcapable.sweetproperty.utils.isEmpty
|
||||||
@@ -48,7 +50,6 @@ import com.highcapable.sweetproperty.utils.noEmpty
|
|||||||
import com.highcapable.sweetproperty.utils.replaceInterpolation
|
import com.highcapable.sweetproperty.utils.replaceInterpolation
|
||||||
import com.highcapable.sweetproperty.utils.toStringMap
|
import com.highcapable.sweetproperty.utils.toStringMap
|
||||||
import com.highcapable.sweetproperty.utils.uppercamelcase
|
import com.highcapable.sweetproperty.utils.uppercamelcase
|
||||||
import org.gradle.api.DomainObjectCollection
|
|
||||||
import org.gradle.api.Project
|
import org.gradle.api.Project
|
||||||
import org.gradle.api.initialization.Settings
|
import org.gradle.api.initialization.Settings
|
||||||
import java.io.File
|
import java.io.File
|
||||||
@@ -102,7 +103,7 @@ internal object PropertiesDeployHelper {
|
|||||||
internal fun initialize(settings: Settings, configs: ISweetPropertyConfigs) {
|
internal fun initialize(settings: Settings, configs: ISweetPropertyConfigs) {
|
||||||
this.configs = configs
|
this.configs = configs
|
||||||
checkingConfigsModified(settings)
|
checkingConfigsModified(settings)
|
||||||
if (configs.isEnable.not()) return
|
if (!configs.isEnable) return
|
||||||
generatedAccessors(settings)
|
generatedAccessors(settings)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -111,7 +112,7 @@ internal object PropertiesDeployHelper {
|
|||||||
* @param rootProject 当前根项目
|
* @param rootProject 当前根项目
|
||||||
*/
|
*/
|
||||||
internal fun resolve(rootProject: Project) {
|
internal fun resolve(rootProject: Project) {
|
||||||
if (configs.isEnable.not()) return
|
if (!configs.isEnable) return
|
||||||
resolveAccessors(rootProject)
|
resolveAccessors(rootProject)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -120,7 +121,7 @@ internal object PropertiesDeployHelper {
|
|||||||
* @param rootProject 当前根项目
|
* @param rootProject 当前根项目
|
||||||
*/
|
*/
|
||||||
internal fun deploy(rootProject: Project) {
|
internal fun deploy(rootProject: Project) {
|
||||||
if (configs.isEnable.not()) return
|
if (!configs.isEnable) return
|
||||||
deployAccessors(rootProject)
|
deployAccessors(rootProject)
|
||||||
deploySourcesCode(rootProject)
|
deploySourcesCode(rootProject)
|
||||||
}
|
}
|
||||||
@@ -152,13 +153,13 @@ internal object PropertiesDeployHelper {
|
|||||||
allConfigs.add(configs.global.buildScript)
|
allConfigs.add(configs.global.buildScript)
|
||||||
}
|
}
|
||||||
configs.projects.forEach { (name, subConfigs) ->
|
configs.projects.forEach { (name, subConfigs) ->
|
||||||
if (subConfigs.buildScript.isEnable.not()) return@forEach
|
if (!subConfigs.buildScript.isEnable) return@forEach
|
||||||
allProperties.add(generatedProperties(subConfigs.buildScript, ProjectDescriptor.create(settings, name)))
|
allProperties.add(generatedProperties(subConfigs.buildScript, ProjectDescriptor.create(settings, name)))
|
||||||
allConfigs.add(subConfigs.buildScript)
|
allConfigs.add(subConfigs.buildScript)
|
||||||
}
|
}
|
||||||
if (isConfigsModified.not() &&
|
if (!isConfigsModified &&
|
||||||
allProperties == cachedSettingsProperties &&
|
allProperties == cachedSettingsProperties &&
|
||||||
accessorsDir.resolve(accessorsPomData.relativePomPath).isEmpty().not()
|
!accessorsDir.resolve(accessorsPomData.relativePomPath).isEmpty()
|
||||||
) return
|
) return
|
||||||
cachedSettingsProperties = allProperties
|
cachedSettingsProperties = allProperties
|
||||||
accessorsGenerator.build(allConfigs, allProperties).compile(accessorsPomData, accessorsDir.absolutePath, accessorsGenerator.compileStubFiles)
|
accessorsGenerator.build(allConfigs, allProperties).compile(accessorsPomData, accessorsDir.absolutePath, accessorsGenerator.compileStubFiles)
|
||||||
@@ -169,7 +170,7 @@ internal object PropertiesDeployHelper {
|
|||||||
* @param rootProject 当前根项目
|
* @param rootProject 当前根项目
|
||||||
*/
|
*/
|
||||||
private fun resolveAccessors(rootProject: Project) {
|
private fun resolveAccessors(rootProject: Project) {
|
||||||
if (accessorsDir.resolve(accessorsPomData.relativePomPath).isEmpty().not())
|
if (!accessorsDir.resolve(accessorsPomData.relativePomPath).isEmpty())
|
||||||
rootProject.addDependencyToBuildScript(accessorsDir.absolutePath, accessorsPomData)
|
rootProject.addDependencyToBuildScript(accessorsDir.absolutePath, accessorsPomData)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -181,7 +182,7 @@ internal object PropertiesDeployHelper {
|
|||||||
/** 部署扩展方法 */
|
/** 部署扩展方法 */
|
||||||
fun Project.deploy() {
|
fun Project.deploy() {
|
||||||
val configs = configs.with(this).buildScript
|
val configs = configs.with(this).buildScript
|
||||||
if (configs.isEnable.not()) return
|
if (!configs.isEnable) return
|
||||||
val className = accessorsGenerator.propertiesClass(configs.name)
|
val className = accessorsGenerator.propertiesClass(configs.name)
|
||||||
val accessorsClass = loadBuildScriptClass(className) ?: SError.make(
|
val accessorsClass = loadBuildScriptClass(className) ?: SError.make(
|
||||||
"""
|
"""
|
||||||
@@ -205,12 +206,14 @@ internal object PropertiesDeployHelper {
|
|||||||
fun Project.generate() {
|
fun Project.generate() {
|
||||||
val configs = configs.with(this).sourcesCode
|
val configs = configs.with(this).sourcesCode
|
||||||
val outputDir = file(configs.generateDirPath)
|
val outputDir = file(configs.generateDirPath)
|
||||||
if (configs.isEnable.not()) return
|
if (!configs.isEnable) return
|
||||||
val properties = generatedProperties(configs, ProjectDescriptor.create(project = this))
|
val properties = generatedProperties(configs, ProjectDescriptor.create(project = this))
|
||||||
if (isConfigsModified.not() && properties == cachedProjectProperties[fullName()] && outputDir.isEmpty().not()) {
|
if (!isConfigsModified && properties == cachedProjectProperties[fullName()] && !outputDir.isEmpty()) {
|
||||||
if (configs.isEnable) configureSourceSets(project = this)
|
if (configs.isEnable) configureSourceSets(project = this)
|
||||||
return
|
return
|
||||||
}; outputDir.apply { if (exists()) deleteRecursively() }
|
}; outputDir.apply { if (exists()) deleteRecursively() }
|
||||||
|
// 每次都会重新创建目录
|
||||||
|
outputDir.mkdirs()
|
||||||
cachedProjectProperties[fullName()] = properties
|
cachedProjectProperties[fullName()] = properties
|
||||||
val packageName = generatedPackageName(configs, project = this)
|
val packageName = generatedPackageName(configs, project = this)
|
||||||
val className = generatedClassName(configs, project = this)
|
val className = generatedClassName(configs, project = this)
|
||||||
@@ -226,16 +229,26 @@ internal object PropertiesDeployHelper {
|
|||||||
* @param project 当前项目
|
* @param project 当前项目
|
||||||
*/
|
*/
|
||||||
private fun configureSourceSets(project: Project) {
|
private fun configureSourceSets(project: Project) {
|
||||||
fun Project.deploySourceSets(name: String) = runCatching {
|
val configs = configs.with(project).sourcesCode
|
||||||
|
fun Project.deploySourceSet(name: String, sourceSetName: String = configs.sourceSetName) = runCatching {
|
||||||
val extension = get(name)
|
val extension = get(name)
|
||||||
val collection = extension.javaClass.getMethod("getSourceSets").invoke(extension) as DomainObjectCollection<*>
|
val collection = extension.javaClass.getMethod("getSourceSets").invoke(extension) as? Iterable<*>?
|
||||||
collection.configureEach {
|
val mainSet = collection?.firstOrNull {
|
||||||
val kotlin = javaClass.getMethod("getKotlin").invoke(this)
|
it?.javaClass?.getMethod("getName")?.invoke(it) == sourceSetName
|
||||||
kotlin.javaClass.getMethod("srcDir", Any::class.java).invoke(kotlin, configs.with(project).sourcesCode.generateDirPath)
|
} ?: return@runCatching SLog.warn("Could not found source set \"$sourceSetName\" for $name extension")
|
||||||
}
|
val kotlin = mainSet.javaClass.getMethod("getKotlin").invoke(mainSet)
|
||||||
|
val generateDir = configs.generateDirPath
|
||||||
|
val generateFile = File(generateDir)
|
||||||
|
// 确保目录存在
|
||||||
|
if (!generateFile.exists()) generateFile.mkdirs()
|
||||||
|
val srcDirs = kotlin.javaClass.getMethod("getSrcDirs").invoke(kotlin) as Set<*>
|
||||||
|
val alreadyAdded = srcDirs.any { it is File && it.canonicalPath == generateFile.canonicalPath }
|
||||||
|
if (!alreadyAdded) kotlin.javaClass.getMethod("srcDir", Any::class.java).invoke(kotlin, generateFile)
|
||||||
|
}.onFailure {
|
||||||
|
SLog.error(msg = "Failed to deploy source set \"$sourceSetName\" for $name extension\n${it.stackTraceToString()}")
|
||||||
}
|
}
|
||||||
if (project.hasExtension("kotlin")) project.deploySourceSets(name = "kotlin")
|
if (project.hasExtension("kotlin")) project.deploySourceSet(name = "kotlin")
|
||||||
if (project.hasExtension("android")) project.deploySourceSets(name = "android")
|
if (project.hasExtension("android")) project.deploySourceSet(name = "android")
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -293,7 +306,8 @@ internal object PropertiesDeployHelper {
|
|||||||
fun String.resolveValue(): String = replaceInterpolation { matchKey ->
|
fun String.resolveValue(): String = replaceInterpolation { matchKey ->
|
||||||
if (resolveKeys.size > 5) SError.make("Key \"$key\" has been called recursively multiple times of those $resolveKeys")
|
if (resolveKeys.size > 5) SError.make("Key \"$key\" has been called recursively multiple times of those $resolveKeys")
|
||||||
resolveKeys.add(matchKey)
|
resolveKeys.add(matchKey)
|
||||||
val resolveValue = if (configs.isEnableValueInterpolation) resolveKeyValues[matchKey] ?: "" else matchKey
|
var resolveValue = if (configs.isEnableValueInterpolation) resolveKeyValues[matchKey] ?: "" else matchKey
|
||||||
|
resolveValue = resolveValue.removeAutoConversion()
|
||||||
if (resolveValue.hasInterpolation()) resolveValue.resolveValue()
|
if (resolveValue.hasInterpolation()) resolveValue.resolveValue()
|
||||||
else resolveValue
|
else resolveValue
|
||||||
}
|
}
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -52,7 +52,7 @@ internal fun String.parseUnixFileSeparator() = replace("\\", "/")
|
|||||||
* - 如果文件不存在 - 返回 true
|
* - 如果文件不存在 - 返回 true
|
||||||
* @return [Boolean]
|
* @return [Boolean]
|
||||||
*/
|
*/
|
||||||
internal fun File.isEmpty() = exists().not() || isDirectory.not() || listFiles().isNullOrEmpty()
|
internal fun File.isEmpty() = !exists() || !isDirectory || listFiles().isNullOrEmpty()
|
||||||
|
|
||||||
/** 删除目录下的空子目录 */
|
/** 删除目录下的空子目录 */
|
||||||
internal fun File.deleteEmptyRecursively() {
|
internal fun File.deleteEmptyRecursively() {
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
@@ -59,7 +59,7 @@ internal object CodeCompiler {
|
|||||||
if (files.isEmpty()) {
|
if (files.isEmpty()) {
|
||||||
if (outputDir.exists()) outputDir.deleteRecursively()
|
if (outputDir.exists()) outputDir.deleteRecursively()
|
||||||
return
|
return
|
||||||
} else outputDir.also { if (it.exists().not()) it.mkdirs() }
|
} else outputDir.also { if (!it.exists()) it.mkdirs() }
|
||||||
val outputBuildDir = "$outputDirPath/build".toFile().also { if (it.exists()) it.deleteRecursively(); it.mkdirs() }
|
val outputBuildDir = "$outputDirPath/build".toFile().also { if (it.exists()) it.deleteRecursively(); it.mkdirs() }
|
||||||
val outputClassesDir = "${outputBuildDir.absolutePath}/classes".toFile().apply { mkdirs() }
|
val outputClassesDir = "${outputBuildDir.absolutePath}/classes".toFile().apply { mkdirs() }
|
||||||
val outputSourcesDir = "${outputBuildDir.absolutePath}/sources".toFile().apply { mkdirs() }
|
val outputSourcesDir = "${outputBuildDir.absolutePath}/sources".toFile().apply { mkdirs() }
|
||||||
@@ -99,7 +99,7 @@ internal object CodeCompiler {
|
|||||||
* @param sourcesDir 编译源码目录
|
* @param sourcesDir 编译源码目录
|
||||||
*/
|
*/
|
||||||
private fun createJarAndPom(pomData: MavenPomData, outputDir: File, buildDir: File, classesDir: File, sourcesDir: File) {
|
private fun createJarAndPom(pomData: MavenPomData, outputDir: File, buildDir: File, classesDir: File, sourcesDir: File) {
|
||||||
val pomDir = outputDir.resolve(pomData.relativePomPath).also { if (it.exists().not()) it.mkdirs() }
|
val pomDir = outputDir.resolve(pomData.relativePomPath).also { if (!it.exists()) it.mkdirs() }
|
||||||
packageToJar(classesDir, pomDir, pomData, isSourcesJar = false)
|
packageToJar(classesDir, pomDir, pomData, isSourcesJar = false)
|
||||||
packageToJar(sourcesDir, pomDir, pomData, isSourcesJar = true)
|
packageToJar(sourcesDir, pomDir, pomData, isSourcesJar = true)
|
||||||
writePom(pomDir, pomData)
|
writePom(pomDir, pomData)
|
||||||
@@ -159,7 +159,7 @@ internal object CodeCompiler {
|
|||||||
* @throws IllegalStateException 如果编译输出目录不存在
|
* @throws IllegalStateException 如果编译输出目录不存在
|
||||||
*/
|
*/
|
||||||
private fun packageToJar(buildDir: File, outputDir: File, pomData: MavenPomData, isSourcesJar: Boolean) {
|
private fun packageToJar(buildDir: File, outputDir: File, pomData: MavenPomData, isSourcesJar: Boolean) {
|
||||||
if (buildDir.exists().not()) SError.make("Jar file output path not found: ${buildDir.absolutePath}")
|
if (!buildDir.exists()) SError.make("Jar file output path not found: ${buildDir.absolutePath}")
|
||||||
val jarFile = outputDir.resolve("${pomData.artifactId}-${pomData.version}${if (isSourcesJar) "-sources" else ""}.jar")
|
val jarFile = outputDir.resolve("${pomData.artifactId}-${pomData.version}${if (isSourcesJar) "-sources" else ""}.jar")
|
||||||
if (jarFile.exists()) jarFile.delete()
|
if (jarFile.exists()) jarFile.delete()
|
||||||
ZipFile(jarFile).addFolder(buildDir, ZipParameters().apply { isIncludeRootFolder = false })
|
ZipFile(jarFile).addFolder(buildDir, ZipParameters().apply { isIncludeRootFolder = false })
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
* SweetProperty - An easy get project properties anywhere Gradle plugin.
|
||||||
* Copyright (C) 2019-2023 HighCapable
|
* Copyright (C) 2019 HighCapable
|
||||||
* https://github.com/HighCapable/SweetProperty
|
* https://github.com/HighCapable/SweetProperty
|
||||||
*
|
*
|
||||||
* Apache License Version 2.0
|
* Apache License Version 2.0
|
||||||
|
Reference in New Issue
Block a user