aboutsummaryrefslogtreecommitdiffstats
path: root/docs/release
diff options
context:
space:
mode:
authorAlexander Kriegisch <Alexander@Kriegisch.name>2024-01-04 11:22:40 +0700
committerAlexander Kriegisch <Alexander@Kriegisch.name>2024-01-06 10:09:11 +0100
commitafea9e8be3869f0100941ff6eff67eaab7029004 (patch)
treeb2632dc0c7bd110d17d339e26fe210cfb82e1c57 /docs/release
parent994a8fd9bcc96cb890439d9598cf47db8a661882 (diff)
downloadaspectj-afea9e8be3869f0100941ff6eff67eaab7029004.tar.gz
aspectj-afea9e8be3869f0100941ff6eff67eaab7029004.zip
Move JavaVersionCompatibility.md to release directory
Signed-off-by: Alexander Kriegisch <Alexander@Kriegisch.name>
Diffstat (limited to 'docs/release')
-rw-r--r--docs/release/JavaVersionCompatibility.md32
1 files changed, 32 insertions, 0 deletions
diff --git a/docs/release/JavaVersionCompatibility.md b/docs/release/JavaVersionCompatibility.md
new file mode 100644
index 000000000..65131cf59
--- /dev/null
+++ b/docs/release/JavaVersionCompatibility.md
@@ -0,0 +1,32 @@
+# AspectJ Java version compatibility
+
+For reasons described e.g. in [this comment](https://github.com/eclipse/org.aspectj/issues/139#issuecomment-1072946123),
+for AspectJ users it has become a little challenging to find out which minimum AspectJ version is required in order to
+process byte code or compile source code using features of a certain Java language version. Since Java 10, this cannot
+be easily concluded from the AspectJ version number anymore, and we are sorry for that. So here is a little overview:
+
+AspectJ version | Java version | Comments
+----------------|--------------|--------
+1.9.21 | 21 | AspectJ compiler requires JDK 17+ during build time. During runtime, AspectJ still only requires Java 8+ for both compile-time and load-time weaving. Pure Java code can be compiled down to as old as 1.3 byte code level.
+1.9.20 - 1.9.20.1 | 20
+1.9.19 | 19
+1.9.9 - 1.9.9.1 | 18
+1.9.8 | 17 | AspectJ compiler requires JDK 11+ during build time. During runtime, AspectJ still only requires Java 8+ for both compile-time and load-time weaving. Pure Java code can be compiled down to as old as 1.3 byte code level.
+1.9.7 | 15, 16
+1.9.6 | 14
+1.9.5 | 13
+1.9.3 - 1.9.4 | 12
+1.9.2 | 11
+1.9.1 | 10
+1.9.0 | 9
+1.8.0 - 1.8.14 | 8
+1.7.0 - 1.7.4 | 7
+1.6.0 - 1.6.12 | 6
+1.5.0 - 1.5.4 | 5
+
+Older versions omitted.
+
+FYI, here is a brief overview of
+[Java language changes since Java 9](https://docs.oracle.com/en/java/javase/18/language/java-language-changes.html).
+They basically correspond to the new Java language features supported by AspectJ versions for the respective Java
+versions.