diff options
author | Jarkko Hietaniemi <jhi@iki.fi> | 2005-10-21 20:15:23 +0300 |
---|---|---|
committer | H.Merijn Brand <h.m.brand@xs4all.nl> | 2005-10-21 14:12:10 +0000 |
commit | ed76c0e43f6496020fbf49e22ea9651b31346e91 (patch) | |
tree | dfb2d6e7605023979056f995918fc79f131e4ccf /symbian/PerlApp.cpp | |
parent | 4ef2275c8517a5b084d75f6179d5b49f77f76d2c (diff) | |
download | perl-ed76c0e43f6496020fbf49e22ea9651b31346e91.tar.gz |
Symbian/beginnings of Series 80 support
Message-ID: <B356D8F434D20B40A8CEDAEC305A1F24E7A67E@esebe105.NOE.Nokia.com>
p4raw-id: //depot/perl@25814
Diffstat (limited to 'symbian/PerlApp.cpp')
-rw-r--r-- | symbian/PerlApp.cpp | 197 |
1 files changed, 165 insertions, 32 deletions
diff --git a/symbian/PerlApp.cpp b/symbian/PerlApp.cpp index dbcdd8cdb7..f5fa29ee07 100644 --- a/symbian/PerlApp.cpp +++ b/symbian/PerlApp.cpp @@ -1,13 +1,26 @@ /* Copyright (c) 2004-2005 Nokia. All rights reserved. */ /* The PerlApp application is licensed under the same terms as Perl itself. - * Note that this PerlApp is for Symbian/Series 60 smartphones and has nothing - * whatsoever to do with the ActiveState PerlApp. */ + * Note that this PerlApp is for Symbian/Series 60/80 smartphones and it has + * nothing whatsoever to do with the ActiveState PerlApp. */ #include "PerlApp.h" -#include <avkon.hrh> -#include <aknnotewrappers.h> +#ifdef __SERIES60__ +# include <avkon.hrh> +# include <aknnotewrappers.h> +# include <AknCommonDialogs.h> +# ifndef __SERIES60_1X__ +# include <CAknFileSelectionDialog.h> +# endif +#endif /* #ifdef __SERIES60__ */ + +#ifdef __SERIES80__ +# include <eikon.hrh> +# include <cknflash.h> +# include <ckndgopn.h> +#endif /* #ifdef __SERIES80__ */ + #include <apparc.h> #include <e32base.h> #include <e32cons.h> @@ -17,17 +30,12 @@ #include <utf.h> #include <f32file.h> -#include <AknCommonDialogs.h> - -#ifndef __SERIES60_1X__ -#include <CAknFileSelectionDialog.h> -#endif - #include <coemain.h> #ifndef PerlMin #include "PerlApp.hrh" + #include "PerlApp.rsg" #endif //#ifndef PerlMin @@ -125,54 +133,98 @@ CPerlAppUi::~CPerlAppUi() #ifndef PerlMin +#ifdef __SERIES60__ + static TBool DlgOk(CAknNoteDialog* dlg) { return dlg && dlg->RunDlgLD() == EAknSoftkeyOk; } +#endif /* #ifdef __SERIES60__ */ + static TBool OkCancelDialogL(TDesC& aMessage) { +#ifdef __SERIES60__ CAknNoteDialog* dlg = new (ELeave) CAknNoteDialog(CAknNoteDialog::EConfirmationTone); dlg->PrepareLC(R_OK_CANCEL_DIALOG); dlg->SetTextL(aMessage); return DlgOk(dlg); +#endif /* #ifdef __SERIES60__ */ +#ifdef __SERIES80__ + return CCknFlashingDialog::RunDlgLD(_L("OK/Cancel"), aMessage, NULL, + CCknFlashingDialog::EShort, + NULL); +#endif /* #ifdef __SERIES80__ */ } static TBool YesNoDialogL(TDesC& aMessage) { +#ifdef __SERIES60__ CAknNoteDialog* dlg = new (ELeave) CAknNoteDialog(CAknNoteDialog::EConfirmationTone); dlg->PrepareLC(R_YES_NO_DIALOG); dlg->SetTextL(aMessage); return DlgOk(dlg); +#endif /* #ifdef __SERIES60__ */ +#ifdef __SERIES80__ + return CCknFlashingDialog::RunDlgLD(_L("Yes/No"), aMessage, NULL, + CCknFlashingDialog::EShort, + NULL); +#endif /* #ifdef __SERIES80__ */ } static TInt InformationNoteL(TDesC& aMessage) { +#ifdef __SERIES60__ CAknInformationNote* note = new (ELeave) CAknInformationNote; return note->ExecuteLD(aMessage); +#endif /* #ifdef __SERIES60__ */ +#ifdef __SERIES80__ + return CCknFlashingDialog::RunDlgLD(_L("Info"), aMessage, NULL, + CCknFlashingDialog::ENormal, + NULL); +#endif /* #ifdef __SERIES80__ */ } static TInt ConfirmationNoteL(TDesC& aMessage) { +#ifdef __SERIES60__ CAknConfirmationNote* note = new (ELeave) CAknConfirmationNote; return note->ExecuteLD(aMessage); +#endif /* #ifdef __SERIES60__ */ +#ifdef __SERIES80__ + return CCknFlashingDialog::RunDlgLD(_L("Confirmation"), aMessage, NULL, + CCknFlashingDialog::ENormal, + NULL); +#endif /* #ifdef __SERIES80__ */ } static TInt WarningNoteL(TDesC& aMessage) { +#ifdef __SERIES60__ CAknWarningNote* note = new (ELeave) CAknWarningNote; return note->ExecuteLD(aMessage); +#endif /* #ifdef __SERIES60__ */ +#ifdef __SERIES80__ + CEikonEnv::Static()->AlertWin(aMessage); + return ETrue; +#endif /* #ifdef __SERIES80__ */ } static TInt TextQueryDialogL(const TDesC& aPrompt, TDes& aData, const TInt aMaxLength) { +#ifdef __SERIES60__ CAknTextQueryDialog* dlg = new (ELeave) CAknTextQueryDialog(aData); dlg->SetPromptL(aPrompt); dlg->SetMaxLength(aMaxLength); return dlg->ExecuteLD(R_TEXT_QUERY_DIALOG); +#endif /* #ifdef __SERIES60__ */ +#ifdef __SERIES80__ + /* TODO */ + return ETrue; +#endif } // The isXXX() come from the Perl headers. @@ -436,15 +488,15 @@ TBool CPerlAppUi::ProcessCommandParametersL(TApaCommand aCommand, TFileName& /* { if (aCommand == EApaCommandRun) { TFileName appName = Application()->AppFullName(); - TParse p; - p.Set(KDefaultScript, &appName, NULL); - TEntry aEntry; - RFs aFs; - aFs.Connect(); - if (aFs.Entry(p.FullName(), aEntry) == KErrNone) { - DoRunScriptL(p.FullName()); - Exit(); - } + TParse p; + p.Set(KDefaultScript, &appName, NULL); + TEntry aEntry; + RFs aFs; + aFs.Connect(); + if (aFs.Entry(p.FullName(), aEntry) == KErrNone) { + DoRunScriptL(p.FullName()); + Exit(); + } } return aCommand == EApaCommandOpen ? ETrue : EFalse; } @@ -458,18 +510,13 @@ void CPerlAppUi::SetFs(const RFs& aFs) #endif // #ifndef PerlMin -void CPerlAppUi::HandleCommandL(TInt aCommand) -{ +static void DoHandleCommandL(TInt aCommand) { #ifndef PerlMin TMessageBuffer message; #endif // #ifndef PerlMin switch(aCommand) { - case EEikCmdExit: - case EAknSoftkeyExit: - Exit(); - break; #ifndef PerlMin case EPerlAppCommandAbout: { @@ -499,21 +546,44 @@ void CPerlAppUi::HandleCommandL(TInt aCommand) break; case EPerlAppCommandRunFile: { - InformationNoteL(message); TFileName aScriptUtf16; +#ifdef __SERIES60__ if (AknCommonDialogs::RunSelectDlgLD(aScriptUtf16, R_MEMORY_SELECTION_DIALOG)) DoRunScriptL(aScriptUtf16); - } +#endif /* #ifdef __SERIES60__ */ +#ifdef __SERIES80__ + aScriptUtf16.Copy(_L("C:\\")); + if (CCknOpenFileDialog::RunDlgLD(aScriptUtf16, + CCknOpenFileDialog::EShowSystemFilesAndFolders | + CCknOpenFileDialog::EShowHiddenFilesAndFolders | + CCknOpenFileDialog::EShowAllDrives | + CCknOpenFileDialog::EShowExtendedView | + CCknOpenFileDialog::EShowNoFilesText) { + /* TODO: despite all the above flags still does not seem + * to allow navigating outside the default directory. */ + TEntry aEntry; + RFs aFs; + aFs.Connect(); + if (aFs.Entry(aScriptUtf16, aEntry) == KErrNone) + DoRunScriptL(aScriptUtf16); + /* else show error message? */ + } +#endif /* #ifdef __SERIES80__ */ + } break; case EPerlAppCommandOneLiner: { _LIT(prompt, "Oneliner:"); - if (TextQueryDialogL(prompt, iOneLiner, KPerlAppOneLinerSize)) { - const TUint KPerlAppUtf8Multi = 3; + CPerlAppUi* cAppUi = + STATIC_CAST(CPerlAppUi*, CEikonEnv::Static()->EikAppUi()); + if (TextQueryDialogL(prompt, + cAppUi->iOneLiner, + KPerlAppOneLinerSize)) { + const TUint KPerlAppUtf8Multi = 3; TBuf8<KPerlAppUtf8Multi * KPerlAppOneLinerSize> utf8; - CnvUtfConverter::ConvertFromUnicodeToUtf8(utf8, iOneLiner); + CnvUtfConverter::ConvertFromUnicodeToUtf8(utf8, cAppUi->iOneLiner); CPerlBase* perl = CPerlBase::NewInterpreterLC(); int argc = 3; char **argv = (char**) malloc(argc * sizeof(char *)); @@ -535,13 +605,71 @@ void CPerlAppUi::HandleCommandL(TInt aCommand) InformationNoteL(message); } break; + case EPerlAppCommandAboutCopyright: + { + TMessageBuffer m1; + TMessageBuffer m2; + m1.Format(KAboutFormat, + PERL_REVISION, + PERL_VERSION, + PERL_SUBVERSION, + PERL_SYMBIANPORT_MAJOR, + PERL_SYMBIANPORT_MINOR, + PERL_SYMBIANPORT_PATCH, + &KFlavor, + PERL_SYMBIANSDK_MAJOR, + PERL_SYMBIANSDK_MINOR + ); + InformationNoteL(message); + m2.Format(KCopyrightFormat); + message.Format(_L("%S %S"), &m1, &m2); + InformationNoteL(message); + } + break; #endif // #ifndef PerlMin default: Panic(EPerlAppCommandUnknown); + } +} + +#ifdef __SERIES60__ + +void CPerlAppUi::HandleCommandL(TInt aCommand) +{ + switch(aCommand) + { + case EEikCmdExit: + case EAknSoftkeyExit: + Exit(); + break; + default: + DoHandleCommandL(aCommand); + break; + } +} + +#endif /* #ifdef __SERIES60__ */ + +#ifdef __SERIES80__ + +void CPerlAppView::HandleCommandL(TInt aCommand) { + DoHandleCommandL(aCommand); +} + +void CPerlAppUi::HandleCommandL(TInt aCommand) { + switch(aCommand) + { + case EEikCmdExit: + Exit(); + break; + default: + iAppView->HandleCommandL(aCommand); break; } } +#endif /* #ifdef __SERIES80__ */ + CPerlAppView* CPerlAppView::NewL(const TRect& aRect) { CPerlAppView* self = CPerlAppView::NewLC(aRect); @@ -564,6 +692,10 @@ void CPerlAppView::ConstructL(const TRect& aRect) ActivateL(); } +CPerlAppView::~CPerlAppView() +{ +} + void CPerlAppView::Draw(const TRect& /*aRect*/) const { CWindowGc& gc = SystemGc(); @@ -586,12 +718,13 @@ CEikAppUi* CPerlAppDocument::CreateAppUiL() #ifndef PerlMin -CFileStore* CPerlAppDocument::OpenFileL(TBool /* aDoOpen */, const TDesC& aFileName, RFs& aFs) +CFileStore* CPerlAppDocument::OpenFileL(TBool aDoOpen, const TDesC& aFileName, RFs& aFs) { CPerlAppUi* appui = STATIC_CAST(CPerlAppUi*, CEikonEnv::Static()->EikAppUi()); appui->SetFs(aFs); - appui->OpenFileL(aFileName); + if (aDoOpen) + appui->OpenFileL(aFileName); return NULL; } |