* Java mapping of Scilab data has now a new method called getType() which
[scilab.git] / scilab / modules / types / src / java / org / scilab / modules / types / ScilabType.java
1 /*
2  *  Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  *  Copyright (C) 2009-2009 - DIGITEO - Bruno JOFRET
4  * 
5  *  This file must be used under the terms of the CeCILL.
6  *  This source file is licensed as described in the file COPYING, which
7  *  you should have received as part of this distribution.  The terms
8  *  are also available at
9  *  http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
10  * 
11  */
12
13 package org.scilab.modules.types;
14
15 import java.io.Serializable;
16
17 /**
18  * This interface specifies what is a Scilab types
19  */
20 public interface ScilabType extends Serializable, Cloneable {
21
22     /** 
23      * Return the type of Scilab 
24      * @return the type of Scilab
25      * @since 5.4.0
26      */
27     public ScilabTypeEnum getType();
28
29         /**
30          * Return the width (number of elements) of the stored data
31          *
32          * @return the width
33          */
34         int getWidth();
35         
36         /**
37          * Return the height (number of elements) of the stored data
38          *
39          * @return the height
40          */
41         int getHeight();
42         
43         /**
44          * Check if the current instance is empty.
45          * 
46          * @return true, the there is no data; false otherwise.
47          */
48         boolean isEmpty();
49         
50
51         /**
52          * Compare if obj is the same object or not
53          * @param obj the object we want to compare
54          * @return true if the two objects are equals, false otherwise
55          */
56         public boolean equals(Object obj);
57
58         /**
59          * Display the representation in the Scilab language of the type<br />
60          * Note that the representation can be copied/pasted straight into Scilab 
61      * 
62          * @return the pretty print
63          */
64         String toString();
65 }