Clover Coverage Report - XWiki Rendering - Parent POM 4.0-SNAPSHOT (Aggregated)
Coverage timestamp: Mon Mar 12 2012 18:03:13 CET
../../../../../../img/srcFileCovDistChart10.png 0% of files have more coverage
7   89   1   7
0   38   0.14   1
1     1  
1    
 
  AnnotatedXHTMLRenderer       Line # 50 7 0% 1 0 100% 1.0
 
  (48)
 
1    /*
2    * See the NOTICE file distributed with this work for additional
3    * information regarding copyright ownership.
4    *
5    * This is free software; you can redistribute it and/or modify it
6    * under the terms of the GNU Lesser General Public License as
7    * published by the Free Software Foundation; either version 2.1 of
8    * the License, or (at your option) any later version.
9    *
10    * This software is distributed in the hope that it will be useful,
11    * but WITHOUT ANY WARRANTY; without even the implied warranty of
12    * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13    * Lesser General Public License for more details.
14    *
15    * You should have received a copy of the GNU Lesser General Public
16    * License along with this software; if not, write to the Free
17    * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
18    * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
19    */
20    package org.xwiki.rendering.internal.renderer.xhtml;
21   
22    import javax.inject.Inject;
23    import javax.inject.Named;
24   
25    import org.xwiki.rendering.internal.renderer.xhtml.image.XHTMLImageRenderer;
26    import org.xwiki.rendering.internal.renderer.xhtml.link.XHTMLLinkRenderer;
27    import org.xwiki.rendering.listener.chaining.BlockStateChainingListener;
28    import org.xwiki.rendering.listener.chaining.ListenerChain;
29    import org.xwiki.rendering.listener.chaining.EmptyBlockChainingListener;
30    import org.xwiki.rendering.listener.chaining.MetaDataStateChainingListener;
31    import org.xwiki.rendering.renderer.AbstractChainingPrintRenderer;
32    import org.xwiki.component.annotation.Component;
33    import org.xwiki.component.annotation.InstantiationStrategy;
34    import org.xwiki.component.descriptor.ComponentInstantiationStrategy;
35    import org.xwiki.component.phase.InitializationException;
36    import org.xwiki.component.phase.Initializable;
37   
38    /**
39    * Generates Annotated XHTML (ie XHTML containing metadata information, for example macro definition or
40    * link definition) from a {@link org.xwiki.rendering.block.XDOM} object being traversed.
41    * The annotations allow initial source content to be fully reconstructed from the generated XHTML. This is required
42    * for example for doing round tripping between wiki syntax and XHTML syntax in the WYSIWYG editor.
43    *
44    * @version $Id: 76fc6741fcff7e11ddde27162730cab0a47ee0cb $
45    * @since 2.0M3
46    */
47    @Component
48    @Named("annotatedxhtml/1.0")
49    @InstantiationStrategy(ComponentInstantiationStrategy.PER_LOOKUP)
 
50    public class AnnotatedXHTMLRenderer extends AbstractChainingPrintRenderer implements Initializable
51    {
52    /**
53    * To render link events into annotated XHTML. This is done so that it's pluggable because link rendering depends
54    * on how the underlying system wants to handle it. For example for XWiki we check if the document exists, we get
55    * the document URL, etc.
56    */
57    @Inject
58    @Named("annotated")
59    private XHTMLLinkRenderer linkRenderer;
60   
61    /**
62    * To render image events into annotated XHTML. This is done so that it's pluggable because image rendering depends
63    * on how the underlying system wants to handle it. For example for XWiki we check if the image exists as a
64    * document attachments, we get its URL, etc.
65    */
66    @Inject
67    @Named("annotated")
68    private XHTMLImageRenderer imageRenderer;
69   
70    /**
71    * {@inheritDoc}
72    * @see org.xwiki.component.phase.Initializable#initialize()
73    * @since 2.0M3
74    */
 
75  48 toggle @Override
76    public void initialize() throws InitializationException
77    {
78  48 ListenerChain chain = new ListenerChain();
79  48 setListenerChain(chain);
80   
81    // Construct the listener chain in the right order. Listeners early in the chain are called before listeners
82    // placed later in the chain.
83  48 chain.addListener(this);
84  48 chain.addListener(new BlockStateChainingListener(chain));
85  48 chain.addListener(new EmptyBlockChainingListener(chain));
86  48 chain.addListener(new MetaDataStateChainingListener(chain));
87  48 chain.addListener(new AnnotatedXHTMLChainingRenderer(this.linkRenderer, this.imageRenderer, chain));
88    }
89    }