http://git-wip-us.apache.org/repos/asf/struts-site/blob/124e36c4/content/docs/documentation-style-guide.html ---------------------------------------------------------------------- diff --git a/content/docs/documentation-style-guide.html b/content/docs/documentation-style-guide.html new file mode 100644 index 0000000..8e5f43b --- /dev/null +++ b/content/docs/documentation-style-guide.html @@ -0,0 +1,475 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> +<!-- +Licensed to the Apache Software Foundation (ASF) under one +or more contributor license agreements. See the NOTICE file +distributed with this work for additional information +regarding copyright ownership. The ASF licenses this file +to you under the Apache License, Version 2.0 (the +"License"); you may not use this file except in compliance +with the License. You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, +software distributed under the License is distributed on an +"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, either express or implied. See the License for the +specific language governing permissions and limitations +under the License. +--> +<html> +<head> + <link type="text/css" rel="stylesheet" href="https://struts.apache.org/css/default.css"> + <style type="text/css"> + .dp-highlighter { + width:95% !important; + } + </style> + <style type="text/css"> + .footer { + background-image: url('https://cwiki.apache.org/confluence/images/border/border_bottom.gif'); + background-repeat: repeat-x; + background-position: left top; + padding-top: 4px; + color: #666; + } + </style> + <link href='https://struts.apache.org/highlighter/style/shCoreStruts.css' rel='stylesheet' type='text/css' /> + <link href='https://struts.apache.org/highlighter/style/shThemeStruts.css' rel='stylesheet' type='text/css' /> + <script src='https://struts.apache.org/highlighter/js/shCore.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushPlain.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushXml.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushJava.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushJScript.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushGroovy.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushBash.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushCss.js' type='text/javascript'></script> + <script type="text/javascript"> + SyntaxHighlighter.defaults['toolbar'] = false; + SyntaxHighlighter.all(); + </script> + <script type="text/javascript" language="javascript"> + var hide = null; + var show = null; + var children = null; + + function init() { + /* Search form initialization */ + var form = document.forms['search']; + if (form != null) { + form.elements['domains'].value = location.hostname; + form.elements['sitesearch'].value = location.hostname; + } + + /* Children initialization */ + hide = document.getElementById('hide'); + show = document.getElementById('show'); + children = document.all != null ? + document.all['children'] : + document.getElementById('children'); + if (children != null) { + children.style.display = 'none'; + show.style.display = 'inline'; + hide.style.display = 'none'; + } + } + + function showChildren() { + children.style.display = 'block'; + show.style.display = 'none'; + hide.style.display = 'inline'; + } + + function hideChildren() { + children.style.display = 'none'; + show.style.display = 'inline'; + hide.style.display = 'none'; + } + </script> + <title>Documentation Style Guide</title> +</head> +<body onload="init()"> +<table border="0" cellpadding="2" cellspacing="0" width="100%"> + <tr class="topBar"> + <td align="left" valign="middle" class="topBarDiv" align="left" nowrap> + <a href="home.html">Home</a> > <a href="guides.html">Guides</a> > <a href="contributors-guide.html">Contributors Guide</a> > <a href="documentation-style-guide.html">Documentation Style Guide</a> + </td> + <td align="right" valign="middle" nowrap> + <form name="search" action="https://www.google.com/search" method="get"> + <input type="hidden" name="ie" value="UTF-8" /> + <input type="hidden" name="oe" value="UTF-8" /> + <input type="hidden" name="domains" value="" /> + <input type="hidden" name="sitesearch" value="" /> + <input type="text" name="q" maxlength="255" value="" /> + <input type="submit" name="btnG" value="Google Search" /> + </form> + </td> + </tr> +</table> + +<div id="PageContent"> + <div class="pageheader" style="padding: 6px 0px 0px 0px;"> + <!-- We'll enable this once we figure out how to access (and save) the logo resource --> + <!--img src="/wiki/images/confluence_logo.gif" style="float: left; margin: 4px 4px 4px 10px;" border="0"--> + <div style="margin: 0px 10px 0px 10px" class="smalltext">Apache Struts 2 Documentation</div> + <div style="margin: 0px 10px 8px 10px" class="pagetitle">Documentation Style Guide</div> + + <div class="greynavbar" align="right" style="padding: 2px 10px; margin: 0px;"> + <a href="https://cwiki.apache.org/confluence/pages/editpage.action?pageId=14055"> + <img src="https://cwiki.apache.org/confluence/images/icons/notep_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Edit Page"></a> + <a href="https://cwiki.apache.org/confluence/pages/editpage.action?pageId=14055">Edit Page</a> + + <a href="https://cwiki.apache.org/confluence/pages/listpages.action?key=WW"> + <img src="https://cwiki.apache.org/confluence/images/icons/browse_space.gif" + height="16" width="16" border="0" align="absmiddle" title="Browse Space"></a> + <a href="https://cwiki.apache.org/confluence/pages/listpages.action?key=WW">Browse Space</a> + + <a href="https://cwiki.apache.org/confluence/pages/createpage.action?spaceKey=WW&fromPageId=14055"> + <img src="https://cwiki.apache.org/confluence/images/icons/add_page_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Add Page"></a> + <a href="https://cwiki.apache.org/confluence/pages/createpage.action?spaceKey=WW&fromPageId=14055">Add Page</a> + + <a href="https://cwiki.apache.org/confluence/pages/createblogpost.action?spaceKey=WW&fromPageId=14055"> + <img src="https://cwiki.apache.org/confluence/images/icons/add_blogentry_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Add News"></a> + <a href="https://cwiki.apache.org/confluence/pages/createblogpost.action?spaceKey=WW&fromPageId=14055">Add News</a> + </div> + </div> + + <div class="pagecontent"> + <div class="wiki-content"> + <div id="ConfluenceContent"><p>It's well-known that a consistent user interface is easier to use. Consistency helps users focus on the task rather than the user interface. Likewise, a consistent documentation style helps users focus on the information, rather than the formatting.</p> + +<p>A related goal is to design the documentation so that it is easy to maintain, so that it tends to remain internally consistent with the framework itself.</p> + +<h2 id="DocumentationStyleGuide-Doitnow.Doitonce.Doitwell.">Do it now. Do it once. Do it well.</h2> + +<p>Overall, there are three goals for the documentation system.</p> +<ul><li>Say it all</li><li>Say it once</li><li>Say it well</li></ul> + + +<p>First, we want the documentation to be both complete and concise. This is job one! The documentation should also be a quick but practical introduction to the framework, so newcomers can get started as easily as possible. To keep people coming back, the documentation should also be a repository of the tips and tricks we use in our own applications, so that people can find it here instead of asking over and over again on the list. </p> + +<p>Second, the documentation should be easy to maintain. Ideally, we should cover the detail of each topic once, and draw as much detail from the source code and examples as possible (using the <a shape="rect" href="documentation-style-guide.html">snippet macro</a>).</p> + +<p>Third, the documentation should be text-book quality; if not in the first draft, then in the next. Don't hesitate to hack in a new page. Better that we have the page than we don't. (See Job One!) But, as time allows, we should try to make each page the best that it can be. A great many people access the documentation, and it's worth the effort to make the "documentation experience" productive and enjoyable.</p> + +<h2 id="DocumentationStyleGuide-Capitalizationofcommonterms">Capitalization of common terms</h2> + +<ul><li>Java</li><li>Javadoc</li><li>HTML</li><li>XML</li></ul> + + +<h2 id="DocumentationStyleGuide-GeneralPunctuationandGrammar">General Punctuation and Grammar</h2> + +<p>Good online resources for punctuation, grammar, and text style include</p> +<ul><li><a shape="rect" class="external-link" href="http://lilt.ilstu.edu/golson/punctuation/" rel="nofollow">Punctuation Made Simple</a></li><li><a shape="rect" class="external-link" href="http://www.wwu.edu/depts/journalism/207labmanUL.htm" rel="nofollow">Associated Press Style Guide Essentials</a></li><li><a shape="rect" class="external-link" href="http://en.wikipedia.org/wiki/Wikipedia:Manual_of_Style" rel="nofollow">Wikipedia Manual of Style</a></li></ul> + + +<p>In print, two excellent (and inexpensive!) resources are</p> +<ul><li><a shape="rect" class="external-link" href="http://www.amazon.com/exec/obidos/tg/detail/-/020530902X/apachesoftwar-20/" rel="nofollow">The Elements of Style</a></li><li><a shape="rect" class="external-link" href="http://www.amazon.com/exec/obidos/tg/detail/-/0465004881/apachesoftwar-20/" rel="nofollow">Associated Press Stylebook</a></li></ul> + + +<p>Also excellent, but more expensive: </p> +<ul><li><a shape="rect" class="external-link" href="http://www.chicagomanualofstyle.org/" rel="nofollow">Chicago Manual of Style</a></li></ul> + + +<h2 id="DocumentationStyleGuide-QuickTips">Quick Tips</h2> + +<ul><li>Use as few words as possible. Instead of "but there are some quirks about it" try "but there are quirks".</li><li>If a list of items includes both a term and an explanation, consider using a table instead of bullets.</li><li>Avoid using "This" by itself. Instead of "This lets us" try "This strategy lets us". + <ul><li>Ask yourself: "This what?"</li></ul> + </li><li>References to other wiki pages can be unqualified. For example: "See <a shape="rect" href="documentation-style-guide.html">Documentation Style Guide</a>."</li></ul> + + +<h2 id="DocumentationStyleGuide-Don'tbesmurfy!">Don't be smurfy!</h2> + +<p>A lot of API members use the term "action". We have</p> +<ul><li>action extensions on pages,</li><li>action attributes in forms,</li><li>action elements in configuration files, and</li><li>Action Java classes, some of which may implement the</li><li>Action interface.</li></ul> + + +<p>Here are some terms that can be used to help clarify which action is which.</p> +<ul><li>Use "the framework" or "Struts 2" to refer to the codebase as a whole, including any frameworks we use internally, like XWork and OGNL.</li><li>Use "Action class" or "action handler" to refer to the Java class incorporated by the action element.</li><li>Use "action mapping" to refer to the object created by the action element.</li></ul> + + +<h2 id="DocumentationStyleGuide-PageSaveComment">Page Save Comment</h2> + +<p>Try to include a brief description of a change when saving a page. The comments are included in the page's history. The comments are also included on the daily change report. In a group environment, it's important to help each other follow along.</p> + +<h2 id="DocumentationStyleGuide-ParentPages">Parent Pages </h2> + +<p>Use the Parent Page feature to create a hierarchy of pages. The parent pages are reflected in the "bread crumb" menu. If properly used, parent pages can help browsers "visualize" the documentation as an outline. </p> + +<p>The root of the documentation is the "Home" page, which is also the "Welcome" page. The documentation is ordered into three main areas: Tutorials, FAQs, and Guides. Each area has a contents page, whose parent is Home. Other pages within each section can also serve as parents, to help organize the documentation into a coherent outline. </p> + +<h2 id="DocumentationStyleGuide-Labels">Labels </h2> + +<p>Pages can be cross-indexed with the Label feature. Labels are not be used much yet, except for internal authoring. </p> + +<div class="table-wrap"><table class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> FIXME </p></th><td colspan="1" rowspan="1" class="confluenceTd"><p> A page that mentions a problem in the distribution that we intend to fix. Review these pages before tagging a distribution to see if the issue has been resolved. </p></td></tr><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> TODO </p></th><td colspan="1" rowspan="1" class="confluenceTd"><p> A page that is incomplete. Try to complete these pages before tagging a distribution </p></td></tr></tbody></table></div> + + +<h2 id="DocumentationStyleGuide-ShortcutsLinks">Shortcuts Links</h2> + +<p>The Shortcut Link feature should be used for any external reference that may be used elsewhere.<br clear="none"> +Shortcuts being used include </p> + +<div class="table-wrap"><table class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1" class="confluenceTh"><p>Shortcut </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Purpose </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Usage </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Result </p></th></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p>primer</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> A bookmark in our Key Technologies Primer </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> [javabeans@primer] </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> <a shape="rect" class="unresolved" href="#">javabeans@primer</a> </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p>jira</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> A ticket in our issue tracker </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> [WW-2111@jira] </p></td><td colspan="1" rowspan ="1" class="confluenceTd"><p> <a shape="rect" href="http://issues.apache.org/jira/browse/WW-2111">WW-2111@jira</a> </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p>s2plugins</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> S2 Plugin Repository </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> [tiles-plugin.html@s2plugins] </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> <a shape="rect" class="unresolved" href="#">tiles-plugin.html@s2plugins</a> </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p>s2site</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> The Struts 2 website </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> [docs/home.html@s2site] </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> <a shape="rect" class="unresolved" href="#">docs/home.html@s2site</a> </p></td></tr></tbody></table></div> + + +<h2 id="DocumentationStyleGuide-AboutHeadings">About Headings</h2> + +<p><img class="emoticon emoticon-information" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/information.png" data-emoticon-name="information" alt="(info)"> This section refers to: <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=headings">Notation Guide >> Headings</a>.</p> + +<h3 id="DocumentationStyleGuide-Abouth1">About h1</h3> + +<p>Don't use <code>h1.</code> at the top of each page. The page title serves as the "top level header". This is not as obvious online, but it is very apparent when the documentation is exported to HTML or PDF.</p> + +<p>Try to start each page with some introductory text, to separate the page title from the rest of content.</p> + +<p>Likewise, try to have some content between all page headings. Avoid placing headings one after the other.</p> + +<h3 id="DocumentationStyleGuide-Documentsections">Document sections</h3> + +<p>Headings can help you divide your document in sections, subsections, sub-subsections and so forth.</p> + +<h4 id="DocumentationStyleGuide-Advantages">Advantages</h4> + +<p>Your document becomes more organized.</p> + +<h4 id="DocumentationStyleGuide-Disadvantages">Disadvantages</h4> + +<p>Too many headings can fragment the text.</p> +<div class="confluence-information-macro confluence-information-macro-warning"><p class="title">Here we go again!</p><span class="aui-icon aui-icon-small aui-iconfont-error confluence-information-macro-icon"></span><div class="confluence-information-macro-body"> +<p>This segment is an example of overusing headings. This whole "Headings" section has so few paragraphs that it really should have been written in just one section. The "advantages" and "disadvantages" would be just as easy to render as a table.</p></div></div> + +<h3 id="DocumentationStyleGuide-Headingscapitalization">Headings capitalization</h3> + +<p>Try to use initial capitals for <code>h1</code> and <code>h2</code> headers.</p> + +<p>For <code>h3</code> and smaller headings, try to capitalize only the first word, and any proper nouns.</p> + +<p>By using different capitalization styles, we emphasize the importance of bigger headings.</p> + +<h3 id="DocumentationStyleGuide-Avoidskippingheaders">Avoid skipping headers</h3> + +<p>The headers form an outline for the page. When writing term papers, it is not a good practice to skip outline levels. When writing hypertext, it is not a good practice to skip heading levels either. Try not to skip from a <code>h2</code> to a <code>h4</code>.</p> +<div class="confluence-information-macro confluence-information-macro-tip"><p class="title">Too many headings?</p><span class="aui-icon aui-icon-small aui-iconfont-approve confluence-information-macro-icon"></span><div class="confluence-information-macro-body"> +<p>If you find yourself writing too many <code>h2</code> headings in a single page, consider breaking the page into child pages.</p></div></div> + +<h2 id="DocumentationStyleGuide-MoreonTextEffects">More on Text Effects</h2> + +<p><img class="emoticon emoticon-yellow-star" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/star_yellow.png" data-emoticon-name="yellow-star" alt="(star)"> This section refers to: <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=texteffects">Notation Guide >> Text Effects</a>.</p> + +<p>Text effects like <strong>strong</strong>, <em>emphasis</em>, and <span style="text-decoration: underline;">inserted</span> can be used in the usual way to denote important parts of a sentence.</p> + +<p><code>Monospaced</code> should be used to files, tags, and methods, like <code>struts.xml</code>, <code><xmltag /></code>, and <code>execute</code>. Class and Interface names may be left in normal face, like Action and Interceptor.</p> + +<p>A panel should be preferred to a block quote.</p> + +<p>The color fonts should be avoided or used only with great care. Some people have difficulty seeing some colors, and the colors may not be apparent if the page is printed.</p> + +<h2 id="DocumentationStyleGuide-TextBreaks">Text Breaks</h2> + +<p><img class="emoticon emoticon-yellow-star" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/star_yellow.png" data-emoticon-name="yellow-star" alt="(star)"> This section refers to: <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=breaks">Notation Guide >> Text Breaks</a>.</p> + +<p>Text breaks should not be used to format blocks on the screen. If there is an issue with the way paragraphs or headings are being rendered, we should customize the stylesheet.</p> + +<h2 id="DocumentationStyleGuide-Lists">Lists</h2> + +<p><img class="emoticon emoticon-yellow-star" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/star_yellow.png" data-emoticon-name="yellow-star" alt="(star)"> This section refers to: <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=lists">Notation Guide >> Lists</a>.</p> + +<p>Unordered lists should be created only with the <code>*</code> (star) notation.</p> + +<p>Ordered list should be used when numbering the items is important. Otherwise, prefer unordered lists.</p> +<ul><li>This is an unordered list in star notation;</li><li>Items can have sub-items + <ul><li>That can have sub-items + <ul><li>That can have sub-items ... + <ul><li>What is the limit?</li></ul> + </li></ul> + </li></ul> + </li><li>Mixing ordered and unordered lists is possible: + <ol><li>One;</li><li>Two;</li><li>Three.</li></ol> + </li></ul> + + +<h2 id="DocumentationStyleGuide-Images">Images</h2> + +<p><img class="emoticon emoticon-yellow-star" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/star_yellow.png" data-emoticon-name="yellow-star" alt="(star)"> This section refers to: <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=images">Notation Guide >> Images</a> and <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=miscellaneous">Notation Guide >> Misc</a>.</p> + +<p>Avoid using external images for bullets or icons. Prefer the equivalents provided with Confluence.</p> + +<p>Images can be included by URL or annexing the binary to the page. Prefer annexing when possible, since URLs are subject to change.</p> + +<p>Always observe copyright issues. Do not annex images unless it an original or public domain work, or the author has donated the image to the foundation.</p> + +<p>Example: <span class="confluence-embedded-file-wrapper"><img class="confluence-embedded-image confluence-external-resource" src="http://struts.apache.org/images/struts-power.gif" data-image-src="http://struts.apache.org/images/struts-power.gif"></span></p> + +<h2 id="DocumentationStyleGuide-Icons">Icons</h2> + +<p>Use <img class="emoticon emoticon-information" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/information.png" data-emoticon-name="information" alt="(info)">, <img class="emoticon emoticon-question" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/help_16.png" data-emoticon-name="question" alt="(question)">, <img class="emoticon emoticon-warning" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/warning.png" data-emoticon-name="warning" alt="(warning)">, and <img class="emoticon emoticon-tick" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/check.png" data-emoticon-name="tick" alt="(tick)"> to bullet important one-liners. Use <img class="emoticon emoticon-light-on" src="https://cwiki.apache. org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/lightbulb_on.png" data-emoticon-name="light-on" alt="(lightbulb)"> to highlight cross references.</p> + +<p>Used carefully, icons can make the content easier to read and understand.</p> + +<p>However, if icons are overused, they lose impact (and can make a page look like a ransom note).</p> + +<p>Casual icons like <img class="emoticon emoticon-smile" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/smile.png" data-emoticon-name="smile" alt="(smile)"> and <img class="emoticon emoticon-thumbs-up" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/thumbs_up.png" data-emoticon-name="thumbs-up" alt="(thumbs up)"> should be used with care or avoided.</p> + +<h2 id="DocumentationStyleGuide-Tables">Tables</h2> + +<p><img class="emoticon emoticon-yellow-star" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/star_yellow.png" data-emoticon-name="yellow-star" alt="(star)"> This section refers to: <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=tables">Notation Guide >> Tables</a>.</p> + +<p>Prefer lists for single-value entries. Prefer tables for lists with multiple columns.</p> + +<p>Tables are very useful when lists just don't do it. Meaning: don't write a table when a list suffices. Tables are more organized, because you can align the text in columns. Since the markup text for tables in Confluence is not easy to read, complex and big tables can be hard to maintain.</p> + +<div class="table-wrap"><table class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> File </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Optional </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Location (relative to webapp) </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Purpose </p></th></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <a shape="rect" href="webxml.html">web.xml</a> </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> no </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> /WEB-INF/ </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> Web deployment descriptor to include all necessary WebWork components </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <a shape="rect" href="strutsxml.html">struts.xml</a> </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> no </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> /W EB-INF/classes/ </p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> Main configuration, contains result/view types, action mappings, interceptors, and so forth </p></td></tr></tbody></table></div> + + +<h2 id="DocumentationStyleGuide-AdvancedFormatting">Advanced Formatting</h2> + +<p><img class="emoticon emoticon-yellow-star" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/star_yellow.png" data-emoticon-name="yellow-star" alt="(star)"> This section refers to: <a shape="rect" class="external-link" href="http://cwiki.apache.org/confluence/renderer/notationhelp.action?section=advanced">Notation Guide >> Advanced Formatting</a>.</p> + +<p>Panels should be used as needed. Try to select the right panel for the content.</p> + +<p>Try to give all panels and {code} blocks meaningful titles. People scan the pages looking for likely tips and examples.</p> + +<p>Avoid generic titles like "Warning" or "Example". Style the headings like they were h3. or smaller.</p> + +<p>When a panel contains a file or a class, the panel title should refer to the filename or classname.</p> + +<p>Try to specify the language for {code} blocks.</p> +<div class="code panel pdl" style="border-width: 1px;"><div class="codeHeader panelHeader pdl" style="border-bottom-width: 1px;"><b>HelloWorld.java</b></div><div class="codeContent panelContent pdl"> +<pre class="brush: java; gutter: false; theme: Default" style="font-size:12px;"> +/** Hello World class. */ +public class HelloWorld { + /** Main method. */ + public static void main(String[] args) { + System.out.println("Hello, World!"); + } +} +</pre> +</div></div> +<p><img class="emoticon emoticon-tick" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/check.png" data-emoticon-name="tick" alt="(tick)"> Try to use <a shape="rect" href="documentation-style-guide.html">snippets</a> for code blocks whenever possible!</p> + +<p>Avoid tabs in code blocks, use two spaces instead. Long lines should be formatted to fit in a 800x600 resolution screen, without resorting to horizontal scrolling.</p> + +<p>A typical example of <code>noformat</code> would be the command line statements to compile and run the code above.</p> + +<p>Either the code or noformat block can be used to represent command line windows. The terminal notation ({$}} should be used to represent a system prompt.</p> + +<div class="code panel pdl" style="border-width: 1px;"><div class="codeHeader panelHeader pdl" style="border-bottom-width: 1px;"><b>Compiling and Running Hello World</b></div><div class="codeContent panelContent pdl"> +<pre class="brush: java; gutter: false; theme: Default" style="font-size:12px;"> +$ javac HelloWorld.java + +$ java HelloWorld +Hello, World! +</pre> +</div></div> + +<h2 id="DocumentationStyleGuide-ChangeHappens">Change Happens</h2> + +<p>Anyone who has worked with databases knows the value of normalizing the schema. Ideally, we want to store each fact exactly once, and then use query system to retrieve that fact whereever it is needed. If we store a fact once, we only need to update it once, and we avoid inconsistencies in our data set.</p> + +<p>To the extent possible, we want to "normalize" our technical documentation. Like a database, all technical documentation is subject to change. When change happens, we want the documentation to be as easy to update as possible. One way to do that is to try and minimize redundancy (without sacrificing ease of use).</p> + +<h3 id="DocumentationStyleGuide-Singlesourcingwithsnippets">Single sourcing with snippets</h3> + +<p>The "holy grail" of technical documentation is <a shape="rect" class="external-link" href="http://en.wikipedia.org/wiki/Single_source_publishing" rel="nofollow">single sourcing</a>. One way we try to single-source documentation is to pull content directly from the <a shape="rect" class="external-link" href="http://en.wikipedia.org/wiki/Javadoc" rel="nofollow">Javadocs</a> and source code into the documentation.</p> + +<p>Using a <strong><a shape="rect" class="external-link" href="http://confluence.atlassian.com/display/CONFEXT/Snippet+Plugin" rel="nofollow">snippet macro</a></strong>, we are able to tag portions of any file for reuse. The macro fetches those snippets from a repository and merges the content into the documentation.</p> +<div class="confluence-information-macro confluence-information-macro-tip"><p class="title">Use the Source!</p><span class="aui-icon aui-icon-small aui-iconfont-approve confluence-information-macro-icon"></span><div class="confluence-information-macro-body"> +<p>Before writing any new content, ask yourself if we could place the content in the repository in either one of the example applications or the Javadocs. Rather than contrive an example, can you pull a snippet from one of the applications? Rather than reiterate Javadoc, could we update the Javadoc and make it a snippet? It is preferable to use snippets from the Struts example apps over Javadoc snippets for anything except plain text content as this ensures that the content's syntax has been validated.</p></div></div> + + +<h3 id="DocumentationStyleGuide-Examplesnippetusage">Example snippet usage</h3> + +<div class="code panel pdl" style="border-width: 1px;"><div class="codeHeader panelHeader pdl" style="border-bottom-width: 1px;"><b>Snippet usage example</b></div><div class="codeContent panelContent pdl"> +<pre class="brush: plain; gutter: false; theme: Default" style="font-size:12px;"> +{snippet:id=example|lang=xml|javadoc=true|url=struts2/core/src/main/java/org/apache/struts2/components/If.java} +</pre> +</div></div> + +<div class="table-wrap"><table class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Snippet Attributes </p></th></tr><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> id </p></th><td colspan="1" rowspan="1" class="confluenceTd"><p> The <em>name</em> of the snippet (optional - defaults to "all", meaning the entire file). </p></td></tr><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> url </p></th><td colspan="1" rowspan="1" class="confluenceTd"><p> The URL where the snippet can be found (<strong>required</strong>). </p></td></tr><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> linenumbers </p></th><td colspan="1" rowspan="1" class="confluenceTd"><p> If true line numbers are displayed. Numbering always starts at 1. </p></td></tr><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> lang </p></th><td colspan="1" rowspan="1" class="confluenceTd"><p> lang=java wo uld surround the snippet with {code:java}snippet{code}. If this snippet is simply text, don't include this parameter and the content will be printed outside of a code block. </p></td></tr><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> javadoc </p></th><td colspan="1" rowspan="1" class="confluenceTd"><p> If true, the content is within a Javadoc block. If this is set to true, then the preceeding "* " (asterisk-space) characters will be stripped before merging the content. Also, the content is assumed to be already HTML escaped and won't be escaped again. </p></td></tr></tbody></table></div> + +<p>All snippets are marked off by the pattern <code>START SNIPPET: XXX</code> and <code>END SNIPPET: XXX</code> where <code>XXX</code> is the <code>name</code> of the snippet that is assigned in the <code>id</code> attribute of the macro. The URL is typically a location that points to the project's source control contents. |</p> + +<h3 id="DocumentationStyleGuide-AboutURLs">About URLs</h3> + +<p>A URL must start with a valid prefix. There are two types of prefixes:</p> +<ul><li><strong>com.opensymphony.xwork2.</strong> Notice the period. This syntax is better when you want to include content from a class because they allow you to use the fully qualified classname as the URL.</li><li><strong>struts2/</strong> Notice the trailing slash. This syntax better when you want to include content content from non-class files such as xml or properties files. They may also be needed if a class based prefix for a sub-project has not be setup.</li></ul> + + +<p>To include a snippet from <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/apps/showcase/src/main/java/org/apache/struts2/showcase/DateAction.java">http://svn.apache.org/repos/asf/struts/struts2/trunk/apps/showcase/src/main/java/org/apache/struts2/showcase/DateAction.java</a> the two possible methods are:</p> +<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent panelContent pdl"> +<pre class="brush: java; gutter: false; theme: Default" style="font-size:12px;"> +{snippet:lang=java|url=struts2/apps/showcase/src/main/java/org/apache/struts2/showcase/DateAction.java} +{snippet:lang=java|url=struts2/apps.showcase.src.main.java.org.apache.struts2.showcase.DateAction} +</pre> +</div></div> + +<p>To include a snippet from <a shape="rect" class="external-link" href="https://svn.apache.org/repos/asf/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/validators/StringLengthFieldValidator.java">https://svn.apache.org/repos/asf/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/validator/validators/StringLengthFieldValidator.java</a> the two possible methods are:</p> +<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent panelContent pdl"> +<pre class="brush: java; gutter: false; theme: Default" style="font-size:12px;"> +{snippet:id=javadoc|javadoc=true|url=com.opensymphony.xwork2.validator.validators.StringLengthFieldValidator} +{snippet:id=javadoc|javadoc=true|url=com.opensymphony.xwork2.validator/validators/StringLengthFieldValidator.java} +</pre> +</div></div> + +<p>The list of available prefixes:</p> +<div class="table-wrap"><table class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1" class="confluenceTh"><p> Prefix </p></th><th colspan="1" rowspan="1" class="confluenceTh"><p> Destination </p></th></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>xwork2/</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/xwork-core/src/main/java/">http://svn.apache.org/repos/asf/struts/struts2/trunk/xwork-core/src/main/java/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>struts2/</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/">http://svn.apache.org/repos/asf/struts/struts2/trunk/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>rest-plugin/</strong> </p></td><td colspan="1" rows pan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/rest/">http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/rest/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>struts2-tags/</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/core/src/site/resources/tags/">http://svn.apache.org/repos/asf/struts/struts2/trunk/core/src/site/resources/tags/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>com.opensymphony.xwork2.</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/">http://svn.apache.org/repos/asf/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/x work2/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>org.apache.struts2.</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/core/src/main/java/org/apache/struts2/">http://svn.apache.org/repos/asf/struts/struts2/trunk/core/src/main/java/org/apache/struts2/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>org.apache.struts2.dojo.</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/dojo/src/main/java/org/apache/struts2/dojo/">http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/dojo/src/main/java/org/apache/struts2/dojo/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>org.apache.struts2.sitegraph.</strong> </p></td><td colspan="1" rowspan="1" class="confl uenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/sitegraph/src/main/java/org/apache/struts2/sitegraph/">http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/sitegraph/src/main/java/org/apache/struts2/sitegraph/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>org.apache.struts2.sitemesh.</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/sitemesh/src/main/java/org/apache/struts2/sitemesh/">http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/sitemesh/src/main/java/org/apache/struts2/sitemesh/</a> </td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>org.apache.struts2.views.tiles.</strong> </p></td><td colspan="1" rowspan="1" class="confluenceTd"> <a shape="rect" class="external-link" href="http://svn.apache.org/repos/asf/struts/str uts2/trunk/plugins/tiles/src/main/java/org/apache/struts2/views/tiles/">http://svn.apache.org/repos/asf/struts/struts2/trunk/plugins/tiles/src/main/java/org/apache/struts2/views/tiles/</a> </td></tr></tbody></table></div> + + + +<h3 id="DocumentationStyleGuide-Aboutsnippetmarkers">About snippet markers</h3> + +<p>When possible, all snippet markers should be in comment blocks. How they are commented depends on where the snippet is being embedded.</p> + +<div class="code panel pdl" style="border-width: 1px;"><div class="codeHeader panelHeader pdl" style="border-bottom-width: 1px;"><b>Commenting HTML or XML snippets</b></div><div class="codeContent panelContent pdl"> +<pre class="brush: xml; gutter: false; theme: Default" style="font-size:12px;"> +<!-- START SNIPPET: xxx --> +... +<!-- END SNIPPET: xxx --> +</pre> +</div></div> + +<div class="code panel pdl" style="border-width: 1px;"><div class="codeHeader panelHeader pdl" style="border-bottom-width: 1px;"><b>Commenting snippets in Java code</b></div><div class="codeContent panelContent pdl"> +<pre class="brush: java; gutter: false; theme: Default" style="font-size:12px;"> +if (true != false) { + // START SNIPPET: xxx + System.out.println("This is some silly code!"); + // END SNIPPET: xxx +} +</pre> +</div></div> + +<p>If the snippet is embedded within Javadoc comments use HTML comments to declare the snippet as they won't render in the Javadocs.</p> + +<p>When using the <code><pre></code> tag within Javadoc comments embed the snippet markers <em>inside</em> the <code><pre></code> tag.</p> +<div class="code panel pdl" style="border-width: 1px;"><div class="codeHeader panelHeader pdl" style="border-bottom-width: 1px;"><b>Snipping XML examples from Javadoc content</b></div><div class="codeContent panelContent pdl"> +<pre class="brush: plain; gutter: false; theme: Default" style="font-size:12px;"> +* <pre> +* <!-- START SNIPPET: example --> +* &lt;!-- records only the action's execution time --&gt; +* &lt;action name="someAction" class="com.examples.SomeAction"&gt; +* &lt;interceptor-ref name="completeStack"/&gt; +* &lt;interceptor-ref name="timer"/&gt; +* &lt;result name="success"&gt;good_result.ftl&lt;/result&gt; +* &lt;/action&gt; +* <!-- END SNIPPET: example --> +* </pre> +</pre> +</div></div> + +<p>A <code><pre></code> tag within a Javadoc comment would be escaped and rendered as part of the snippet. See <a shape="rect" class="external-link" href="https://svn.apache.org/repos/asf/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/interceptor/TimerInterceptor.java">TimerInterceptor.java</a> for an complete example.</p> + +<h2 id="DocumentationStyleGuide-Back:">Back: <a shape="rect" href="contributors-guide.html">Contributors Guide</a></h2></div> + </div> + + + </div> +</div> +<div class="footer"> + Generated by CXF SiteExporter +</div> +</body> +</html>
http://git-wip-us.apache.org/repos/asf/struts-site/blob/124e36c4/content/docs/does-myeclipse-6-support-struts-2.html ---------------------------------------------------------------------- diff --git a/content/docs/does-myeclipse-6-support-struts-2.html b/content/docs/does-myeclipse-6-support-struts-2.html new file mode 100644 index 0000000..3516c92 --- /dev/null +++ b/content/docs/does-myeclipse-6-support-struts-2.html @@ -0,0 +1,197 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> +<!-- +Licensed to the Apache Software Foundation (ASF) under one +or more contributor license agreements. See the NOTICE file +distributed with this work for additional information +regarding copyright ownership. The ASF licenses this file +to you under the Apache License, Version 2.0 (the +"License"); you may not use this file except in compliance +with the License. You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, +software distributed under the License is distributed on an +"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, either express or implied. See the License for the +specific language governing permissions and limitations +under the License. +--> +<html> +<head> + <link type="text/css" rel="stylesheet" href="https://struts.apache.org/css/default.css"> + <style type="text/css"> + .dp-highlighter { + width:95% !important; + } + </style> + <style type="text/css"> + .footer { + background-image: url('https://cwiki.apache.org/confluence/images/border/border_bottom.gif'); + background-repeat: repeat-x; + background-position: left top; + padding-top: 4px; + color: #666; + } + </style> + <link href='https://struts.apache.org/highlighter/style/shCoreStruts.css' rel='stylesheet' type='text/css' /> + <link href='https://struts.apache.org/highlighter/style/shThemeStruts.css' rel='stylesheet' type='text/css' /> + <script src='https://struts.apache.org/highlighter/js/shCore.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushPlain.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushXml.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushJava.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushJScript.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushGroovy.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushBash.js' type='text/javascript'></script> + <script src='https://struts.apache.org/highlighter/js/shBrushCss.js' type='text/javascript'></script> + <script type="text/javascript"> + SyntaxHighlighter.defaults['toolbar'] = false; + SyntaxHighlighter.all(); + </script> + <script type="text/javascript" language="javascript"> + var hide = null; + var show = null; + var children = null; + + function init() { + /* Search form initialization */ + var form = document.forms['search']; + if (form != null) { + form.elements['domains'].value = location.hostname; + form.elements['sitesearch'].value = location.hostname; + } + + /* Children initialization */ + hide = document.getElementById('hide'); + show = document.getElementById('show'); + children = document.all != null ? + document.all['children'] : + document.getElementById('children'); + if (children != null) { + children.style.display = 'none'; + show.style.display = 'inline'; + hide.style.display = 'none'; + } + } + + function showChildren() { + children.style.display = 'block'; + show.style.display = 'none'; + hide.style.display = 'inline'; + } + + function hideChildren() { + children.style.display = 'none'; + show.style.display = 'inline'; + hide.style.display = 'none'; + } + </script> + <title>Does MyEclipse 6 support Struts 2?</title> +</head> +<body onload="init()"> +<table border="0" cellpadding="2" cellspacing="0" width="100%"> + <tr class="topBar"> + <td align="left" valign="middle" class="topBarDiv" align="left" nowrap> + <a href="home.html">Home</a> > <a href="faqs.html">FAQs</a> > <a href="does-myeclipse-6-support-struts-2.html">Does MyEclipse 6 support Struts 2?</a> + </td> + <td align="right" valign="middle" nowrap> + <form name="search" action="https://www.google.com/search" method="get"> + <input type="hidden" name="ie" value="UTF-8" /> + <input type="hidden" name="oe" value="UTF-8" /> + <input type="hidden" name="domains" value="" /> + <input type="hidden" name="sitesearch" value="" /> + <input type="text" name="q" maxlength="255" value="" /> + <input type="submit" name="btnG" value="Google Search" /> + </form> + </td> + </tr> +</table> + +<div id="PageContent"> + <div class="pageheader" style="padding: 6px 0px 0px 0px;"> + <!-- We'll enable this once we figure out how to access (and save) the logo resource --> + <!--img src="/wiki/images/confluence_logo.gif" style="float: left; margin: 4px 4px 4px 10px;" border="0"--> + <div style="margin: 0px 10px 0px 10px" class="smalltext">Apache Struts 2 Documentation</div> + <div style="margin: 0px 10px 8px 10px" class="pagetitle">Does MyEclipse 6 support Struts 2?</div> + + <div class="greynavbar" align="right" style="padding: 2px 10px; margin: 0px;"> + <a href="https://cwiki.apache.org/confluence/pages/editpage.action?pageId=75019"> + <img src="https://cwiki.apache.org/confluence/images/icons/notep_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Edit Page"></a> + <a href="https://cwiki.apache.org/confluence/pages/editpage.action?pageId=75019">Edit Page</a> + + <a href="https://cwiki.apache.org/confluence/pages/listpages.action?key=WW"> + <img src="https://cwiki.apache.org/confluence/images/icons/browse_space.gif" + height="16" width="16" border="0" align="absmiddle" title="Browse Space"></a> + <a href="https://cwiki.apache.org/confluence/pages/listpages.action?key=WW">Browse Space</a> + + <a href="https://cwiki.apache.org/confluence/pages/createpage.action?spaceKey=WW&fromPageId=75019"> + <img src="https://cwiki.apache.org/confluence/images/icons/add_page_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Add Page"></a> + <a href="https://cwiki.apache.org/confluence/pages/createpage.action?spaceKey=WW&fromPageId=75019">Add Page</a> + + <a href="https://cwiki.apache.org/confluence/pages/createblogpost.action?spaceKey=WW&fromPageId=75019"> + <img src="https://cwiki.apache.org/confluence/images/icons/add_blogentry_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Add News"></a> + <a href="https://cwiki.apache.org/confluence/pages/createblogpost.action?spaceKey=WW&fromPageId=75019">Add News</a> + </div> + </div> + + <div class="pagecontent"> + <div class="wiki-content"> + <div id="ConfluenceContent"><p>MyEclipse 6 is a great platform. Everything you need to develop enterprise-grade applications is in a single download, including a web container, (Tomcat), DBMS (Derby), Data Access Library (Hibernate), Dependency Injection System (Spring), and your choice of web application frameworks, such as Struts 1 and Tapestry. Even the Java runtime is included in the same download. And, since it's Eclipse, we can run it all in place, without tweaking any system registries or such. In fact, a complete, runnable system with a working application can be squeezedonto a 1GB USB drive.</p> + +<p>MyEclipse may be an all-one-download, but we can still install any other Eclipse plugins that we might want to use. And, we can also install other frameworks, like Struts 2.</p> + +<p>The simplest approach is to create a web application project in the usual way. Then, drag and drop the necessary Struts 2 dependencies into the WEB-INF folder that MyEclipse will create. The needed JARs are:</p> + +<ul><li>struts2-core</li><li>xwork2</li><li>freemarker</li><li>ognl</li><li>commons-logging</li></ul> + + +<p>The commons-logging JAR is optional, but it helps. The versions will vary depending on which release of Struts 2 is being used. Just use whatever is provided in the Struts 2 lib distribution. (But not everything that is in the distribution!)</p> + +<p>The one other step is to configure the web.xml to load the Struts filter. MyEclipse will create a starter web.xml. Just change it to look like this:</p> + +<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent panelContent pdl"> +<pre class="brush: java; gutter: false; theme: Default" style="font-size:12px;"> +<?xml version="1.0" encoding="UTF-8"?> +<web-app version="2.5" + xmlns="http://java.sun.com/xml/ns/javaee" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://java.sun.com/xml/ns/javaee + http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> + + <filter> + <filter-name> + struts2 + </filter-name> + <filter-class> + org.apache.struts2.dispatcher.FilterDispatcher + </filter-class> + </filter> + <filter-mapping> + <filter-name> + struts2 + </filter-name> + <url-pattern> + /* + </url-pattern> + </filter-mapping> + <welcome-file-list> + <welcome-file>index.html</welcome-file> + </welcome-file-list> +</web-app> +</pre> +</div></div> + +<p>And that's it! Welcome to Struts 2 and MyEclipse 6!</p></div> + </div> + + + </div> +</div> +<div class="footer"> + Generated by CXF SiteExporter +</div> +</body> +</html> http://git-wip-us.apache.org/repos/asf/struts-site/blob/124e36c4/content/docs/does-the-framework-integrate-with-hibernate.html ---------------------------------------------------------------------- diff --git a/content/docs/does-the-framework-integrate-with-hibernate.html b/content/docs/does-the-framework-integrate-with-hibernate.html new file mode 100644 index 0000000..694d499 --- /dev/null +++ b/content/docs/does-the-framework-integrate-with-hibernate.html @@ -0,0 +1,145 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> +<!-- +Licensed to the Apache Software Foundation (ASF) under one +or more contributor license agreements. See the NOTICE file +distributed with this work for additional information +regarding copyright ownership. The ASF licenses this file +to you under the Apache License, Version 2.0 (the +"License"); you may not use this file except in compliance +with the License. You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, +software distributed under the License is distributed on an +"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, either express or implied. See the License for the +specific language governing permissions and limitations +under the License. +--> +<html> +<head> + <link type="text/css" rel="stylesheet" href="https://struts.apache.org/css/default.css"> + <style type="text/css"> + .dp-highlighter { + width:95% !important; + } + </style> + <style type="text/css"> + .footer { + background-image: url('https://cwiki.apache.org/confluence/images/border/border_bottom.gif'); + background-repeat: repeat-x; + background-position: left top; + padding-top: 4px; + color: #666; + } + </style> + <script type="text/javascript" language="javascript"> + var hide = null; + var show = null; + var children = null; + + function init() { + /* Search form initialization */ + var form = document.forms['search']; + if (form != null) { + form.elements['domains'].value = location.hostname; + form.elements['sitesearch'].value = location.hostname; + } + + /* Children initialization */ + hide = document.getElementById('hide'); + show = document.getElementById('show'); + children = document.all != null ? + document.all['children'] : + document.getElementById('children'); + if (children != null) { + children.style.display = 'none'; + show.style.display = 'inline'; + hide.style.display = 'none'; + } + } + + function showChildren() { + children.style.display = 'block'; + show.style.display = 'none'; + hide.style.display = 'inline'; + } + + function hideChildren() { + children.style.display = 'none'; + show.style.display = 'inline'; + hide.style.display = 'none'; + } + </script> + <title>Does the framework integrate with Hibernate</title> +</head> +<body onload="init()"> +<table border="0" cellpadding="2" cellspacing="0" width="100%"> + <tr class="topBar"> + <td align="left" valign="middle" class="topBarDiv" align="left" nowrap> + <a href="home.html">Home</a> > <a href="faqs.html">FAQs</a> > <a href="does-the-framework-integrate-with-hibernate.html">Does the framework integrate with Hibernate</a> + </td> + <td align="right" valign="middle" nowrap> + <form name="search" action="https://www.google.com/search" method="get"> + <input type="hidden" name="ie" value="UTF-8" /> + <input type="hidden" name="oe" value="UTF-8" /> + <input type="hidden" name="domains" value="" /> + <input type="hidden" name="sitesearch" value="" /> + <input type="text" name="q" maxlength="255" value="" /> + <input type="submit" name="btnG" value="Google Search" /> + </form> + </td> + </tr> +</table> + +<div id="PageContent"> + <div class="pageheader" style="padding: 6px 0px 0px 0px;"> + <!-- We'll enable this once we figure out how to access (and save) the logo resource --> + <!--img src="/wiki/images/confluence_logo.gif" style="float: left; margin: 4px 4px 4px 10px;" border="0"--> + <div style="margin: 0px 10px 0px 10px" class="smalltext">Apache Struts 2 Documentation</div> + <div style="margin: 0px 10px 8px 10px" class="pagetitle">Does the framework integrate with Hibernate</div> + + <div class="greynavbar" align="right" style="padding: 2px 10px; margin: 0px;"> + <a href="https://cwiki.apache.org/confluence/pages/editpage.action?pageId=13851"> + <img src="https://cwiki.apache.org/confluence/images/icons/notep_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Edit Page"></a> + <a href="https://cwiki.apache.org/confluence/pages/editpage.action?pageId=13851">Edit Page</a> + + <a href="https://cwiki.apache.org/confluence/pages/listpages.action?key=WW"> + <img src="https://cwiki.apache.org/confluence/images/icons/browse_space.gif" + height="16" width="16" border="0" align="absmiddle" title="Browse Space"></a> + <a href="https://cwiki.apache.org/confluence/pages/listpages.action?key=WW">Browse Space</a> + + <a href="https://cwiki.apache.org/confluence/pages/createpage.action?spaceKey=WW&fromPageId=13851"> + <img src="https://cwiki.apache.org/confluence/images/icons/add_page_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Add Page"></a> + <a href="https://cwiki.apache.org/confluence/pages/createpage.action?spaceKey=WW&fromPageId=13851">Add Page</a> + + <a href="https://cwiki.apache.org/confluence/pages/createblogpost.action?spaceKey=WW&fromPageId=13851"> + <img src="https://cwiki.apache.org/confluence/images/icons/add_blogentry_16.gif" + height="16" width="16" border="0" align="absmiddle" title="Add News"></a> + <a href="https://cwiki.apache.org/confluence/pages/createblogpost.action?spaceKey=WW&fromPageId=13851">Add News</a> + </div> + </div> + + <div class="pagecontent"> + <div class="wiki-content"> + <div id="ConfluenceContent"> +<div class="confluence-information-macro confluence-information-macro-information"><p class="title">About Hibernate</p><span class="aui-icon aui-icon-small aui-iconfont-info confluence-information-macro-icon"></span><div class="confluence-information-macro-body"><p><a shape="rect" class="external-link" href="http://hibernate.org/" rel="nofollow">Hibernate</a> is a object/relational persistence and query service. Hibernate lets you develop persistent classes following object-oriented idiom - including association, inheritance, polymorphism, composition, and collections.</p></div></div> + +<p><img class="emoticon emoticon-tick" src="https://cwiki.apache.org/confluence/s/en_GB/5982/f2b47fb3d636c8bc9fd0b11c0ec6d0ae18646be7.1/_/images/icons/emoticons/check.png" data-emoticon-name="tick" alt="(tick)"> Hibernate works well with most web application frameworks, including Struts 2. If you setup Hibernate in <a shape="rect" class="external-link" href="http://www.hibernate.org/5.html" rel="nofollow">the usual way</a>, it should work well with the framework.</p> + +<h2 id="DoestheframeworkintegratewithHibernate-AdditionalHibernateResources">Additional Hibernate Resources</h2> + +<ul><li><a shape="rect" class="external-link" href="http://www.hibernate.org/51.html" rel="nofollow">Hibernate Aware Action</a></li><li><a shape="rect" class="external-link" href="http://www.hibernate.org/159.html#A9" rel="nofollow">Hibernate AdminApp (Hibernate2, WebWork, Tomcat, MySQL)</a></li><li><a shape="rect" href="non-ioc-version-of-opensessioninviewinterceptor.html">Non-IoC version of OpenSessionInViewInterceptor</a></li><li><a shape="rect" class="external-link" href="http://www.wiley.com/legacy/compbooks/walnes" rel="nofollow">Petsoar Application</a></li></ul></div> + </div> + + + </div> +</div> +<div class="footer"> + Generated by CXF SiteExporter +</div> +</body> +</html>