Tue, 10 Feb 2015 18:12:00 +0100
Import initial revisions of existing project AndroidCaldavSyncAdapater,
forked from upstream repository at 27e8a0f8495c92e0780d450bdf0c7cec77a03a55.
1 /**
2 * Copyright (c) 2012, Ben Fortuna
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * o Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 *
12 * o Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 *
16 * o Neither the name of Ben Fortuna nor the names of any other contributors
17 * may be used to endorse or promote products derived from this software
18 * without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
24 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
27 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
28 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
29 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
30 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 */
32 package net.fortuna.ical4j.model.property;
34 import net.fortuna.ical4j.model.ParameterList;
35 import net.fortuna.ical4j.model.Property;
36 import net.fortuna.ical4j.model.PropertyFactoryImpl;
37 import net.fortuna.ical4j.model.ValidationException;
38 import net.fortuna.ical4j.util.CompatibilityHints;
40 /**
41 * $Id$
42 *
43 * Created: [Apr 6, 2004]
44 *
45 * Defines a CALSCALE iCalendar property.
46 * @author benf
47 */
48 public class CalScale extends Property {
50 private static final long serialVersionUID = 7446184786984981423L;
52 /**
53 * Constant for Gregorian calendar representation.
54 */
55 public static final CalScale GREGORIAN = new ImmutableCalScale("GREGORIAN");
57 /**
58 * @author Ben Fortuna An immutable instance of CalScale.
59 */
60 private static final class ImmutableCalScale extends CalScale {
62 private static final long serialVersionUID = 1750949550694413878L;
64 /**
65 * @param value
66 */
67 private ImmutableCalScale(final String value) {
68 super(new ParameterList(true), value);
69 }
71 /**
72 * {@inheritDoc}
73 */
74 public void setValue(final String aValue) {
75 throw new UnsupportedOperationException(
76 "Cannot modify constant instances");
77 }
78 }
80 private String value;
82 /**
83 * Default constructor.
84 */
85 public CalScale() {
86 super(CALSCALE, PropertyFactoryImpl.getInstance());
87 }
89 /**
90 * @param aValue a value string for this component
91 */
92 public CalScale(final String aValue) {
93 super(CALSCALE, PropertyFactoryImpl.getInstance());
94 this.value = aValue;
95 }
97 /**
98 * @param aList a list of parameters for this component
99 * @param aValue a value string for this component
100 */
101 public CalScale(final ParameterList aList, final String aValue) {
102 super(CALSCALE, aList, PropertyFactoryImpl.getInstance());
103 this.value = aValue;
104 }
106 /**
107 * {@inheritDoc}
108 */
109 public void setValue(final String aValue) {
110 this.value = aValue;
111 }
113 /**
114 * {@inheritDoc}
115 */
116 public final String getValue() {
117 return value;
118 }
120 /**
121 * {@inheritDoc}
122 */
123 public final void validate() throws ValidationException {
124 if (CompatibilityHints.isHintEnabled(CompatibilityHints.KEY_RELAXED_VALIDATION)) {
125 if (!GREGORIAN.getValue().equalsIgnoreCase(value)) {
126 throw new ValidationException("Invalid value [" + value + "]");
127 }
128 }
129 else {
130 if (!GREGORIAN.getValue().equals(value)) {
131 throw new ValidationException("Invalid value [" + value + "]");
132 }
133 }
134 }
135 }