Statistics
| Revision:

gvsig-scripting / org.gvsig.scripting.app / trunk / org.gvsig.scripting.app / org.gvsig.scripting.app.extension / src / main / java / org / gvsig / scripting / app / extension / ScriptingExtension.java @ 458

History | View | Annotate | Download (5.8 KB)

1 191 jbadia
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * of the License, or (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 General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 */
22
23
package org.gvsig.scripting.app.extension;
24
25
26 253 jjdelcerro
import java.io.File;
27 458 jbadia
import java.util.Arrays;
28 442 jjdelcerro
import java.util.List;
29 253 jjdelcerro
30 361 jjdelcerro
import javax.swing.JOptionPane;
31
32 442 jjdelcerro
import org.gvsig.andami.IconThemeHelper;
33 253 jjdelcerro
import org.gvsig.andami.PluginsLocator;
34
import org.gvsig.andami.PluginsManager;
35 191 jbadia
import org.gvsig.andami.plugins.Extension;
36 361 jjdelcerro
import org.gvsig.app.ApplicationLocator;
37
import org.gvsig.app.ApplicationManager;
38 360 jjdelcerro
import org.gvsig.scripting.ScriptingBaseScript;
39 253 jjdelcerro
import org.gvsig.scripting.ScriptingLocator;
40 191 jbadia
import org.gvsig.scripting.ScriptingManager;
41 303 jjdelcerro
import org.gvsig.scripting.swing.api.JScriptingComposer;
42 191 jbadia
import org.gvsig.scripting.swing.api.ScriptingSwingLocator;
43
import org.gvsig.scripting.swing.api.ScriptingUIManager;
44 303 jjdelcerro
import org.gvsig.tools.dynobject.DynObject;
45 253 jjdelcerro
import org.gvsig.tools.swing.api.ToolsSwingLocator;
46
import org.gvsig.tools.swing.api.windowmanager.WindowManager;
47 303 jjdelcerro
import org.gvsig.tools.swing.impl.windowmanager.DefaultWindowManager;
48 442 jjdelcerro
import org.slf4j.Logger;
49
import org.slf4j.LoggerFactory;
50 191 jbadia
51
public class ScriptingExtension extends Extension {
52
53 442 jjdelcerro
        private static Logger logger = LoggerFactory.getLogger(ScriptingExtension.class);
54 303 jjdelcerro
55 191 jbadia
        public void execute(String actionCommand) {
56 360 jjdelcerro
                this.execute(actionCommand,null);
57
        }
58
59
        public void execute(String command, Object[] args) {
60 253 jjdelcerro
            ScriptingUIManager uimanager = ScriptingSwingLocator.getUIManager();
61
                WindowManager winmanager = ToolsSwingLocator.getWindowManager();
62 191 jbadia
63 442 jjdelcerro
                if( "tools-scripting-launcher".equalsIgnoreCase(command) ) {
64 458 jbadia
                    winmanager.showWindow(uimanager.createLauncher(), uimanager.getTranslation("Scripting_Launcher"), WindowManager.MODE.TOOL);
65 361 jjdelcerro
66 442 jjdelcerro
                } else if( "tools-scripting-composer".equalsIgnoreCase(command) ) {
67 303 jjdelcerro
                        DynObject preferences = this.getPlugin().getPluginProperties();
68
                        Boolean composerUseHisWindowManager = (Boolean) preferences.getDynValue("ComposerUseHisWindowManager");
69
                        JScriptingComposer composer = uimanager.createComposer();
70
                        if( composerUseHisWindowManager.booleanValue() ) {
71
                                winmanager = new DefaultWindowManager();
72
                                composer.setWindowManager(winmanager);
73 458 jbadia
                                winmanager.showWindow(composer, uimanager.getTranslation("Scripting_Composer"), WindowManager.MODE.WINDOW);
74 303 jjdelcerro
                        } else {
75 458 jbadia
                                winmanager.showWindow(composer, uimanager.getTranslation("Scripting_Composer"), WindowManager.MODE.WINDOW);
76 303 jjdelcerro
                        }
77 361 jjdelcerro
78
                } else {
79
                        ScriptingBaseScript script = uimanager.getManager().getScript(command);
80
                        if( script != null ) {
81
                                script.run(args);
82
                        } else {
83
                                ApplicationManager application = ApplicationLocator.getManager();
84
                                application.messageDialog("Can't locate script '"+command+"'.", "ScriptLaunch", JOptionPane.OK_OPTION);
85
                        }
86 191 jbadia
                }
87
        }
88
89 253 jjdelcerro
        public void initialize() {
90 442 jjdelcerro
                IconThemeHelper.registerIcon("action", "tools-scripting-launcher", this);
91
                IconThemeHelper.registerIcon("action", "tools-scripting-composer", this);
92
                IconThemeHelper.registerIcon("action", "tools-scripting-console-jython", this);
93 191 jbadia
        }
94
95 253 jjdelcerro
        public void postInitialize() {
96
            super.postInitialize();
97
            ScriptingManager manager = ScriptingLocator.getManager();
98
            PluginsManager pluginManager = PluginsLocator.getManager();
99 191 jbadia
100 303 jjdelcerro
            File home = this.getPlugin().getPluginHomeFolder();
101
            manager.setHomeFolder(home);
102
103 458 jbadia
            List<File> pluginsFolders = Arrays.asList(pluginManager.getPluginsFolder().listFiles());
104 442 jjdelcerro
            for( File pluginsFolder : pluginsFolders ) {
105
                    File[] folders = pluginsFolder.listFiles();
106
                    for (File folder : folders) {
107
                            File scriptsFolder = new File(folder,"scripting/scripts");
108
                            if( scriptsFolder.exists() ) {
109
                                    manager.registerSystemFolder(folder.getName(), scriptsFolder);
110
                            }
111
                            File libFolder = new File(folder,"scripting/lib");
112
                            if( libFolder.exists() ) {
113
                                    manager.addLibFolder(libFolder);
114
                            }
115
                        }
116
            }
117
            File autorun_file = null;
118
            ScriptingBaseScript autorun = null;
119
            for( File pluginsFolder : pluginsFolders ) {
120
                    File[] folders = pluginsFolder.listFiles();
121
                    for (File folder : folders) {
122
                            autorun_file = new File(folder,"scripting/scripts/autorun.inf");
123
                            if( autorun_file.exists() ) {
124
                                    autorun = manager.getScript(autorun_file);
125
                                    try {
126
                                            autorun.run();
127
                                    } catch(Exception ex) {
128
                                            logger.warn("Can't execute autorun from '"+autorun_file.getAbsolutePath()+"'.",ex);
129
                                    }
130
                            }
131
                        }
132
            }
133
            try {
134
                    autorun_file = new File( manager.getRootUserFolder(),"autorun.inf" );
135
                    if( autorun_file.exists() ) {
136
                        autorun = (ScriptingBaseScript) manager.getUserFolder().getUnit(new File("autorun.inf"));
137
                        if( autorun!=null) {
138
                                autorun.run();
139
                        }
140
                    }
141
            } catch(Exception ex) {
142
                    logger.warn("Can't execute autorun in home.",ex);
143
            }
144
145 415 jldominguez
            /*
146
             *
147 414 jjdelcerro
            ProviderManager providerManager = InstallerProviderLocator.getProviderManager();
148
        providerManager.addProviderFactory(new ScriptingInstallerProviderFactory());
149 415 jldominguez
        */
150 191 jbadia
        }
151 253 jjdelcerro
152 191 jbadia
        public boolean isEnabled() {
153
                return true;
154
        }
155
156
        public boolean isVisible() {
157
                return true;
158
        }
159
160
}