source: java/main/src/main/java/com/framsticks/experiment/NetLoadSaveLogic.java @ 102

Last change on this file since 102 was 102, checked in by psniegowski, 11 years ago

HIGHLIGHTS:

for Joinables running

CHANGELOG:
Add WorkPackageLogic? and classes representing prime experiment state.

Add classes for PrimeExperiment? state.

Extract single netload routine in Simulator.

Working netload with dummy content in PrimeExperiment?.

More development with NetLoadSaveLogic? and PrimeExperiment?.

Improvement around prime.

Improve BufferedDispatcher?.isActive logic.

Add prime-all.xml configuration.

Manual connecting to existing simulators from GUI.

Guard in SimulatorConnector? against expdef mismatch.

Guard against empty target dispatcher in BufferedDispatcher?.

Make BufferedDispatcher? a Dispatcher (and Joinable).

Minor improvements.

Done StackedJoinable?, improve Experiment.

Develop StackedJoinable?.

Add StackedJoinable? utility joinables controller.

Add dependency on apache-commons-lang.

Add ready ListChange? on Simulators.

Improve hints in ListChange?.

Several improvements.

Found bug with dispatching in Experiment.

Minor improvements.

Fix bug with early finishing Server.

Many changes in Dispatching.

Fix bug with connection.

Do not obfuscate log with socket related exceptions.

Add SocketClosedException?.

Add SimulatorConnector?.

Work out conception of experiment composing of logics building blocks.

Rename SinkInterface? to Sink.

Move saving of Accesses into AccessOperations?.

Some improvements to Experiment.

Improve joinables.

Fix issue with joinables closing.

Add direct and managed consoles to popup menu.

File size: 1.8 KB
Line 
1package com.framsticks.experiment;
2
3
4import org.apache.logging.log4j.Logger;
5import org.apache.logging.log4j.LogManager;
6
7import com.framsticks.communication.File;
8import com.framsticks.core.ListChange;
9import com.framsticks.params.EventListener;
10import com.framsticks.params.annotations.FramsClassAnnotation;
11import com.framsticks.params.annotations.ParamAnnotation;
12import com.framsticks.util.dispatching.Future;
13import com.framsticks.util.dispatching.FutureHandler;
14
15@FramsClassAnnotation
16public abstract class NetLoadSaveLogic extends AbstractExperimentLogic {
17        private static final Logger log = LogManager.getLogger(NetLoadSaveLogic.class);
18
19
20        protected String option = "an option";
21
22        /**
23         * @param experiment
24         */
25        public NetLoadSaveLogic(Experiment parentExperiment) {
26                super(parentExperiment);
27
28                experiment.addSimulatorsListener(new EventListener<ListChange>() {
29
30                        @Override
31                        public void action(ListChange argument) {
32                                assert experiment.isActive();
33
34                                if (argument.hasHint("ready")) {
35                                        final Simulator simulator = experiment.getSimulators().get(argument.getIdentifier());
36                                        log.debug("simulator is ready: {}", simulator);
37
38                                        netload(simulator, new FutureHandler<File>(simulator) {
39
40                                                @Override
41                                                protected void result(final File file) {
42                                                        simulator.uploadNet(file, new FutureHandler<Object>(this) {
43
44                                                                @Override
45                                                                protected void result(Object result) {
46                                                                        log.debug("netload of {} done", file);
47                                                                }
48                                                        });
49                                                }
50                                        });
51                                }
52                        }
53                });
54        }
55
56        public abstract void netload(Simulator simulator, Future<File> net);
57
58        public abstract void netsave(Simulator simulator, File net);
59
60        /**
61         * @return the option
62         */
63        @ParamAnnotation
64        public String getOption() {
65                return option;
66        }
67
68        /**
69         * @param option the option to set
70         */
71        @ParamAnnotation
72        public void setOption(String option) {
73                this.option = option;
74        }
75
76}
Note: See TracBrowser for help on using the repository browser.