Revision 60

View differences:

org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/pom.xml
1
<?xml version="1.0" encoding="UTF-8"?>
2
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
3
	<modelVersion>4.0.0</modelVersion>
4
	
5
	<groupId>org.gvsig</groupId>
6
	<artifactId>org.gvsig.toolbox</artifactId>
7
	<packaging>pom</packaging>
8
	<name>Algorithms</name>
9
	<version>1.0.3-SNAPSHOT</version>
10
	
11
	<parent>
12
		<groupId>org.gvsig</groupId>
13
		<artifactId>org.gvsig.desktop</artifactId>
14
		<version>2.0.25</version>
15
	</parent>
16
	
17
	<scm>
18
        <connection>scm:svn:https://devel.gvsig.org/svn/gvsig-toolbox/org.gvsig.toolbox/trunk/org.gvsig.toolbox</connection>
19
        <developerConnection>scm:svn:https://devel.gvsig.org/svn/gvsig-toolbox/org.gvsig.toolbox/trunk/org.gvsig.toolbox</developerConnection>
20
        <url>https://devel.gvsig.org/redmine/projects/gvsig-toolbox/repository/show/org.gvsig.toolbox/trunk/org.gvsig.toolbox</url>
21
    </scm>
22
	
23
	<repositories>
24
      <repository>
25
        <id>gvsig-public-http-repository</id>
26
        <name>gvSIG maven public HTTP repository</name>
27
        <url>http://devel.gvsig.org/m2repo/j2se</url>
28
        <releases>
29
          <enabled>true</enabled>
30
          <updatePolicy>daily</updatePolicy>
31
          <checksumPolicy>warn</checksumPolicy>
32
        </releases>
33
        <snapshots>
34
          <enabled>true</enabled>
35
          <updatePolicy>daily</updatePolicy>
36
          <checksumPolicy>warn</checksumPolicy>
37
        </snapshots>
38
      </repository>
39
    </repositories> 
40
    
41
	<properties>
42
    	<maven.compiler.source>1.6</maven.compiler.source>
43
    	<maven.compiler.target>1.6</maven.compiler.target>
44
	</properties>
45
	
46
	 <build>
47
	
48
	    <pluginManagement>
49
	       <plugins>
50
	          <plugin>
51
                <groupId>org.codehaus.mojo</groupId>
52
                <artifactId>animal-sniffer-maven-plugin</artifactId>
53
                <version>1.7</version>
54
              </plugin>
55
	       </plugins>
56
	    </pluginManagement>
57
	    
58
	   <sourceDirectory>src</sourceDirectory>
59
	    
60
	    <resources>
61
			<resource>
62
				<directory>resources</directory>
63
				<includes>
64
					<include>**/*</include>
65
				</includes>
66
			</resource>
67
		</resources>
68
		
69
	    <plugins>
70
        	<plugin>
71
            	<groupId>org.apache.maven.plugins</groupId>
72
            	<artifactId>maven-compiler-plugin</artifactId>
73
            	<version>2.0.2</version>
74
            	<configuration>
75
                	<source>1.6</source>
76
                	<target>1.6</target>
77
                	<encoding>ISO-8859-1</encoding>
78
            	</configuration>
79
        	</plugin>
80
        	
81
        	<plugin>
82
              <groupId>org.codehaus.mojo</groupId>
83
              <artifactId>animal-sniffer-maven-plugin</artifactId>
84
              <executions>
85
                <execution>
86
                    <id>check-java-api</id>
87
                    <phase>test</phase>
88
                    <goals>
89
                        <goal>check</goal>
90
                    </goals>
91
                    <configuration>
92
                        <signature>
93
                            <groupId>org.codehaus.mojo.signature
94
                            </groupId>
95
                            <artifactId>java16</artifactId>
96
                            <version>1.0</version>
97
                        </signature>
98
                    </configuration>
99
                </execution>
100
              </executions>
101
             </plugin>
102
             
103
             <plugin>
104
                <groupId>org.apache.maven.plugins</groupId>
105
                <artifactId>maven-release-plugin</artifactId>
106
                <configuration>
107
                    <tagBase>https://devel.gvsig.org/svn/gvsig-toolbox/org.gvsig.toolbox/tags/</tagBase>
108
                    <goals>deploy</goals>
109
                </configuration>
110
            </plugin>
111
            
112
    	  </plugins>
113
    </build>
114
	
115
	<dependencyManagement>
116
      <dependencies>
117
		<dependency>
118
			<groupId>gishur</groupId>
119
			<artifactId>gishur_x</artifactId>
120
			<version>unknown</version>
121
		</dependency>
122
		<dependency>
123
			<groupId>gishur</groupId>
124
			<artifactId>gishur_core</artifactId>
125
			<version>unknown</version>
126
		</dependency>
127
		<dependency>
128
			<groupId>com.vividsolutions</groupId>
129
			<artifactId>jts</artifactId>
130
			<version>1.13</version>
131
		</dependency>
132
		<dependency>
133
			<groupId>org.gvsig</groupId>
134
			<artifactId>org.gvsig.toolbox.core</artifactId>
135
			<version>1.0.3-SNAPSHOT</version>
136
		</dependency>
137
		<dependency>
138
			<groupId>org.gvsig</groupId>
139
			<artifactId>org.gvsig.toolbox.gui</artifactId>
140
			<version>1.0.3-SNAPSHOT</version>
141
		</dependency>
142
		<dependency>
143
			<groupId>org.gvsig</groupId>
144
			<artifactId>org.gvsig.toolbox.math</artifactId>
145
			<version>1.0.3-SNAPSHOT</version>
146
		</dependency>
147
		<dependency>
148
			<groupId>gnu.trove</groupId>
149
			<artifactId>trove</artifactId>
150
			<version>0.1.8</version>
151
		</dependency>
152
		<dependency>
153
			  <groupId>org.gvsig.legacy</groupId>
154
			  <artifactId>jama</artifactId>
155
			  <version>1.0.2</version>
156
		</dependency>
157
        <dependency>
158
			<groupId>org.nfunk</groupId>
159
			<artifactId>jep</artifactId>
160
			<version>2.4.0</version>
161
		</dependency>
162
		<dependency>
163
			<groupId>commons-codec</groupId>
164
			<artifactId>commons-codec</artifactId>
165
			<version>1.8</version>
166
		</dependency>
167
		<dependency>
168
            <groupId>es.unex</groupId>
169
            <artifactId>sextante_wps</artifactId>
170
            <version>0.6.0</version>
171
        </dependency>
172
        <dependency>
173
			<groupId>es.unex</groupId>
174
			<artifactId>libDocEngines</artifactId>
175
			<version>0.6.0</version>
176
		</dependency>
177
		<dependency>
178
			<groupId>org.beanshell</groupId>
179
			<artifactId>bsh</artifactId>
180
			<version>2.0b4</version>
181
		</dependency>
182
        <dependency>
183
            <groupId>org.japura</groupId>
184
            <artifactId>org.japura</artifactId>
185
            <version>1.14.0</version>
186
        </dependency>
187
		<dependency>
188
			<groupId>commons-codec</groupId>
189
			<artifactId>commons-codec</artifactId>
190
			<version>1.8</version>
191
		</dependency>
192
	  </dependencies>
193
	</dependencyManagement>
194
	
195
	 <modules>
196
		<module>org.gvsig.toolbox.math</module>
197
		<module>org.gvsig.toolbox.gui</module>
198
		<module>org.gvsig.toolbox.core</module>
199
		<module>org.gvsig.toolbox.algorithm</module>
200
	</modules>
201
</project>
0 202

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/MANIFEST.MF
1
Manifest-Version: 1.0
2
Ant-Version: Apache Ant 1.7.1
3
Created-By: 20.1-b02 (Sun Microsystems Inc.)
4
Implementation-Version: 0.7
5
Built-Date: 2013-03-04 16:06:37
6

  
0 7

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/jsh/shell/Utils.java
1
/*
2
 * 20:25:20 20/05/99
3
 *
4
 * The Java Shell: Utilities.
5
 * (C)1999 Romain Guy, Osvaldo Pinali Doederlein.
6
 *
7
 * LICENSE
8
 * =======
9
 * This program is free software; you can redistribute it and/or
10
 * modify it under the terms of the GNU General Public License
11
 * as published by the Free Software Foundation; either version 2
12
 * of the License, or any later version.
13
 *
14
 * This program is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU General Public License
20
 * along with this program; if not, write to the Free Software
21
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22
 *
23
 * CHANGES
24
 * =======
25
 * 1.0.8 - Filled the listRoots method                   (Romain & Osvaldo)
26
 * 1.0.7 - Several bug fixes in constructPath            (Romain)
27
 * 1.0.6 - Split JDK1.1/1.2                              (Osvaldo)
28
 * 1.0.5 - Important bug fix in constructPath(String)    (Romain)
29
 * 1.0.4 - Added getSize(Enumeration)                    (Osvaldo)
30
 * 1.0.3 - Changed sortStrings bubble-sort algorithm to  (Romain)
31
 *         quick-sort (James Gosling)
32
 * 1.0.2 - Fixed two little bug in constructPath(String) (Romain)
33
 * 1.0.1 - Added listFiles(String[], boolean)            (Romain)
34
 *       - Removed unecessary createWhiteSpace(int)      (Romain)
35
 *       - Modified getWildCardMatches(String, boolean)  (Romain)
36
 *       - Slighty improved javadoc comments             (Romain)
37
 * 1.0.0 - Initial release.                              (Romain & Osvaldo)
38
 *
39
 * LINKS
40
 * =====
41
 * Contact: mailto@osvaldo.visionnaire.com.br
42
 * Site #1: http://www.geocities.com/ResearchTriangle/Node/2005/
43
 * Site #2: http://student.vub.ac.be/~opinalid/
44
 */
45

  
46
package jsh.shell;
47

  
48
import java.io.File;
49
import java.util.Enumeration;
50
import java.util.Vector;
51

  
52
import es.unex.sextante.gui.core.SextanteGUI;
53

  
54
/**
55
 * The Java Shell: Utility pack.
56
 *
57
 * @author Romain Guy.
58
 * @author Osvaldo Pinali Doederlein.
59
 */
60

  
61
public class Utils {
62

  
63
   /**
64
    * Removes some elements from a String array.
65
    *
66
    * @param arr
67
    *                The array.
68
    * @param first
69
    *                First element to keep (new 0-index).
70
    * @param last
71
    *                Last element to keep.
72
    * @return Copy of arr[first..]
73
    */
74
   public static String[] subarray(final String[] arr,
75
                                   int first,
76
                                   final int last) {
77
      final String[] newArr = new String[last - first + 1];
78

  
79
      for (int i = 0; i < newArr.length; ++i, ++first) {
80
         newArr[i] = arr[first];
81
      }
82

  
83
      return newArr;
84
   }
85

  
86

  
87
   /**
88
    * Removes some leading elements from a String array.
89
    *
90
    * @param arr
91
    *                The array.
92
    * @param first
93
    *                First element to keep (new 0-index).
94
    * @return Copy of arr[first..]
95
    */
96
   public static String[] subarray(final String[] arr,
97
                                   final int first) {
98
      return subarray(arr, first, arr.length - 1);
99
   }
100

  
101

  
102
   /**
103
    * Formats a number of bytes for output.
104
    *
105
    * @param bytes
106
    *                Number of bytes.
107
    * @return "xxxxK" form.
108
    */
109
   public static String fmtBytes(final long bytes) {
110
      return Long.toString(bytes / 1024) + "K";
111
   }
112

  
113

  
114
   /**
115
    * Formats time for output.
116
    *
117
    * @param bytes
118
    *                Number of milliseconds.
119
    * @return "x,yyys" form.
120
    */
121
   public static String fmtTime(final long ms) {
122
      return Float.toString(ms / 1000.0f) + "s";
123
   }
124

  
125

  
126
   /**
127
    * Return a String made of spaces.
128
    *
129
    * @param len
130
    *                Number of spaces
131
    */
132
   public static String getSpaces(final int len) {
133
      final StringBuffer buf = new StringBuffer();
134

  
135
      for (int i = 0; i < len; i++) {
136
         buf.append(' ');
137
      }
138

  
139
      return buf.toString();
140
   }
141

  
142

  
143
   public static String[] toArray(final Vector strings) {
144
      final String[] arr = new String[strings.size()];
145

  
146
      for (int i = 0; i < strings.size(); ++i) {
147
         arr[i] = (String) strings.elementAt(i);
148
      }
149

  
150
      return arr;
151
   }
152

  
153

  
154
   /**
155
    * When the user has to specify file names, he can use wildcards (*, ?). This methods handles the usage of these wildcards.
156
    *
157
    * @param s
158
    *                Wilcards
159
    * @param sort
160
    *                Set to true will sort file names
161
    * @return An array of String which contains all files matching <code>s</code> in current directory.
162
    * @see Utils#match(String, String)
163
    */
164

  
165
   public static String[] getWildCardMatches(final String s,
166
                                             final boolean sort) {
167
      final String args = new String(s.trim());
168
      String files[];
169
      final Vector filesThatMatchVector = new Vector();
170
      String filesThatMatch[];
171

  
172
      files = (new File(getUserDirectory())).list();
173

  
174
      for (int i = 0; i < files.length; i++) {
175
         if (match(args, files[i])) {
176
            final File temp = new File(getUserDirectory(), files[i]);
177
            filesThatMatchVector.addElement(new String(temp.getName()));
178
         }
179
      }
180

  
181
      filesThatMatch = new String[filesThatMatchVector.size()];
182
      filesThatMatchVector.copyInto(filesThatMatch);
183

  
184
      if (sort) {
185
         sortStrings(filesThatMatch);
186
      }
187

  
188
      return filesThatMatch;
189
   }
190

  
191

  
192
   /**
193
    * This method can determine if a String matches a pattern of wildcards
194
    *
195
    * @param pattern
196
    *                The pattern used for comparison
197
    * @param string
198
    *                The String to be checked
199
    * @return true if <code>string</code> matches <code>pattern</code>
200
    * @see Utils#getWildCardMatches(String)
201
    */
202

  
203
   public static boolean match(final String pattern,
204
                               final String string) {
205
      for (int p = 0;; p++) {
206
         for (int s = 0;; p++, s++) {
207
            final boolean sEnd = (s >= string.length());
208
            final boolean pEnd = (p >= pattern.length() || pattern.charAt(p) == '|');
209

  
210
            if (sEnd && pEnd) {
211
               return true;
212
            }
213
            if (sEnd || pEnd) {
214
               break;
215
            }
216
            if (pattern.charAt(p) == '?') {
217
               continue;
218
            }
219

  
220
            if (pattern.charAt(p) == '*') {
221
               int i;
222
               p++;
223

  
224
               for (i = string.length(); i >= s; --i) {
225
                  if (match(pattern.substring(p), string.substring(i))) {
226
                     return true;
227
                  }
228
               }
229

  
230
               break;
231
            }
232

  
233
            if (pattern.charAt(p) != string.charAt(s)) {
234
               break;
235
            }
236
         }
237

  
238
         p = pattern.indexOf('|', p);
239

  
240
         if (p == -1) {
241
            return false;
242
         }
243
      }
244
   }
245

  
246

  
247
   /**
248
    * Quick sort an array of Strings.
249
    *
250
    * @param string
251
    *                Strings to be sorted
252
    */
253

  
254
   public static void sortStrings(final String[] strings) {
255
      sortStrings(strings, 0, strings.length - 1);
256
   }
257

  
258

  
259
   /**
260
    * Quick sort an array of Strings.
261
    *
262
    * @param a
263
    *                Strings to be sorted
264
    * @param lo0
265
    *                Lower bound
266
    * @param hi0
267
    *                Higher bound
268
    */
269

  
270
   public static void sortStrings(final String a[],
271
                                  final int lo0,
272
                                  final int hi0) {
273
      int lo = lo0;
274
      int hi = hi0;
275
      String mid;
276

  
277
      if (hi0 > lo0) {
278
         mid = a[(lo0 + hi0) / 2];
279

  
280
         while (lo <= hi) {
281
            while (lo < hi0 && a[lo].compareTo(mid) < 0) {
282
               ++lo;
283
            }
284

  
285
            while (hi > lo0 && a[hi].compareTo(mid) > 0) {
286
               --hi;
287
            }
288

  
289
            if (lo <= hi) {
290
               swap(a, lo, hi);
291
               ++lo;
292
               --hi;
293
            }
294
         }
295

  
296
         if (lo0 < hi) {
297
            sortStrings(a, lo0, hi);
298
         }
299

  
300
         if (lo < hi0) {
301
            sortStrings(a, lo, hi0);
302
         }
303
      }
304
   }
305

  
306

  
307
   /**
308
    * Swaps two Strings.
309
    *
310
    * @param a
311
    *                The array to be swapped
312
    * @param i
313
    *                First String index
314
    * @param j
315
    *                Second String index
316
    */
317

  
318
   public static void swap(final String a[],
319
                           final int i,
320
                           final int j) {
321
      String T;
322
      T = a[i];
323
      a[i] = a[j];
324
      a[j] = T;
325
   }
326

  
327

  
328
   /**
329
    * Returns the user current directory.
330
    */
331
   public static String getUserDirectory() {
332

  
333
      String folder = SextanteGUI.getOutputFolder();
334
      if (folder == null) {
335
         folder = System.getProperty("user.home");
336
      }
337

  
338
      return folder;
339

  
340
   }
341

  
342

  
343
   /**
344
    * Sometimes, Strings are too long to be correctly displayed. This method will reduce a String, keeping first and last
345
    * characters.
346
    *
347
    * @param longString
348
    *                The String to be modified
349
    * @param maxLength
350
    *                The maximum length of the String
351
    * @return A shorter String
352
    */
353

  
354
   public static String getShortStringOf(final String longString,
355
                                         final int maxLength) {
356
      final int len = longString.length();
357

  
358
      if (len < maxLength) {
359
         return longString;
360
      }
361
      else {
362
         return longString.substring(0, maxLength / 2) + "..." + longString.substring(len - (maxLength / 2));
363
      }
364
   }
365

  
366

  
367
   /**
368
    * Because a lot of people still use JDK 1.1, we need this method to create an array of Files from an array of String.
369
    *
370
    * @param names
371
    *                Names of the files
372
    * @param construct
373
    *                Set it to true if names does not contain full paths
374
    * @return An array of Files
375
    */
376
   public static File[] listFiles(final String[] names,
377
                                  final boolean construct) {
378
      final File[] files = new File[names.length];
379

  
380
      String path = Utils.getUserDirectory();
381

  
382
      if (construct) {
383
         if (!path.endsWith(File.separator)) {
384
            path += File.separator;
385
         }
386
      }
387

  
388
      for (int i = 0; i < files.length; i++) {
389
         if (construct) {
390
            files[i] = new File(path + names[i]);
391
         }
392
         else {
393
            files[i] = new File(names[i]);
394
         }
395
      }
396

  
397
      return files;
398
   }
399

  
400

  
401
   /**
402
    * Counts things in an Enumeration (and destroys it as a side effect).
403
    *
404
    * @param enum
405
    *                The enumeration, in the start position.
406
    * @return Elements found.
407
    */
408
   public static int getSize(final Enumeration enu) {
409
      int size = 0;
410

  
411
      while (enu.hasMoreElements()) {
412
         ++size;
413
         enu.nextElement();
414
      }
415

  
416
      return size;
417
   }
418

  
419

  
420
   /**
421
    * Constructs a new path from current user path. This is an easy way to get a path if the user specified, for example,
422
    * "..\Java" as new path. This method will return the argument if this one is a path to a root (i.e, if <code>change</code>
423
    * is equal to C:\Jdk, constructPath will return C:\Jdk).
424
    *
425
    * @param change
426
    *                The modification to apply to the path
427
    * @see Utils#beginsWithRoot(String), Utils#getRoot(String)
428
    */
429

  
430
   public static String constructPath(final String change) {
431
      if (change == null || beginsWithRoot(change)) {
432
         return change;
433
      }
434

  
435
      String newPath = getUserDirectory();
436

  
437
      char current;
438
      char lastChar = '\0';
439
      boolean toAdd = false;
440
      StringBuffer buf = new StringBuffer(change.length());
441

  
442
      for (int i = 0; i < change.length(); i++) {
443
         switch ((current = change.charAt(i))) {
444
            case '.':
445
               if (lastChar == '.') {
446
                  final String parent = (new File(newPath)).getParent();
447
                  if (parent != null) {
448
                     newPath = parent;
449
                  }
450
               }
451
               else if (lastChar != '\0' && lastChar != '\\' && lastChar != '/') {
452
                  buf.append('.');
453
               }
454
               lastChar = '.';
455
               break;
456
            case '\\':
457
            case '/':
458
               if (lastChar == '\0') {
459
                  newPath = getRoot(newPath);
460
               }
461
               else {
462
                  if (!newPath.endsWith("\\")) {
463
                     newPath += File.separator + buf.toString();
464
                  }
465
                  else {
466
                     newPath += buf.toString();
467
                  }
468
                  buf = new StringBuffer();
469
                  toAdd = false;
470
               }
471
               lastChar = '\\';
472
               break;
473
            case '~':
474
               if (i < change.length() - 1) {
475
                  if (change.charAt(i + 1) == '\\' || change.charAt(i + 1) == '/') {
476
                     newPath = System.getProperties().getProperty("user.home");
477
                  }
478
                  else {
479
                     buf.append('~');
480
                  }
481
               }
482
               else if (i == 0) {
483
                  newPath = System.getProperties().getProperty("user.home");
484
               }
485
               else {
486
                  buf.append('~');
487
               }
488
               lastChar = '~';
489
               break;
490
            default:
491
               lastChar = current;
492
               buf.append(current);
493
               toAdd = true;
494
               break;
495
         }
496
      }
497

  
498
      if (toAdd) {
499
         if (!newPath.endsWith(File.separator)) {
500
            newPath += File.separator + buf.toString();
501
         }
502
         else {
503
            newPath += buf.toString();
504
         }
505
      }
506

  
507
      return newPath;
508
   }
509

  
510

  
511
   /**
512
    * It can be necessary to determine which is the root of a path. For example, the root of D:\Projects\Java is D:\.
513
    *
514
    * @param path
515
    *                The path used to get a root
516
    * @return The root which contais the specified path
517
    */
518

  
519
   public static String getRoot(final String path) {
520
      final File roots[] = listRoots(new File(path));
521

  
522
      for (int i = 0; i < roots.length; i++) {
523
         if (path.startsWith(roots[i].getPath())) {
524
            return roots[i].getPath();
525
         }
526
      }
527

  
528
      return path;
529
   }
530

  
531

  
532
   /**
533
    * It can be necessary to determine if a path begins with a root.
534
    *
535
    * @param path
536
    *                The path to check
537
    * @return True if path begins with a root, false otherwise
538
    */
539

  
540
   public static boolean beginsWithRoot(final String path) {
541
      final File roots[] = listRoots(new File(path));
542

  
543
      for (int i = 0; i < roots.length; i++) {
544
         if (path.regionMatches(true, 0, roots[i].getPath(), 0, roots[i].getPath().length())) {
545
            return true;
546
         }
547
      }
548

  
549
      return false;
550
   }
551

  
552

  
553
   /**
554
    * We override a Java2 specific method.
555
    *
556
    * @param f
557
    *                A File
558
    * @return A list of standards roots
559
    */
560

  
561
   public static File[] listRoots(final File f) {
562
      if (System.getProperty("os.name").startsWith("Windows")) {
563
         return new File[] { new File("A:\\"), new File("B:\\"), new File("C:\\"), new File("D:\\"), new File("E:\\"),
564
                  new File("F:\\"), new File("G:\\"), new File("H:\\"), new File("I:\\") };
565
         //return new File[]{new File(System.getProperty("java.home").substring(0, 3))};
566
      }
567
      else {
568
         return new File[] { new File("/") };
569
      }
570
   }
571

  
572

  
573
   /**
574
    * We override a Java2 spcific method.
575
    *
576
    * @param file
577
    *                Determine if this file is hidden or not
578
    * @return Always false
579
    */
580

  
581
   public boolean isHidden(final File file) {
582
      return false;
583
   }
584

  
585
}
586

  
587
// End of Utils.java
0 588

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/RenderingData.java
1

  
2

  
3
package es.unex.sextante.gui.core;
4

  
5
public class RenderingData {
6

  
7
   public String algName;
8
   public String outputName;
9
   public Object rendering;
10

  
11
}
0 12

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/GenericInfoDialog.java
1
package es.unex.sextante.gui.core;
2

  
3
import java.awt.BorderLayout;
4
import java.awt.Component;
5
import java.awt.Frame;
6

  
7
import javax.swing.JDialog;
8
import javax.swing.JPanel;
9

  
10
/**
11
 * A simple dialog to show a java component
12
 * 
13
 * @author volaya
14
 * 
15
 */
16
public class GenericInfoDialog
17
         extends
18
            JDialog {
19

  
20
   /**
21
    * constructor
22
    * 
23
    * @param component
24
    *                the component to show in the dialog
25
    * @param sTitle
26
    *                the title of the dialog
27
    * @param parent
28
    *                the parent frame
29
    */
30
   public GenericInfoDialog(final Component component,
31
                            final String sTitle,
32
                            final Frame parent) {
33

  
34
      super(parent, sTitle, true);
35

  
36
      initGUI(component);
37

  
38
      pack();
39
      setLocationRelativeTo(null);
40

  
41
   }
42

  
43

  
44
   protected void initGUI(final Component component) {
45

  
46
      setPreferredSize(component.getPreferredSize());
47
      setSize(component.getPreferredSize());
48
      final BorderLayout thisLayout = new BorderLayout();
49
      final JPanel pane = new JPanel();
50
      pane.setLayout(thisLayout);
51
      setContentPane(pane);
52
      pane.add(component, BorderLayout.CENTER);
53

  
54
   }
55

  
56

  
57
}
0 58

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/IPostProcessTaskFactory.java
1
package es.unex.sextante.gui.core;
2

  
3
import es.unex.sextante.core.GeoAlgorithm;
4
import es.unex.sextante.gui.additionalResults.AdditionalResults;
5

  
6
/**
7
 * Interface to be implemented by post process factories. A post process factory is used to define the task that should be
8
 * performed with algorithm results, once a SEXTANTE geoalgorithm has been executed from the SEXTANTE GUI
9
 * 
10
 * @author volaya
11
 * 
12
 */
13
public interface IPostProcessTaskFactory {
14

  
15
   /**
16
    * Returns a task to post-process the given algorithm. This task should take the outputs generated by the algorithm, adding
17
    * them to the GUI or doing with them whatever is needed.
18
    * 
19
    * To be compatible with the {@link AdditionalResults} class, charts and text result has to be added as java Components. Check
20
    * the documentation of that class for more information.
21
    * 
22
    * @param alg
23
    *                the algorithm to post-process
24
    * @param bShowResultsDialog
25
    *                if this parameter is true, the task will show the results dialog if the algorithm has produced some kind of
26
    *                output other than layers or tables. If it is false, those results will be added to the set of current
27
    *                results, but the results dialog will not be shown
28
    * @return a task to post-process the given algorithm
29
    */
30
   public Runnable getPostProcessTask(GeoAlgorithm alg,
31
                                      boolean bShowResultsDialog);
32

  
33

  
34
}
0 35

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/IDataRenderer.java
1

  
2

  
3
package es.unex.sextante.gui.core;
4

  
5
import java.util.HashMap;
6

  
7
import es.unex.sextante.dataObjects.ILayer;
8

  
9

  
10
/**
11
 * A class containing information needed to set rendering styles for layers generated by SEXTANTE geoalgorithms
12
 * 
13
 * @author volaya
14
 * 
15
 */
16
public interface IDataRenderer {
17

  
18
   public Object getRenderingForLayer(String sAlgCmdName,
19
                                      String sOutputName);
20

  
21

  
22
   public void setRenderingForAlgorithm(String sAlgCmdName,
23
                                        HashMap<String, Object> renderer);
24

  
25

  
26
   public void save();
27

  
28

  
29
   public void open();
30

  
31

  
32
   public Object getRenderingDataFromLayer(ILayer layer);
33

  
34
}
0 35

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/IAlgorithmProvider.java
1
package es.unex.sextante.gui.core;
2

  
3
import java.util.ArrayList;
4
import java.util.HashMap;
5

  
6
import javax.swing.ImageIcon;
7

  
8
import es.unex.sextante.core.GeoAlgorithm;
9
import es.unex.sextante.gui.settings.Setting;
10

  
11
public interface IAlgorithmProvider {
12

  
13
   /**
14
    * Performs the initialization needed to load the corresponding algorithm into the algorithm provider
15
    */
16
   public void initialize();
17

  
18

  
19
   /**
20
    * Returns the name of the algorithm provider. This will be used as the group name in the toolbox
21
    * 
22
    * @return
23
    */
24
   public String getName();
25

  
26

  
27
   /**
28
    * Returns a map with algorithm command-line names as keys and geoalgorithms as values
29
    * 
30
    * @return a map with algorithm command-line names as keys and geoalgorithms as values
31
    */
32
   public HashMap<String, GeoAlgorithm> getAlgorithms();
33

  
34

  
35
   /**
36
    * Returns a map of custom parameter panels. Keys are algorithm command-line names, and values are the corresponding panel
37
    * classes
38
    * 
39
    * @return a map of custom parameter panels.
40
    */
41
   public HashMap<String, Class> getCustomModelerParameterPanels();
42

  
43

  
44
   /**
45
    * Returns a map of custom modeler parameter panels. Keys are algorithm command-line names, and values are the corresponding
46
    * panel classes
47
    * 
48
    * @return a map of custom modeler parameter panels.
49
    */
50
   public HashMap<String, Class> getCustomParameterPanels();
51

  
52

  
53
   /**
54
    * Returns the icon to use for the algorithms provided by this provider
55
    * 
56
    * @return the icon to use for the algorithms provided by this provider
57
    */
58
   public ImageIcon getIcon();
59

  
60

  
61
   /**
62
    * Returns the settings object corresponding to this provider
63
    * 
64
    * @return the settings object corresponding to this provider
65
    */
66
   public Setting getSettings();
67

  
68

  
69
   /**
70
    * Updates the list of algorithms in this provider
71
    */
72
   public void update();
73

  
74

  
75
   /**
76
    * 
77
    * Returns the help associated with the passed algorithm as a HTML string or a URL
78
    * 
79
    * @param alg
80
    *                the algorithm
81
    * @return the help associated with the passed algorithm as a HTML string or a URL
82
    */
83
   public Object getAlgorithmHelp(GeoAlgorithm alg);
84

  
85

  
86
   /**
87
    * Returns the filename where the help for a given algorithm is stored
88
    * 
89
    * @param alg
90
    *                the algorithm
91
    * @param bForceCurrentLocale
92
    *                if true it will return the current locale folder, even if the help file does not exists
93
    * @return
94
    */
95
   public String getAlgorithmHelpFilename(GeoAlgorithm alg,
96
                                          boolean bForceCurrentLocale);
97

  
98

  
99
   /**
100
    * Returns true if the help files associated with the algorithms from this provider can be edited by the user
101
    * 
102
    * @return true if the help files associated with the algorithms from this provider can be edited by the user
103
    */
104
   public boolean canEditHelp();
105

  
106

  
107
   /**
108
    * Returns the toolbox actions to be added to the toolbox by this algorithm provider.
109
    * 
110
    * @return A Map containing toolbox actions to be added to the toolbox by this algorithm provider
111
    */
112
   public HashMap<NameAndIcon, ArrayList<ToolboxAction>> getToolboxActions();
113

  
114

  
115
   /**
116
    * Return the right button actions to be added to the toolbox by this algorithm provider. These actions should work on the
117
    * particular type of algorithms provided by the provider
118
    * 
119
    * @return the right button actions to be added to the toolbox by this algorithm provider.
120
    */
121
   public IToolboxRightButtonAction[] getToolboxRightButtonActions();
122

  
123

  
124
}
0 125

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/ProgressMonitor.java
1
package es.unex.sextante.gui.core;
2

  
3
import info.clearthought.layout.TableLayout;
4
import info.clearthought.layout.TableLayoutConstants;
5

  
6
import java.awt.Dimension;
7
import java.awt.event.ActionEvent;
8
import java.awt.event.ActionListener;
9

  
10
import javax.swing.JButton;
11
import javax.swing.JDialog;
12
import javax.swing.JLabel;
13
import javax.swing.JProgressBar;
14
import javax.swing.SwingUtilities;
15
import javax.swing.WindowConstants;
16

  
17
import es.unex.sextante.core.Sextante;
18
import es.unex.sextante.gui.grass.GrassUtils;
19

  
20
/**
21
 * A progress monitor showing a progress bar and a cancel button
22
 * 
23
 * @author volaya
24
 * 
25
 */
26
public class ProgressMonitor
27
         extends
28
            JDialog {
29

  
30
   private JLabel       jTitle;
31
   private JButton      jButtonCancel;
32
   private JProgressBar jProgressBar;
33
   private JLabel       jProgressText;
34
   private boolean      m_bCanceled;
35
   private String       m_sPrefix      = "";
36
   private String       m_sDescription = "";
37

  
38

  
39
   /**
40
    * Constructor
41
    * 
42
    * @param sText
43
    *                The title text to show
44
    * @param bDeterminate
45
    *                true if the process to monitor is determinate
46
    * @param parent
47
    *                the parent dialog
48
    */
49
   public ProgressMonitor(final String sText,
50
                          final boolean bDeterminate,
51
                          final JDialog parent) {
52

  
53
      super(parent, "", false);
54

  
55
      setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE);
56
      setLocationRelativeTo(null);
57

  
58
      m_bCanceled = false;
59
      m_sDescription = sText;
60

  
61
      initGUI(bDeterminate);
62

  
63
   }
64

  
65

  
66
   /**
67
    * Constructor. Uses the main frame as the parent component
68
    * 
69
    * @param sText
70
    *                The title text to show
71
    * @param bDeterminate
72
    *                true if the process to monitor is determinate
73
    */
74
   public ProgressMonitor(final String sText,
75
                          final boolean bDeterminate) {
76

  
77
      super(SextanteGUI.getMainFrame(), "", false);
78

  
79
      setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE);
80
      setLocationRelativeTo(null);
81

  
82
      m_bCanceled = false;
83
      m_sDescription = sText;
84

  
85
      initGUI(bDeterminate);
86

  
87
   }
88

  
89

  
90
   private void initGUI(boolean bDeterminate) {
91

  
92
      final TableLayout thisLayout = new TableLayout(new double[][] {
93
               { 6.0, TableLayoutConstants.FILL, TableLayoutConstants.FILL, 6.0 },
94
               { 1.0, TableLayoutConstants.FILL, TableLayoutConstants.FILL, 1, 15.0, 1.0, 25.0, 1.0 } });
95
      thisLayout.setHGap(5);
96
      thisLayout.setVGap(5);
97
      setPreferredSize(new Dimension(350, 150));
98
      setSize(new Dimension(350, 150));
99
      getContentPane().setLayout(thisLayout);
100
      {
101
         jTitle = new JLabel(m_sDescription);
102
         getContentPane().add(jTitle, "1, 1, 2, 1");
103
      }
104
      {
105
         jButtonCancel = new JButton();
106
         getContentPane().add(jButtonCancel, "2, 6");
107
         jButtonCancel.setText(Sextante.getText("Cancel"));
108
         jButtonCancel.addActionListener(new ActionListener() {
109
            public void actionPerformed(final ActionEvent evt) {
110
               cancel();
111
            }
112
         });
113
      }
114
      {
115
         jProgressBar = new JProgressBar();
116
         jProgressBar.setIndeterminate(!bDeterminate);
117
         if (bDeterminate) {
118
            jProgressBar.setMinimum(0);
119
            jProgressBar.setMaximum(100);
120
            jProgressBar.setValue(0);
121
         }
122
         getContentPane().add(jProgressBar, "1, 4, 2, 4");
123
      }
124
      {
125
         jProgressText = new JLabel();
126
         getContentPane().add(jProgressText, "1, 2");
127
      }
128

  
129
   }
130

  
131

  
132
   private void cancel() {
133

  
134
      //If this is a running GRASS process: kill it
135
      GrassUtils.cancelProcess();
136

  
137
      m_bCanceled = true;
138

  
139
   }
140

  
141

  
142
   /**
143
    * Returns true if the process has been canceled using the cancel button
144
    * 
145
    * @return true if the process has been canceled
146
    */
147
   public boolean isCanceled() {
148

  
149
      return m_bCanceled;
150

  
151
   }
152

  
153

  
154
   /**
155
    * Sets the text describing the current phase of the process being monitored
156
    * 
157
    * @param sText
158
    *                the description
159
    */
160
   public void setProgressText(final String sText) {
161

  
162
      try {
163
         final Runnable runnable = new Runnable() {
164
            public void run() {
165
               jProgressText.setText(sText);
166
            }
167
         };
168
         if (SwingUtilities.isEventDispatchThread()) {
169
            runnable.run();
170
         }
171
         else {
172
            SwingUtilities.invokeAndWait(runnable);
173
         }
174
      }
175
      catch (final Exception e) {}
176

  
177

  
178
   }
179

  
180

  
181
   /**
182
    * Sets the description to show at the top of the progress monitor
183
    * 
184
    * @param sDescription
185
    *                the description
186
    */
187
   public void setDescription(final String sDescription) {
188

  
189
      m_sDescription = sDescription;
190
      updateTitle();
191

  
192
   }
193

  
194

  
195
   private void updateTitle() {
196

  
197
      try {
198

  
199
         final Runnable runnable = new Runnable() {
200
            public void run() {
201
               jTitle.setText(m_sPrefix + m_sDescription);
202
            }
203
         };
204
         if (SwingUtilities.isEventDispatchThread()) {
205
            runnable.run();
206
         }
207
         else {
208
            SwingUtilities.invokeAndWait(runnable);
209
         }
210
      }
211
      catch (final Exception e) {}
212

  
213
   }
214

  
215

  
216
   /**
217
    * Sets the current progress value (in the range 1-100)
218
    * 
219
    * @param iValue
220
    */
221
   public void setProgress(final int iValue) {
222

  
223
      try {
224
         final Runnable runnable = new Runnable() {
225
            public void run() {
226
               jProgressBar.setValue(iValue);
227
            }
228
         };
229
         if (SwingUtilities.isEventDispatchThread()) {
230
            runnable.run();
231
         }
232
         else {
233
            SwingUtilities.invokeAndWait(runnable);
234
         }
235
      }
236
      catch (final Exception e) {}
237

  
238
   }
239

  
240

  
241
   /**
242
    * Sets whether the process being monitored is determinate or not
243
    * 
244
    * @param bDeterminate
245
    */
246
   public void setDeterminate(final boolean bDeterminate) {
247

  
248
      try {
249
         final Runnable runnable = new Runnable() {
250
            public void run() {
251
               jProgressBar.setIndeterminate(!bDeterminate);
252
            }
253
         };
254
         if (SwingUtilities.isEventDispatchThread()) {
255
            runnable.run();
256
         }
257
         else {
258
            SwingUtilities.invokeAndWait(runnable);
259
         }
260
      }
261
      catch (final Exception e) {}
262

  
263
   }
264

  
265

  
266
   /**
267
    * this method sets a prefix to be prepended to the description title. This can be used for processes that include several
268
    * algorithms, so when each algorithm sets its owns description, it will also contain a string indicating the part of the
269
    * global process that it represents. This method should, therefore, not be called by simple algorithms, but just from complex
270
    * processes
271
    * 
272
    * @param sPrefix
273
    *                the prefix to prepend to the description title.
274
    */
275
   public void setDescriptionPrefix(final String sPrefix) {
276

  
277
      m_sPrefix = sPrefix;
278
      updateTitle();
279

  
280

  
281
   }
282

  
283
}
0 284

  
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/NameAndIcon.java
1

  
2

  
3
package es.unex.sextante.gui.core;
4

  
5
import javax.swing.ImageIcon;
6

  
7

  
8
public class NameAndIcon {
9

  
10
   private String    m_sName;
11
   private ImageIcon m_Icon;
12

  
13

  
14
   public NameAndIcon(final String sName,
15
                      final ImageIcon icon) {
16

  
17
      m_sName = sName;
18
      m_Icon = icon;
19

  
... This diff was truncated because it exceeds the maximum size that can be displayed.

Also available in: Unified diff