TAP5-2769 Upgrade ASM to 9.6 to allow running on Java 21 (#46)

* TAP5-2769 Upgrade ASM to 9.6 to allow running on Java 21

- Remove the copy of ASM
- Add project 'plastic-asm' to be the shadowed version of ASM 9.6
- Add a version property for ASM in the build

* TAP5-2769 Upgrade ASM to 9.6 to allow running on Java 21

- Inject a Tapestry specific TapestryAnnotationNode into ASM to get access to the static helper instead of relying on reflection

---------

Co-authored-by: Chris Poulsen <cpoulsen@dezide.com>
146 files changed
tree: 127733d3c43db3f6437485f0943054c99c8ef4e7
  1. .github/
  2. beanmodel/
  3. buildSrc/
  4. commons/
  5. genericsresolver-guava/
  6. gradle/
  7. plastic/
  8. plastic-asm/
  9. quickstart/
  10. src/
  11. support/
  12. tapestry-beanvalidator/
  13. tapestry-cdi/
  14. tapestry-clojure/
  15. tapestry-core/
  16. tapestry-func/
  17. tapestry-hibernate/
  18. tapestry-hibernate-core/
  19. tapestry-http/
  20. tapestry-internal-test/
  21. tapestry-ioc/
  22. tapestry-ioc-jcache/
  23. tapestry-ioc-junit/
  24. tapestry-javadoc/
  25. tapestry-jmx/
  26. tapestry-jpa/
  27. tapestry-json/
  28. tapestry-kaptcha/
  29. tapestry-latest-java-tests/
  30. tapestry-mongodb/
  31. tapestry-openapi-viewer/
  32. tapestry-rest-jackson/
  33. tapestry-runner/
  34. tapestry-spock/
  35. tapestry-spring/
  36. tapestry-test/
  37. tapestry-test-constants/
  38. tapestry-test-data/
  39. tapestry-upload/
  40. tapestry-version-migrator/
  41. tapestry-webresources/
  42. tapestry5-annotations/
  43. .asf.yaml
  44. .gitignore
  45. 5.7_RELEASE_NOTES.md
  46. 54_RELEASE_NOTES.md
  47. 55_RELEASE_NOTES.md
  48. 583_RELEASE_NOTES.md
  49. build.gradle
  50. gradle.properties
  51. gradlew
  52. gradlew.bat
  53. LICENSE.txt
  54. md5.gradle
  55. NOTICE.txt
  56. README.md
  57. settings.gradle
  58. sha256.gradle
  59. ssh.gradle
README.md

Tapestry is a component-oriented Java web app framework focusing on performance and developer productivity.

A component is just a reusable part of a page. It's trivially easy to create your own components, and Tapestry comes with a large number of components you can use (Form, Loop, Select, Checkbox, Grid, BeanEditor, etc.).

In Tapestry, each page and component is a simple Java POJO with a corresponding HTML template. The HTML template and corresponding Java class have the same name (e.g. “Breadcrumbs.html” and “Breadcrumbs.java”), so you don‘t have to tell Tapestry which template uses which Java class. It’s automatic.

Tapestry features live class reloading: change your Java code, refresh the browser and see the changes instantly.

AJAX support allows you to create responsive web interfaces while writing little to no JavaScript. (But if you like writing JavaScript, great, no problem, Tapestry gets out of your way.)

Quick Start

Main article: Getting Started

You can let Apache Maven create your initial project for you:

mvn archetype:generate -DarchetypeCatalog=http://tapestry.apache.org

Maven will prompt you for the archetype to create (“Tapestry 5 Quickstart Project”) and the Tapestry version number (e.g., “5.4.3”). It also asks you to create a group id, artifact id (e.g., “newapp”) and version number for your app. Once Maven dowloads everything, then you can start the app:

$ cd newapp
$ mvn jetty:run

Then just send your browser to http://localhost:8080/newapp

See the Getting Started introduction as well as the Tapestry Tutorial for a deeper dive.

Main Docs

See https://tapestry.apache.org/documentation.html for the details on every Tapestry topic.