MarkedObject.java

1
/*
2
 * $Id: MarkedObject.java 3373 2008-05-12 16:21:24Z xlv $
3
 *
4
 * Copyright 2007 by Bruno Lowagie.
5
 *
6
 * The contents of this file are subject to the Mozilla Public License Version 1.1
7
 * (the "License"); you may not use this file except in compliance with the License.
8
 * You may obtain a copy of the License at http://www.mozilla.org/MPL/
9
 *
10
 * Software distributed under the License is distributed on an "AS IS" basis,
11
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12
 * for the specific language governing rights and limitations under the License.
13
 *
14
 * The Original Code is 'iText, a free JAVA-PDF library'.
15
 *
16
 * The Initial Developer of the Original Code is Bruno Lowagie. Portions created by
17
 * the Initial Developer are Copyright (C) 1999-2007 by Bruno Lowagie.
18
 * All Rights Reserved.
19
 * Co-Developer of the code is Paulo Soares. Portions created by the Co-Developer
20
 * are Copyright (C) 2000-2007 by Paulo Soares. All Rights Reserved.
21
 *
22
 * Contributor(s): all the names of the contributors are added in the source code
23
 * where applicable.
24
 *
25
 * Alternatively, the contents of this file may be used under the terms of the
26
 * LGPL license (the "GNU LIBRARY GENERAL PUBLIC LICENSE"), in which case the
27
 * provisions of LGPL are applicable instead of those above.  If you wish to
28
 * allow use of your version of this file only under the terms of the LGPL
29
 * License and not to allow others to use your version of this file under
30
 * the MPL, indicate your decision by deleting the provisions above and
31
 * replace them with the notice and other provisions required by the LGPL.
32
 * If you do not delete the provisions above, a recipient may use your version
33
 * of this file under either the MPL or the GNU LIBRARY GENERAL PUBLIC LICENSE.
34
 *
35
 * This library is free software; you can redistribute it and/or modify it
36
 * under the terms of the MPL as stated above or under the terms of the GNU
37
 * Library General Public License as published by the Free Software Foundation;
38
 * either version 2 of the License, or any later version.
39
 *
40
 * This library is distributed in the hope that it will be useful, but WITHOUT
41
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
42
 * FOR A PARTICULAR PURPOSE. See the GNU Library general Public License for more
43
 * details.
44
 *
45
 * If you didn't download this code from the following link, you should check if
46
 * you aren't using an obsolete version:
47
 * http://www.lowagie.com/iText/
48
 */
49
50
package com.lowagie.text;
51
52
import java.util.ArrayList;
53
import java.util.Properties;
54
55
/**
56
 * Wrapper that allows to add properties to 'basic building block' objects.
57
 * Before iText 1.5 every 'basic building block' implemented the MarkupAttributes interface.
58
 * By setting attributes, you could add markup to the corresponding XML and/or HTML tag.
59
 * This functionality was hardly used by anyone, so it was removed, and replaced by
60
 * the MarkedObject functionality.
61
 */
62
63
public class MarkedObject implements Element {
64
65
    /** The element that is wrapped in a MarkedObject. */
66
    protected Element element;
67
68
    /** Contains extra markupAttributes */
69
    protected Properties markupAttributes = new Properties();
70
        
71
    /**
72
     * This constructor is for internal use only.
73
     */
74
    protected MarkedObject() {
75
        element = null;
76
    }
77
    
78
    /**
79
     * Creates a MarkedObject.
80
     */
81
    public MarkedObject(Element element) {
82
        this.element = element;
83
    }
84
    
85
    /**
86
     * Gets all the chunks in this element.
87
     *
88
     * @return  an <CODE>ArrayList</CODE>
89
     */
90
    public ArrayList getChunks() {
91
        return element.getChunks();
92
    }
93
94
    /**
95
     * Processes the element by adding it (or the different parts) to an
96
     * <CODE>ElementListener</CODE>.
97
     *
98
     * @param       listener        an <CODE>ElementListener</CODE>
99
     * @return <CODE>true</CODE> if the element was processed successfully
100
     */
101
    public boolean process(ElementListener listener) {
102
        try {
103 1 1. process : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
            return listener.add(element);
104
        }
105
        catch(DocumentException de) {
106 1 1. process : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
            return false;
107
        }
108
    }
109
    
110
    /**
111
     * Gets the type of the text element.
112
     *
113
     * @return  a type
114
     */
115
    public int type() {
116
        return MARKED;
117
    }
118
    
119
    /**
120
     * @see com.lowagie.text.Element#isContent()
121
     * @since    iText 2.0.8
122
     */
123
    public boolean isContent() {
124
        return true;
125
    }
126
127
    /**
128
     * @see com.lowagie.text.Element#isNestable()
129
     * @since    iText 2.0.8
130
     */
131
    public boolean isNestable() {
132
        return true;
133
    }
134
135
    /**
136
     * Getter for the markup attributes.
137
     * @return the markupAttributes
138
     */
139
    public Properties getMarkupAttributes() {
140
        return markupAttributes;
141
    }
142
    
143
    /**
144
     * Adds one markup attribute.
145
     */
146
    public void setMarkupAttribute(String key, String value) {
147
        markupAttributes.setProperty(key, value);
148
    }
149
150
}

Mutations

103

1.1
Location : process
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

106

1.1
Location : process
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

Active mutators

Tests examined


Report generated by PIT 1.4.2