
com.threerings.crowd.data.PlaceObject Maven / Gradle / Ivy
//
// $Id$
//
// Narya library - tools for developing networked games
// Copyright (C) 2002-2012 Three Rings Design, Inc., All Rights Reserved
// http://code.google.com/p/narya/
//
// This library is free software; you can redistribute it and/or modify it
// under the terms of the GNU Lesser General Public License as published
// by the Free Software Foundation; either version 2.1 of the License, or
// (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
package com.threerings.crowd.data;
import javax.annotation.Generated;
import com.threerings.util.Name;
import com.threerings.presents.dobj.DObject;
import com.threerings.presents.dobj.DObjectManager;
import com.threerings.presents.dobj.DSet;
import com.threerings.presents.dobj.OidList;
import com.threerings.presents.dobj.ServerMessageEvent;
import com.threerings.crowd.chat.data.SpeakMarshaller;
import com.threerings.crowd.chat.data.SpeakObject;
import static com.threerings.crowd.Log.log;
/**
* A distributed object that contains information on a place that is occupied by bodies. This place
* might be a chat room, a game room, an island in a massively multiplayer piratical universe,
* anything that has occupants that might want to chat with one another.
*/
public class PlaceObject extends DObject
implements SpeakObject
{
// AUTO-GENERATED: FIELDS START
/** The field name of the occupants
field. */
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public static final String OCCUPANTS = "occupants";
/** The field name of the occupantInfo
field. */
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public static final String OCCUPANT_INFO = "occupantInfo";
/** The field name of the speakService
field. */
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public static final String SPEAK_SERVICE = "speakService";
// AUTO-GENERATED: FIELDS END
/**
* Exists to make calls into the manager look sensible:
*
* _plobj.manager.invoke("someMethod", args);
*
* and to route events through the right distributed object manager if we are running in
* standalone/single-player mode where both client and server are running in the same VM.
*
* Note: For this to work, your manager needs to override
* PlaceManager.allowManagerCall()
and return true for the desired method name.
* But maybe you should consider using an InvocationService instead.
*/
public class ManagerCaller
{
/**
* @deprecated this is pretty darn unsafe. Why don't you just set up a Service?
*/
@Deprecated
public void invoke (String method, Object ... args) {
_omgr.postEvent(new ServerMessageEvent(_oid, method, args));
}
protected ManagerCaller (DObjectManager omgr) {
_omgr = omgr;
}
protected DObjectManager _omgr;
}
/**
* Allows the client to call methods on the manager.
*/
public transient ManagerCaller manager;
/**
* Tracks the oid of the body objects of all of the occupants of this place.
*/
public OidList occupants = new OidList();
/**
* Contains an info record (of type {@link OccupantInfo}) for each occupant that contains
* information about that occupant that needs to be known by everyone in the place.
* Note: Don't obtain occupant info records directly from this set when on the server,
* use PlaceManager.getOccupantInfo()
instead (along with
* PlaceManager.updateOccupantInfo()
) because it does some special processing to
* ensure that readers and updaters don't step on one another even if they make rapid fire
* changes to a user's occupant info.
*/
public DSet occupantInfo = new DSet();
/** Used to generate speak requests on this place object. */
public SpeakMarshaller speakService;
/**
* Called on the client when the location director receives this place object to configure our
* manager caller using the client's distributed object manager.
*/
public void initManagerCaller (DObjectManager omgr)
{
manager = new ManagerCaller(omgr);
}
/**
* Used to indicate whether broadcast chat messages should be dispatched on this place object.
*/
public boolean shouldBroadcast ()
{
return true;
}
/**
* Looks up a user's occupant info by name.
*
* @return the occupant info record for the named user or null if no user in the room has that
* username.
*/
public OccupantInfo getOccupantInfo (Name username)
{
try {
for (OccupantInfo info : occupantInfo) {
if (info.username.equals(username)) {
return info;
}
}
} catch (Throwable t) {
log.warning("PlaceObject.getOccupantInfo choked.", t);
}
return null;
}
// documentation inherited
public void applyToListeners (ListenerOp op)
{
for (int ii = 0, ll = occupants.size(); ii < ll; ii++) {
op.apply(occupants.get(ii));
}
}
// AUTO-GENERATED: METHODS START
/**
* Requests that oid
be added to the occupants
* oid list. The list will not change until the event is actually
* propagated through the system.
*/
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public void addToOccupants (int oid)
{
requestOidAdd(OCCUPANTS, occupants, oid);
}
/**
* Requests that oid
be removed from the
* occupants
oid list. The list will not change until the
* event is actually propagated through the system.
*/
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public void removeFromOccupants (int oid)
{
requestOidRemove(OCCUPANTS, occupants, oid);
}
/**
* Requests that the specified entry be added to the
* occupantInfo
set. The set will not change until the event is
* actually propagated through the system.
*/
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public void addToOccupantInfo (OccupantInfo elem)
{
requestEntryAdd(OCCUPANT_INFO, occupantInfo, elem);
}
/**
* Requests that the entry matching the supplied key be removed from
* the occupantInfo
set. The set will not change until the
* event is actually propagated through the system.
*/
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public void removeFromOccupantInfo (Comparable> key)
{
requestEntryRemove(OCCUPANT_INFO, occupantInfo, key);
}
/**
* Requests that the specified entry be updated in the
* occupantInfo
set. The set will not change until the event is
* actually propagated through the system.
*/
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public void updateOccupantInfo (OccupantInfo elem)
{
requestEntryUpdate(OCCUPANT_INFO, occupantInfo, elem);
}
/**
* Requests that the occupantInfo
field be set to the
* specified value. Generally one only adds, updates and removes
* entries of a distributed set, but certain situations call for a
* complete replacement of the set value. The local value will be
* updated immediately and an event will be propagated through the
* system to notify all listeners that the attribute did
* change. Proxied copies of this object (on clients) will apply the
* value change when they received the attribute changed notification.
*/
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public void setOccupantInfo (DSet value)
{
requestAttributeChange(OCCUPANT_INFO, value, this.occupantInfo);
DSet clone = (value == null) ? null : value.clone();
this.occupantInfo = clone;
}
/**
* Requests that the speakService
field be set to the
* specified value. The local value will be updated immediately and an
* event will be propagated through the system to notify all listeners
* that the attribute did change. Proxied copies of this object (on
* clients) will apply the value change when they received the
* attribute changed notification.
*/
@Generated(value={"com.threerings.presents.tools.GenDObjectTask"})
public void setSpeakService (SpeakMarshaller value)
{
SpeakMarshaller ovalue = this.speakService;
requestAttributeChange(
SPEAK_SERVICE, value, ovalue);
this.speakService = value;
}
// AUTO-GENERATED: METHODS END
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy