Statistics
| Revision:

root / sqs-reader / src / main / java / net / sqs2 / omr / session / broker / impl / PageTaskExecutorSessionServerDispatcher.java @ 1841

History | View | Annotate | Download (3.4 KB)

1
/**
2
 *  TaskExecutorEnv.java
3
4
 Copyright 2007 KUBO Hiroya (hiroya@cuc.ac.jp).
5
6
 Licensed under the Apache License, Version 2.0 (the "License");
7
 you may not use this file except in compliance with the License.
8
 You may obtain a copy of the License at
9
10
 http://www.apache.org/licenses/LICENSE-2.0
11
12
 Unless required by applicable law or agreed to in writing, software
13
 distributed under the License is distributed on an "AS IS" BASIS,
14
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
 See the License for the specific language governing permissions and
16
 limitations under the License.
17
18
 Created on 2007/01/31
19
 Author hiroya
20
 */
21
22
package net.sqs2.omr.session.broker.impl;
23
24
import java.rmi.RemoteException;
25
import java.util.HashMap;
26
import java.util.Map;
27
28
import net.sqs2.omr.master.PageMaster;
29
import net.sqs2.omr.model.AbstractPageTask;
30
import net.sqs2.omr.session.broker.SessionSourceServerDispatcher;
31
import net.sqs2.omr.session.config.SourceDirectoryConfiguration;
32
import net.sqs2.omr.session.source.RemoteSessionSourceServer;
33
import net.sqs2.omr.session.source.SessionSourceServer;
34
import net.sqs2.omr.util.FileContents;
35
import net.sqs2.util.FileResourceID;
36
37
import org.apache.commons.collections15.map.LRUMap;
38
39
public class PageTaskExecutorSessionServerDispatcher extends SessionSourceServerDispatcher{
40
41
        public static final int IMAGE_BYTEARRAY_CACHE_SIZE = 3; // size
42
        private Map<FileResourceID, PageMaster> pageMasterCache = new LRUMap<FileResourceID, PageMaster>();
43
        private Map<FileResourceID, SourceDirectoryConfiguration> configHandlerCache = new HashMap<FileResourceID, SourceDirectoryConfiguration>();
44
        private Map<FileResourceID, FileContents> fileResourceCache = new LRUMap<FileResourceID, FileContents>(32);
45
46
        public PageTaskExecutorSessionServerDispatcher(SessionSourceServer localSessionService, RemoteSessionSourceServer remoteSessionService,
47
                        long key){
48
                super(localSessionService, remoteSessionService, key);
49
        }
50
        
51
        public byte[] getImageByteArray(long sessionID, FileResourceID fileResourceID) throws RemoteException {
52
                synchronized (this.fileResourceCache) {
53
                        FileContents fileResource = this.fileResourceCache.get(fileResourceID);
54
                        if (fileResource == null) {
55
                                fileResource = getSessionSourceServer().getFileContentBytes(getKey(), sessionID, fileResourceID);
56
                                this.fileResourceCache.put(fileResourceID, fileResource);
57
                        }
58
                        return fileResource.getBytes();
59
                }
60
        }
61
62
        public PageMaster getPageMaster(long sessionID, AbstractPageTask pageTask) throws RemoteException {
63
                return getPageMaster(sessionID, pageTask.getMasterFileResourceID());
64
        }
65
66
        public PageMaster getPageMaster(long sessionID, FileResourceID fileResourceID) throws RemoteException {
67
                synchronized (this.pageMasterCache) {
68
                        PageMaster master = this.pageMasterCache.get(fileResourceID);
69
                        if (master == null) {
70
                                master = getSessionSourceServer().getMaster(getKey(), sessionID, fileResourceID);
71
                                this.pageMasterCache.put(fileResourceID, master);
72
                        }
73
                        return master;
74
                }
75
        }
76
77
        public SourceDirectoryConfiguration getConfiguration(long sessionID, FileResourceID fileResourceID) throws RemoteException {
78
                synchronized (this.configHandlerCache) {
79
                        SourceDirectoryConfiguration configHandler = this.configHandlerCache.get(fileResourceID);
80
                        if (configHandler == null) {
81
                                configHandler = getSessionSourceServer().getConfigration(getKey(), sessionID, fileResourceID);
82
                                this.configHandlerCache.put(fileResourceID, configHandler);
83
                        }
84
                        return configHandler;
85
                }
86
        }
87
88
}