01 
02 /*
03  *  Descripter 1.0 - Java Script Engines
04  *  Copyright (C) 2010-2015  Jianjun Liu (J.J.Liu)
05  *  
06  *  This program is free software: you can redistribute it and/or modify
07  *  it under the terms of the GNU Affero General Public License as published by
08  *  the Free Software Foundation, either version 3 of the License, or
09  *  (at your option) any later version.
10  *  
11  *  This program is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  *  GNU Affero General Public License for more details.
15  *  
16  *  You should have received a copy of the GNU Affero General Public License
17  *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
18  */
19 
20 package org.descripter.js.api.core;
21 
22 import org.descripter.js.api.Function;
23 
24 /**
25  * <p>Emulates JavaScript Boolean objects.</p>
26  * 
27  * @author <a href="mailto:jianjunliu@126.com">J.J.Liu (Jianjun Liu)</a> at <a href="http://www.descripter.org" target="_blank">http://www.descripter.org</a>
28  * @since Descripter 1.0
29  */
30 public class CBoolean extends CObject
31 {
32     private final Boolean value;
33 
34     /**
35      * <p>Constructs a {@link CObject} context of this type.</p>
36      * @param constructor The constructor {@link Function} object.
37      * @param value The initial value
38      * @since Descripter 1.0
39      */
40     public CBoolean(Function<?> constructor, Boolean value) {
41         super(constructor);
42         this.value = value;
43     }
44 
45     /**
46      * <p>Returns a string representation of the current object.</p>
47      * @return The string representation of the current object
48      * @since Descripter 1.0
49      */
50     @Override
51     public final String toString() {
52         return value.toString();
53     }
54 
55     /**
56      * <p>Returns the primitive value associated with this object, if there is one. </p>
57      * @return The primitive value associated with this object, if there is one, or this object itself.
58      * @since Descripter 1.0
59      */
60     @Override
61     public final Boolean valueOf() {
62         return value;
63     }
64 }