blob: fa0c4a3831bc6e309928b12b05df41d2d2185047 [file] [log] [blame]
// Copyright 2007 The Apache Software Foundation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package org.apache.tapestry5.ioc.internal;
import org.apache.tapestry5.ioc.def.ServiceDef;
import org.apache.tapestry5.ioc.services.ServiceActivity;
import org.apache.tapestry5.ioc.services.ServiceActivityScoreboard;
import org.apache.tapestry5.ioc.services.Status;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import org.apache.tapestry5.commons.util.CollectionFactory;
import org.apache.tapestry5.ioc.ScopeConstants;
import org.apache.tapestry5.ioc.services.PerThreadValue;
import org.apache.tapestry5.ioc.services.PerthreadManager;
public class ServiceActivityTrackerImpl implements ServiceActivityScoreboard,
ServiceActivityTracker
{
public static class MutableServiceActivity implements ServiceActivity
{
private final ServiceDef serviceDef;
private Status status;
private final PerThreadValue<Status> perThreadStatus;
public MutableServiceActivity(ServiceDef serviceDef, PerthreadManager perthreadManager, Status status)
{
this.serviceDef = serviceDef;
if (serviceDef.getServiceScope().equals(ScopeConstants.PERTHREAD)) {
perThreadStatus = perthreadManager.createValue();
perThreadStatus.set(status);
this.status = status; // this is now the default status
} else {
perThreadStatus = null;
this.status = status;
}
}
@Override
public String getServiceId()
{
return serviceDef.getServiceId();
}
@Override
public Class getServiceInterface()
{
return serviceDef.getServiceInterface();
}
@Override
public String getScope()
{
return serviceDef.getServiceScope();
}
@Override
public Set<Class> getMarkers()
{
return serviceDef.getMarkers();
}
// Mutable properties must be synchronized
@Override
public synchronized Status getStatus()
{
if (perThreadStatus != null) {
if (!perThreadStatus.exists()) perThreadStatus.set(status);
return perThreadStatus.get();
}
else return status;
}
synchronized void setStatus(Status status)
{
if (perThreadStatus != null) perThreadStatus.set(status);
else this.status = status;
}
}
private final PerthreadManager perthreadManager;
public ServiceActivityTrackerImpl(PerthreadManager perthreadManager) {
this.perthreadManager = perthreadManager;
}
/**
* Tree map keeps everything in order by key (serviceId).
*/
private final Map<String, MutableServiceActivity> serviceIdToServiceStatus = new TreeMap<String, MutableServiceActivity>();
@Override
public synchronized List<ServiceActivity> getServiceActivity()
{
// Need to wrap the values in a new list because
// a) we don't want people arbitrarily changing the internal state of
// _serviceIdtoServiceStatus
// b) values() is Collection and we want to return List
// Note: ugly code here to keep Sun compiler happy.
List<ServiceActivity> result = CollectionFactory.newList();
result.addAll(serviceIdToServiceStatus.values());
return result;
}
void startup()
{
// Does nothing, first pass does not use a worker thread
}
void shutdown()
{
// Does nothing, first pass does not use a worker thread
}
@Override
public synchronized void define(ServiceDef serviceDef, Status initialStatus)
{
serviceIdToServiceStatus.put(serviceDef.getServiceId(), new MutableServiceActivity(
serviceDef, perthreadManager, initialStatus));
}
@Override
public synchronized void setStatus(String serviceId, Status status)
{
serviceIdToServiceStatus.get(serviceId).setStatus(status);
}
}