--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/accessoryservices/remotecontrolfw/server/src/main.cpp Tue Feb 02 00:53:00 2010 +0200
@@ -0,0 +1,91 @@
+// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// Entry point for Rem Con server.
+//
+//
+
+/**
+ @file
+ @internalComponent
+*/
+
+#include <bluetooth/logger.h>
+#include <e32base.h>
+#include "remconserver.h"
+#include "server.h"
+
+#ifdef __FLOG_ACTIVE
+_LIT8(KLogComponent, LOG_COMPONENT_REMCON_SERVER);
+#endif
+
+static void RunServerL();
+
+/**
+Entry point for the Remote Control server.
+@return Error.
+*/
+GLDEF_C TInt E32Main()
+ {
+ CONNECT_LOGGER;
+ LOG_STATIC_FUNC;
+ TInt ret = KErrNoMemory;
+
+ __UHEAP_MARK;
+
+ CTrapCleanup* cleanup = CTrapCleanup::New();
+
+ if ( cleanup )
+ {
+ TRAP(ret, RunServerL());
+
+ delete cleanup;
+ }
+
+ __UHEAP_MARKEND;
+
+ LOG1(_L8("\tret = %d"), ret);
+ CLOSE_LOGGER;
+ return ret;
+ }
+
+/**
+Create the active scheduler and Rem Con server instances, and start the
+server.
+*/
+static void RunServerL()
+ {
+ LOG_STATIC_FUNC;
+ LEAVEIFERRORL(User::RenameThread(KRemConServerName));
+
+ CONNECT_LOGGER
+
+ // Create and install the active scheduler.
+ CActiveScheduler* scheduler = new(ELeave) CActiveScheduler;
+ CleanupStack::PushL(scheduler);
+ CActiveScheduler::Install(scheduler);
+
+ // Create the server. NB Odd syntax in this line because we never refer to
+ // it directly- it's always owned by the cleanup stack!
+ (void)CRemConServer::NewLC();
+
+ // Initialisation complete, now signal the client
+ RProcess::Rendezvous(KErrNone);
+
+ // Ready to run. This only returns when the server is closing down.
+ CActiveScheduler::Start();
+
+ // Clean up the server and scheduler.
+ CleanupStack::PopAndDestroy(2, scheduler);
+ CLOSE_LOGGER
+ }