Java-Gaming.org
Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
Featured games (78)
games approved by the League of Dukes
Games in Showcase (407)
games submitted by our members
Games in WIP (293)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  SimUserDataListener.userJoinedChannel() not always called?  (Read 810 times)
0 Members and 1 Guest are viewing this topic.
Offline kingfai

Junior Newbie




Java games rock!


« Posted 2006-05-08 20:18:18 »

I've noticed that sometimes on the server, SimUserDataListener.userJoinedChannel() is not called eventhough, on the client, UserManagerClientListener.joinedChannel() is called. If a second client connects, userJoinedChannel() is called correctly. Also if I sleep for a second before opening the channel, SimUserDataListener.userJoinedChannel() is properly called on the server.

Could this be happening because the transaction where SimTask.getCurrent().addUserDataListener() on the server has not finished yet when the client attempts to m_manager.openChannel()? Is this to be expected or am I doing something weird?

Here's a snippet from my client:

1  
2  
3  
4  
5  
6  
7  
8  
9  
10  
11  
12  
13  
14  
15  
16  
17  
18  
19  
20  
21  
22  
   
public class Main implements ClientConnectionManagerListener, ClientChannelListener
{
...
        public void connected(byte[] values)
   {
      log("connected():"+ StringUtils.bytesToHex(values));
     
      try
      {
         Thread.sleep(1000);
      }
      catch(InterruptedException ignore)
      {
         
      }
      m_manager.openChannel(GAME_CHANNEL);
   }

...

}


And here's a snippet from my server class:

1  
2  
3  
4  
5  
6  
7  
8  
9  
10  
11  
12  
13  
14  
15  
16  
17  
18  
19  
20  
21  
22  
23  
24  
25  
26  
27  
28  
29  
30  
31  
32  
33  
34  
35  
36  
37  
38  
39  
40  
41  
public class RockPaperScissorsBoot implements SimBoot<RockPaperScissorsBoot>,
      SimUserDataListener, SimUserListener
{
...
   public void boot(com.sun.gi.logic.GLOReference<? extends RockPaperScissorsBoot> gLOReference,
         boolean firstBoot)
   {
      SimTask task = SimTask.getCurrent();
     
      log("RockPaperScissorsBoot.boot(), appid="+task.getAppID());
      m_thisObj = gLOReference;
      m_gameChannel = task.openChannel(GAME_CHANNEL);
     
      task.addUserListener(m_thisObj);
   }
...

   public void userJoined(com.sun.gi.comm.routing.UserID userID, javax.security.auth.Subject subject)
   {
      String loginName;
      Set<Principal> principals = subject.getPrincipals();
     
      // first principal always contains the login name
     Principal principal = principals.iterator().next();
      loginName = principal.getName();
      log("User joined server: "+userID+" login:"+loginName);
     
      m_users.add(userID);
      m_loginNameMap.put(userID, loginName);
      SimTask.getCurrent().addUserDataListener(userID, m_thisObj);
   }

   public void userJoinedChannel(com.sun.gi.comm.routing.ChannelID channelID, com.sun.gi.comm.routing.UserID userID)
   {
      log("userJoinedChannel(): channel="+channelID.toString()+" userID:"+userID.toString());
                ...
        }

...

}


I think this is what is happening:

              Client                                                  Server
                    |                                                         |
                connect()------------------------------------> userJoined()
                                                                     transaction started??
                                                                     addUserDataListener() // register channel listener
                connected() <----------------------------     notify client of connection // not clear when this event happens but it seems to be here
                openChannel() --------------------------->  oops, but transaction has not been commited yet(?), so there is no channel listener
                                                                     transaction ends(?), now channel listener has really been registered

Offline Jeff

JGO Coder




Got any cats?


« Reply #1 - Posted 2006-05-08 23:57:29 »

Yes its quite possible that thre is a synchronization issue there.  There is a known problem (which I believe is fixed next release) where the client gets the "connected" message before the server has finished processing the connection.

In the mean time, see if putting a small sleep in your connected() callback solves the problem.


Got a question about Java and game programming?  Just new to the Java Game Development Community?  Try my FAQ.  Its likely you'll learn something!

http://wiki.java.net/bin/view/Games/JeffFAQ
Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

Play Revenge of the Titans! The situation is critical. We need fancy commanders to defend Earth, the moon, Mars!
 
Try the Free Demo of Revenge of the Titans

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

The invasion has landed! On Mars! And you're there to beat 'em!
cubemaster21 (91 views)
2013-05-17 21:29:12

alaslipknot (100 views)
2013-05-16 21:24:48

gouessej (130 views)
2013-05-16 00:53:38

gouessej (125 views)
2013-05-16 00:17:58

theagentd (136 views)
2013-05-15 15:01:13

theagentd (123 views)
2013-05-15 15:00:54

StreetDoggy (165 views)
2013-05-14 15:56:26

kutucuk (187 views)
2013-05-12 17:10:36

kutucuk (190 views)
2013-05-12 15:36:09

UnluckyDevil (196 views)
2013-05-12 05:09:57
Complex number cookbook
by Roquen
2013-04-24 12:47:31

2D Dynamic Lighting
by Oskuro
2013-04-17 16:46:12

2D Dynamic Lighting
by Oskuro
2013-04-17 16:45:57

2D Dynamic Lighting
by Oskuro
2013-04-17 16:23:20

Noise (bandpassed white)
by Roquen
2013-04-05 17:36:01

Noise (bandpassed white)
by Roquen
2013-04-03 16:17:38

Java Data structures
by Roquen
2013-03-29 13:21:12

Topic Request
by kutucuk
2013-03-22 21:42:01
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!
Page created in 0.073 seconds with 20 queries.