source: java/main/src/main/java/com/framsticks/core/LocalInstance.java @ 85

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

HIGHLIGHTS:

  • upgrade to Java 7
    • use try-multi-catch clauses
    • use try-with-resources were appropriate
  • configure FindBugs? (use mvn site and then navigate in browser to the report)
    • remove most bugs found
  • parametrize Dispatching environment (Dispatcher, RunAt?) to enforce more control on the place of closures actual call

CHANGELOG:
Rework FavouritesXMLFactory.

FindBugs?. Thread start.

FindBugs?. Minor change.

FindBugs?. Iterate over entrySet.

FindBugs?. Various.

FindBug?.

FindBug?. Encoding.

FindBug?. Final fields.

FindBug?.

Remove synchronization bug in ClientConnection?.

Experiments with findbugs.

Finish parametrization.

Make RunAt? an abstract class.

More changes in parametrization.

More changes in parametrizing dispatching.

Several changes to parametrize tasks.

Rename Runnable to RunAt?.

Add specific framsticks Runnable.

Add JSR305 (annotations).

Add findbugs reporting.

More improvements to ParamBuilder? wording.

Make FramsClass? accept also ParamBuilder?.

Change wording of ParamBuilder?.

Change wording of Request creation.

Use Java 7 exception catch syntax.

Add ScopeEnd? class.

Upgrade to Java 7.

File size: 2.3 KB
Line 
1package com.framsticks.core;
2
3import com.framsticks.hosting.InstanceClient;
4import com.framsticks.util.dispatching.Thread;
5
6import org.apache.commons.configuration.Configuration;
7import org.apache.log4j.Logger;
8
9import java.io.IOException;
10import java.net.InetSocketAddress;
11import java.net.ServerSocket;
12import java.net.Socket;
13import java.util.HashSet;
14import java.util.Set;
15import com.framsticks.util.dispatching.RunAt;
16
17
18/**
19 * @author Piotr Sniegowski
20 */
21public abstract class LocalInstance extends Instance {
22
23        private static final Logger log = Logger.getLogger(LocalInstance.class.getName());
24
25        public LocalInstance() {
26
27        }
28
29        @Override
30        public void configure(Configuration config) {
31                Integer accept = config.getInteger("accept", null);
32                if (accept != null) {
33                        try {
34                                acceptSocket = new ServerSocket();
35                                acceptSocket.setReuseAddress(true);
36                                acceptThread = new Thread<Accept>(name + "-accept").start();
37                                tryBind(accept);
38                        } catch (IOException e) {
39                                log.fatal("failed to create accept socket: " + e);
40                        }
41                }
42        }
43
44        protected final Set<InstanceClient> clients = new HashSet<InstanceClient>();
45        ServerSocket acceptSocket;
46
47        public static class Accept {
48        };
49
50        Thread<Accept> acceptThread;
51
52        protected void acceptNext() {
53                acceptThread.invokeLater(new RunAt<Accept>() {
54                        @Override
55                        public void run() {
56                                try {
57                                        final Socket socket = acceptSocket.accept();
58                                        assert socket != null;
59                                        log.debug("accepted socket: " + socket.getInetAddress().getHostAddress());
60                                        invokeLater(new RunAt<LocalInstance>() {
61                                                @Override
62                                                public void run() {
63                                                        InstanceClient client = new InstanceClient(LocalInstance.this, socket);
64                                                        clients.add(client);
65                                                        log.info("client connected: " + client);
66                                                }
67                                        });
68                                } catch (IOException e) {
69                                        log.error("failed to accept socket: " + e);
70                                }
71                                acceptNext();
72                        }
73                });
74        }
75
76        public void tryBind(final Integer accept) {
77                acceptThread.invokeLater(new RunAt<Accept>() {
78                        @Override
79                        public void run() {
80                                try {
81                                        acceptSocket.bind(new InetSocketAddress(accept));
82                                        log.debug("started accepting on port " + accept);
83                                        acceptNext();
84                                } catch (IOException e) {
85                                        log.fatal("failed to accept on port " + accept + ": " + e);
86                                }
87                                try {
88                                        java.lang.Thread.sleep(1000);
89                                } catch (InterruptedException ignored) {
90                                }
91                                tryBind(accept);
92                        }
93                });
94        }
95
96}
Note: See TracBrowser for help on using the repository browser.