KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > krysalis > barcode > ChecksumMode


1 /*
2  * $Id$
3  * ============================================================================
4  * The Krysalis Patchy Software License, Version 1.1_01
5  * Copyright (c) 2002-2003 Nicola Ken Barozzi. All rights reserved.
6  *
7  * This Licence is compatible with the BSD licence as described and
8  * approved by http://www.opensource.org/, and is based on the
9  * Apache Software Licence Version 1.1.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  *
15  * 1. Redistributions of source code must retain the above copyright
16  * notice, this list of conditions and the following disclaimer.
17  *
18  * 2. Redistributions in binary form must reproduce the above copyright
19  * notice, this list of conditions and the following disclaimer in
20  * the documentation and/or other materials provided with the
21  * distribution.
22  *
23  * 3. The end-user documentation included with the redistribution,
24  * if any, must include the following acknowledgment:
25  * "This product includes software developed for project
26  * Krysalis (http://www.krysalis.org/)."
27  * Alternately, this acknowledgment may appear in the software itself,
28  * if and wherever such third-party acknowledgments normally appear.
29  *
30  * 4. The names "Krysalis" and "Nicola Ken Barozzi" and
31  * "Krysalis Barcode" must not be used to endorse or promote products
32  * derived from this software without prior written permission. For
33  * written permission, please contact nicolaken@krysalis.org.
34  *
35  * 5. Products derived from this software may not be called "Krysalis",
36  * "Krysalis Barcode", nor may "Krysalis" appear in their name,
37  * without prior written permission of Nicola Ken Barozzi.
38  *
39  * 6. This software may contain voluntary contributions made by many
40  * individuals, who decided to donate the code to this project in
41  * respect of this licence, and was originally created by
42  * Jeremias Maerki <jeremias@maerki.org>.
43  *
44  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
45  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
46  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
47  * DISCLAIMED. IN NO EVENT SHALL THE KRYSALIS PROJECT OR
48  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
49  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
50  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
51  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
52  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
53  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
54  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
55  * SUCH DAMAGE.
56  * ====================================================================
57  */

58 package org.krysalis.barcode;
59
60 import org.apache.avalon.framework.Enum;
61
62 /**
63  * Enumeration type for checksum policy.
64  *
65  * @author Jeremias Maerki
66  */

67 public class ChecksumMode extends Enum JavaDoc {
68
69     /** "auto" chooses the barcode's default checksum behaviour */
70     public static final ChecksumMode CP_AUTO = new ChecksumMode("auto");
71     /** "ignore" doesn't check nor add a checksum */
72     public static final ChecksumMode CP_IGNORE = new ChecksumMode("ignore");
73     /** "add" adds the necessary checksum to the message to be encoded */
74     public static final ChecksumMode CP_ADD = new ChecksumMode("add");
75     /** "check" requires the check character to be present in the message. It
76      * will be checked.
77      */

78     public static final ChecksumMode CP_CHECK = new ChecksumMode("check");
79
80     /**
81      * Creates a new ChecksumMode instance.
82      * @param name the name of the ChecksumMode
83      */

84     protected ChecksumMode(String JavaDoc name) {
85         super(name);
86     }
87     
88     /**
89      * Returns a ChecksumMode instance by name.
90      * @param name the name of the ChecksumMode
91      * @return the requested instance
92      */

93     public static ChecksumMode byName(String JavaDoc name) {
94         if (name.equalsIgnoreCase(ChecksumMode.CP_AUTO.getName())) {
95             return ChecksumMode.CP_AUTO;
96         } else if (name.equalsIgnoreCase(ChecksumMode.CP_IGNORE.getName())) {
97             return ChecksumMode.CP_IGNORE;
98         } else if (name.equalsIgnoreCase(ChecksumMode.CP_ADD.getName())) {
99             return ChecksumMode.CP_ADD;
100         } else if (name.equalsIgnoreCase(ChecksumMode.CP_CHECK.getName())) {
101             return ChecksumMode.CP_CHECK;
102         } else {
103             throw new IllegalArgumentException JavaDoc("Invalid ChecksumMode: " + name);
104         }
105     }
106     
107 }
108
Popular Tags