Project Layout

Project Layout

This is the suggested layout for your Tapestry project; it is the layout of folders and files created by the Tapestry Quickstart Archetype. If you are creating your own build using Ant, you may use whatever conventions work for you ... as long as everything gets packaged up into the right place in the target WAR.

Parts of this project layout mimics the format of an exploded WAR (a WAR file unpackaged onto the file system). This will often enable you to run your application directly from your workspace, without any special build or packaging process, while developing. Each of the major IDEs has plugins to allow you to accomplish this task ... and it's one of the factors (combined with live class reloading) that makes working with Tapestry a breeze.

Below is a sample project, whose root package is com.example.myapp:

Main source files - src/main/java

Main Java source files, the files that will be compiled into the WAR file, are in src/main/java. This is only Java source files. You can see the Index.java source file inside the pages subpackage, and the Layout.java source file inside the components subpackage. The package names demonstrated here are required, dictated by the rules for component classes.

Compiled Java classes will ultimately be packaged in the WAR inside the WEB-INF/classes folder.

Classpath Resources - src/main/resources

Resource files are under src/main/resources. This includes the message catalog for the Index page (Index.properties), as well as the message catalog and component template for the Layout component (Layout.tml). These files will also be packaged into the WEB-INF/classes folder of the WAR.

Component templates will always be stored in the resources folder. Templates for pages may be packaged in the WAR proper instead.

Context Resources - src/main/webapp

The WAR is built primarily from the src/main/webapp folder; this is where ordinary files are stored (such as images and stylesheets). Page templates may also be stored here (Index.tml). The file src/main/webapp/WEB-INF/web.xml is the servlet container deployment descriptor, which has a very specific configuration for Tapestry.

The build tool (usually Maven) will be responsible for putting compiled classes and resources into the WEB-INF/classes folder of the WAR, and for putting the Tapestry library, and its dependencies (as well as any additional libraries defined by your application) into the WEB-INF/lib folder.

Testing - src/test

The folders src/test/java and src/test/resources are used when compiling and executing tests. Files in these folders are not packaged into the final WAR.