javamanager/javalauncher/tsrc/testmidletstart/src.s60/main.cpp
branchRCL_3
changeset 19 04becd199f91
child 25 9ac0a0a7da70
equal deleted inserted replaced
16:f5050f1da672 19:04becd199f91
       
     1 /*
       
     2 * Copyright (c) 2008 - 2009 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description: prototyping starting midlet from native applications
       
    15 */
       
    16 
       
    17 
       
    18 #include <e32std.h>
       
    19 #include <e32base.h>
       
    20 #include <f32file.h>
       
    21 #include <apgcli.h> // for RApaLsSession
       
    22 #include <e32property.h>
       
    23 #include <swinstallerinternalpskeys.h>
       
    24 #include <apacmdln.h> //CApaCommandLine
       
    25 #include <s32mem.h>   // RDesWriteStream
       
    26 #include <stdio.h>
       
    27 #include <s60commonutils.h>
       
    28 
       
    29 #include "javauids.h"
       
    30 #include "logger.h"
       
    31 
       
    32 _LIT(KJavaLauncherExe, "javalauncher.exe");
       
    33 
       
    34 /**
       
    35  *
       
    36  */
       
    37 static void startByJavaLauncherSimpleL()
       
    38 {
       
    39     LOG(EJavaConverters, EInfo,
       
    40         "testmidletstart: startByJavaLauncherSimple: Going to start midlet from 'testmidletstart.txt'");
       
    41 
       
    42     // Read the content of test data file
       
    43     RFs fs;
       
    44     TInt err = fs.Connect();
       
    45     if (KErrNone != err)
       
    46     {
       
    47         ELOG1(EJavaConverters,
       
    48               "testmidletstart: startByJavaLauncherSimple: Cannot connect to RFs, err %d", err);
       
    49         User::Leave(err);
       
    50     }
       
    51     CleanupClosePushL(fs);
       
    52     RFile testData;
       
    53     err = testData.Open(fs, _L("E:\\testmidletstart.txt"), EFileRead);
       
    54     if (KErrNotFound == err)
       
    55     {
       
    56         err = testData.Open(fs, _L("C:\\testmidletstart.txt"), EFileRead);
       
    57     }
       
    58     if (KErrNone != err)
       
    59     {
       
    60         ELOG1(EJavaConverters,
       
    61               "testmidletstart: startByJavaLauncherSimple: Cannot open E: "
       
    62               "or C:\\testmidletstart.txt, err %d", err);
       
    63         User::Leave(err);
       
    64     }
       
    65     CleanupClosePushL(testData);
       
    66     TInt testDataSize = 0;
       
    67     err = testData.Size(testDataSize);
       
    68     if (KErrNone != err)
       
    69     {
       
    70         ELOG1(EJavaConverters,
       
    71               "testmidletstart: startByJavaLauncherSimple: Cannot get size of "
       
    72               "testmidletstart.txt, err %d", err);
       
    73         User::Leave(err);
       
    74     }
       
    75 
       
    76     HBufC8 *pBuf = HBufC8::NewLC(testDataSize + 8);
       
    77     TPtr8 buf = pBuf->Des();
       
    78     err = testData.Read(buf);
       
    79     if (KErrNone != err)
       
    80     {
       
    81         ELOG1(EJavaConverters,
       
    82               "testmidletstart: startByJavaLauncherSimple: Reading "
       
    83               "testmidletstart.txt failed, err %d", err);
       
    84         User::Leave(err);
       
    85     }
       
    86 
       
    87     printf("File content was %s", (const char *)(buf.PtrZ()));
       
    88 
       
    89 
       
    90     TInt pos = 0;
       
    91     // Find LF
       
    92     TInt end = buf.Locate(0x0A);
       
    93     if (KErrNotFound == end)
       
    94     {
       
    95         end = buf.Length();
       
    96     }
       
    97     else if (buf.Locate(0x0D) == (end - 1))
       
    98     {
       
    99         // If there is CR before LF, it does not belong to cmd line
       
   100         --end;
       
   101     }
       
   102 
       
   103     // Read one line from buffer, convert it to 16 bit
       
   104     TPtrC8 oneLine = buf.Mid(pos, end - pos);
       
   105 
       
   106     TDesC *pCmdLine = NULL;
       
   107     TInt res = java::util::S60CommonUtils::ConvertNarrowToWiderL(oneLine, pCmdLine);
       
   108 
       
   109     // Create one process using this command line
       
   110     RProcess rProcess;
       
   111     // start
       
   112 //    TInt err = rProcess.Create(KJavaLauncherExe, _L("midlet-uid=0x1014e720;midlet-args=startMode=startFromCmdLine;sound=ON;landscapeMode=true;"));  // OK
       
   113 //    TInt err = rProcess.Create(KJavaLauncherExe, _L("midlet-name=%E6%98%9F%E5%A4%A2%E7%BE%8E%E5%B0%91%E5%A5%B3%E7%A0%8C%E5%9C%96"));
       
   114 //    TInt err = rProcess.Create(KJavaLauncherExe, _L("midlet-name=%C3%80%C3%80NEST%C3%80.EXE"));
       
   115 //    err = rProcess.Create(KJavaLauncherExe, _L("midlet-name=SPtesti;midlet-args=mode=nativestart;sounds=ON;difficulty=medium;wizard_mode"));
       
   116 
       
   117     err = rProcess.Create(KJavaLauncherExe, *pCmdLine);
       
   118     if (KErrNone == err)
       
   119     {
       
   120         LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherSimple calling Rendezvous");
       
   121         // This call will wait until midlet exits (or panics)
       
   122         TRequestStatus status;
       
   123         rProcess.Logon(status);
       
   124 
       
   125         LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherSimple calling Resume");
       
   126         rProcess.Resume();
       
   127 
       
   128         // now wait until javalauncher exits
       
   129         User::WaitForRequest(status);
       
   130         if (status.Int() != KErrNone)
       
   131         {
       
   132             ELOG1(EJavaConverters,
       
   133                   "testmidletstart: startByJavaLauncherSimple javalauncher exited with error %d",
       
   134                   status.Int());
       
   135         }
       
   136     }
       
   137     else
       
   138     {
       
   139         ELOG1(EJavaConverters,
       
   140               "testmidletstart: startByJavaLauncherSimple Cannot start midlet, error %d", err);
       
   141     }
       
   142 
       
   143     LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherSimple calling RProcess::Close");
       
   144 
       
   145     delete pCmdLine;
       
   146     rProcess.Close();
       
   147 
       
   148     // free resources before returning
       
   149     CleanupStack::PopAndDestroy(3);
       
   150 }
       
   151 
       
   152 
       
   153 /**
       
   154  *
       
   155  */
       
   156 static void startByAppArcL()
       
   157 {
       
   158     RApaLsSession apaSession;
       
   159 
       
   160     TInt err = apaSession.Connect();
       
   161     if (KErrNone != err)
       
   162     {
       
   163         ELOG1(EJavaConverters,
       
   164               "testmidletstart::startByAppArcL RApaLsSession Connect error %d", err);
       
   165         User::Leave(err);
       
   166     }
       
   167     CleanupClosePushL(apaSession);
       
   168 
       
   169     CApaCommandLine* cmdLine = CApaCommandLine::NewLC();
       
   170 
       
   171     // Drive letter must be correct
       
   172     cmdLine->SetExecutableNameL(_L("C:\\269712461.fakeapp"));
       
   173     cmdLine->SetCommandL(EApaCommandRun);
       
   174     cmdLine->SetTailEndL(_L8(" midletparam1 -param2 -param3=no"));
       
   175 
       
   176     LOG(EJavaConverters, EInfo, "testmidletstart: startByAppArcL: Going to start midlet SystemProperties");
       
   177 
       
   178     err = apaSession.StartApp(*cmdLine);
       
   179     if (KErrNone != err)
       
   180     {
       
   181         ELOG1(EJavaConverters,
       
   182               "testmidletstart::startByAppArcL StartApp error %d", err);
       
   183     }
       
   184 
       
   185     CleanupStack::PopAndDestroy(cmdLine);
       
   186     CleanupStack::PopAndDestroy(); // apaSession
       
   187 }
       
   188 
       
   189 
       
   190 /**
       
   191  * Start javalauncher.exe that will start midlet
       
   192  */
       
   193 static void startByJavaLauncherL()
       
   194 {
       
   195     LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherL: Going to start midlet SystemProperties");
       
   196 
       
   197     RProcess rProcess;
       
   198     // Build command line used to pass all necessary info
       
   199     CApaCommandLine* cmdLine = CApaCommandLine::NewLC();
       
   200 
       
   201     cmdLine->SetExecutableNameL(KJavaLauncherExe);
       
   202     cmdLine->SetCommandL(EApaCommandRun);
       
   203 
       
   204     cmdLine->SetDocumentNameL(_L("C:/data/my_own_doc.kwi"));
       
   205 
       
   206     // The midlet to be started can be specified by using opaque data like here or
       
   207     // by specifying midlet name and vendor in command line
       
   208     TBuf8<4>         opaqueData;     // opaque data will contain one signed 32-bit int
       
   209     RDesWriteStream  writeStream(opaqueData);
       
   210     writeStream.WriteInt32L(0x10137c4d);   // midlet application Uid
       
   211     writeStream.CommitL();
       
   212     cmdLine->SetOpaqueDataL(opaqueData);
       
   213 
       
   214     LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherL: Create process");
       
   215 
       
   216     // start
       
   217     TInt err = rProcess.Create(KJavaLauncherExe, _L("midlet-uid=0x10137c4d;midlet-args=startMode=strangeStart"));
       
   218     if (KErrNone == err)
       
   219     {
       
   220         LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherL: Set process commandline");
       
   221 
       
   222         cmdLine->SetProcessEnvironmentL(rProcess);
       
   223 
       
   224         LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherL calling Logon");
       
   225         // This call will wait until javalauncher exits (or panics)
       
   226         TRequestStatus status;
       
   227         rProcess.Logon(status);
       
   228 
       
   229         LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherL calling Resume");
       
   230         rProcess.Resume();
       
   231 
       
   232         // now wait until javalauncher exits
       
   233         User::WaitForRequest(status);
       
   234         if (status.Int() != KErrNone)
       
   235         {
       
   236             ELOG1(EJavaConverters,
       
   237                   "testmidletstart: startByJavaLauncherL javalauncher exited with error %d",
       
   238                   status.Int());
       
   239         }
       
   240     }
       
   241     else
       
   242     {
       
   243         ELOG1(EJavaConverters,
       
   244               "testmidletstart: startByJavaLauncherL Cannot start midlet, error %d", err);
       
   245     }
       
   246 
       
   247     LOG(EJavaConverters, EInfo, "testmidletstart: startByJavaLauncherL calling RProcess::Close");
       
   248     // free resources before returning
       
   249     CleanupStack::PopAndDestroy(cmdLine);
       
   250     rProcess.Close();
       
   251 }
       
   252 
       
   253 
       
   254 /**
       
   255  * Read all midlets from AppArc.
       
   256  * Log midlet Uid, Midlet name, installation drive,
       
   257  * group name and icon file path name
       
   258  */
       
   259 static void readMidletsFromAppArcL()
       
   260 {
       
   261     TInt   retryCounter = 10;
       
   262     TUid   appTypeUid;
       
   263     TApaAppInfo   info;
       
   264     RApaLsSession apaSession;
       
   265 
       
   266     TBuf8<512> midletDesc;
       
   267 
       
   268 
       
   269     TInt err = apaSession.Connect();
       
   270     if (KErrNone != err)
       
   271     {
       
   272         ELOG1(EJavaConverters,
       
   273               "testmidletstart::readMidletsFromAppArcL RApaLsSession Connect error %d", err);
       
   274         User::Leave(err);
       
   275     }
       
   276     CleanupClosePushL(apaSession);
       
   277 
       
   278     // Get the process of getting the list of all non native applications
       
   279     // (mostly java applications)
       
   280     err =
       
   281         apaSession.GetFilteredApps(
       
   282             TApaAppCapability::ENonNative, TApaAppCapability::ENonNative);
       
   283 
       
   284     TFullName logBuf;
       
   285 
       
   286     do
       
   287     {
       
   288         err = apaSession.GetNextApp(info);
       
   289         if (RApaLsSession::EAppListInvalid == err)
       
   290         {
       
   291             // Application list has not yet been populated,
       
   292             // try again after a short delay
       
   293             retryCounter--;
       
   294             if (retryCounter > 0)
       
   295             {
       
   296                 User::After(500000);
       
   297                 continue;
       
   298             }
       
   299             else
       
   300             {
       
   301                 ELOG(EJavaConverters,
       
   302                      "testmidletstart::readMidletsFromAppArcL RApaLsSession "
       
   303                      "GetNext returned EAppListInvalid for 10 times, error");
       
   304                 User::Leave(err);
       
   305             }
       
   306         }
       
   307         else if (KErrNone == err)
       
   308         {
       
   309             // Info contains valid app info. Now check whether it is java app
       
   310             err = apaSession.GetAppType(appTypeUid, info.iUid);
       
   311             if (KErrNone != err)
       
   312             {
       
   313                 ELOG1(EJavaConverters,
       
   314                       "testmidletstart::readMidletsFromAppArcL RApaLsSession "
       
   315                       "GetAppType returned error %d", err);
       
   316                 User::Leave(err);
       
   317             }
       
   318             if (appTypeUid.iUid == KMidletApplicationTypeUid)
       
   319             {
       
   320                 // This is java application. Log info
       
   321                 LOG1(EJavaConverters, EInfo, "testmidletstart: readMidletsFromAppArcL: midlet uid %x", info.iUid);
       
   322 
       
   323                 logBuf = info.iCaption;
       
   324                 LOG1WSTR(EJavaConverters, EInfo, "testmidletstart: readMidletsFromAppArcL: midlet name %s",
       
   325                          (wchar_t *)(logBuf.PtrZ()));
       
   326 
       
   327                 logBuf = info.iFullName;
       
   328                 LOG1WSTR(EJavaConverters, EInfo, "testmidletstart: readMidletsFromAppArcL: midlet path %s",
       
   329                          (wchar_t *)(logBuf.PtrZ()));
       
   330 
       
   331             }
       
   332         }
       
   333 
       
   334     }
       
   335     while (KErrNone == err);
       
   336 
       
   337     if (RApaLsSession::ENoMoreAppsInList != err)
       
   338     {
       
   339         ELOG1(EJavaConverters,
       
   340               "testmidletstart:readMidletsFromAppArcL: RApaLsSession GetNext returned error %d", err);
       
   341         User::Leave(err);
       
   342     }
       
   343 
       
   344     CleanupStack::PopAndDestroy(); // apaSession
       
   345 }
       
   346 
       
   347 
       
   348 /**
       
   349  *
       
   350  */
       
   351 static void registerAsMimeHandlerL()
       
   352 {
       
   353     TInt   retryCounter = 10;
       
   354     TUid   appTypeUid;
       
   355     TApaAppInfo   info;
       
   356     RApaLsSession apaSession;
       
   357 
       
   358 
       
   359     TInt err = apaSession.Connect();
       
   360     if (KErrNone != err)
       
   361     {
       
   362         ELOG1(EJavaConverters,
       
   363               "testmidletstart::registerAsMimeHandlerL RApaLsSession Connect error %d", err);
       
   364         User::Leave(err);
       
   365     }
       
   366     CleanupClosePushL(apaSession);
       
   367 
       
   368     // Get current handler for file e:\tif.tif
       
   369     TUid      handlerUid;
       
   370     TDataType mimeType;
       
   371     err = apaSession.AppForDocument(_L("e:\\tif.tif"), handlerUid, mimeType);
       
   372     if (KErrNone != err)
       
   373     {
       
   374         ELOG1(EJavaConverters,
       
   375               "testmidletstart::registerAsMimeHandlerL AppForDocument error %d", err);
       
   376         User::Leave(err);
       
   377     }
       
   378 
       
   379     TBuf8<256> mimeTypeName;
       
   380     mimeTypeName = mimeType.Des8();
       
   381     mimeTypeName.Append('\0');
       
   382     LOG1(EJavaConverters, EInfo,
       
   383          "testmidletstart::registerAsMimeHandlerL file MIME type is %s", &(mimeTypeName[0]));
       
   384     LOG1(EJavaConverters, EInfo,
       
   385          "testmidletstart::registerAsMimeHandlerL handler for it is %x", handlerUid.iUid);
       
   386 
       
   387     TUid midletUid;
       
   388     midletUid.iUid = 0x10137c4d;
       
   389     TDataTypePriority priority(100);
       
   390     err = apaSession.InsertDataMapping(mimeType, priority, midletUid);
       
   391     if (KErrNone != err)
       
   392     {
       
   393         ELOG1(EJavaConverters,
       
   394               "testmidletstart::registerAsMimeHandlerL InsertDataMapping error %d", err);
       
   395         User::Leave(err);
       
   396     }
       
   397 
       
   398     TUid  newHandlerUid;
       
   399     err = apaSession.AppForDocument(_L("e:\\tif.tif"), newHandlerUid, mimeType);
       
   400     if (KErrNone != err)
       
   401     {
       
   402         ELOG1(EJavaConverters,
       
   403               "testmidletstart::registerAsMimeHandlerL AppForDocument2 error %d", err);
       
   404         User::Leave(err);
       
   405     }
       
   406     LOG1(EJavaConverters, EInfo,
       
   407          "testmidletstart::registerAsMimeHandlerL NOW handler is %x", newHandlerUid.iUid);
       
   408 
       
   409 
       
   410 
       
   411     // Restore old handler
       
   412     TDataTypePriority oldHandlerPriority(300);
       
   413     TUid originalHandlerUid;
       
   414     originalHandlerUid.iUid = 0x1000599d;
       
   415     err = apaSession.InsertDataMapping(mimeType, oldHandlerPriority, originalHandlerUid);
       
   416     if (KErrNone != err)
       
   417     {
       
   418         ELOG1(EJavaConverters,
       
   419               "testmidletstart::registerAsMimeHandlerL InsertDataMapping (restore old handler) error %d", err);
       
   420         User::Leave(err);
       
   421     }
       
   422 
       
   423     /*
       
   424         // Restore old handler
       
   425         TDataTypePriority oldHandlerPriority(300);
       
   426         TUid originalHandlerUid;
       
   427         originalHandlerUid.iUid = 0x101f4d90;
       
   428         err = apaSession.InsertDataMapping(mimeType, oldHandlerPriority, originalHandlerUid);
       
   429         if (KErrNone != err)
       
   430         {
       
   431             ELOG1(EJavaConverters,
       
   432                 "testmidletstart::registerAsMimeHandlerL InsertDataMapping (restore old handler) error %d", err);
       
   433             User::Leave(err);
       
   434         }
       
   435     */
       
   436 
       
   437     CleanupStack::PopAndDestroy(); // apaSession
       
   438 }
       
   439 
       
   440 
       
   441 /**
       
   442  * Create cleanup stack and run the cleaner code inside TRAP harness
       
   443  * to log unexpected leaves.
       
   444  */
       
   445 TInt E32Main()
       
   446 {
       
   447 //    __UHEAP_MARK;
       
   448     CTrapCleanup* cleanupStack = CTrapCleanup::New();
       
   449 
       
   450     TRAPD(err, readMidletsFromAppArcL());
       
   451     if (KErrNone != err)
       
   452     {
       
   453         ELOG1(EJavaConverters, "testmidletstart: readMidletsFromAppArcL leaved with err %d", err);
       
   454     }
       
   455 
       
   456     // Wait for a moment
       
   457     User::After(500000);
       
   458 
       
   459     TRAP(err, startByJavaLauncherSimpleL());
       
   460     if (KErrNone != err)
       
   461     {
       
   462         ELOG1(EJavaConverters, "testmidletstart: startByJavaLauncherSimple leaved with err %d", err);
       
   463     }
       
   464 
       
   465     // Wait for a moment
       
   466     User::After(500000);
       
   467 
       
   468     /*
       
   469         TRAP(err, startByAppArcL());
       
   470         if (KErrNone != err)
       
   471         {
       
   472             ELOG1(EJavaConverters, "testmidletstart: startByAppArcL leaved with err %d", err);
       
   473         }
       
   474 
       
   475         // Wait for a moment
       
   476         User::After(500000);
       
   477 
       
   478         TRAP(err, startByJavaLauncherL());
       
   479         if (KErrNone != err)
       
   480         {
       
   481             ELOG1(EJavaConverters, "testmidletstart: startByJavaLauncherL leaved with err %d", err);
       
   482         }
       
   483 
       
   484 
       
   485         // Wait for a moment
       
   486         User::After(500000);
       
   487 
       
   488         TRAP(err, registerAsMimeHandlerL());
       
   489         if (KErrNone != err)
       
   490         {
       
   491             ELOG1(EJavaConverters, "testmidletstart: registerAsMimeHandlerL leaved with err %d", err);
       
   492         }
       
   493     */
       
   494 
       
   495     delete cleanupStack;
       
   496 //    __UHEAP_MARKEND;
       
   497     return KErrNone;
       
   498 }
       
   499 // eof