Fixed lots of issues with installing a low-caps version of fshell from SIS file.
* Fixed issue in CCommandFactory whereby some APIs like GetCommandInfoL could trigger allocations on the wrong heap or signals to the wrong thread. The symptoms were often seen as a crash in the which_00 thread when running ciftest.
* Lots of build fixes for when FSHELL_PROTECTED_UIDS isn't defined and when all capabilities aren't available.
* Added new platform.mmh macro FSHELL_OPEN_SIGNED.
* Open signing of fshell SIS files is now supported for production S60 handsets. Build fshell with the FSHELL_OPEN_SIGNED macro defined (and without defining FSHELL_CAP_ALL or FSHELL_PROTECTED_UIDS) in your platform.mmh and submit \epoc32\fshell\fshell.unsigned.sis to https://www.symbiansigned.com/app/page/public/openSignedOnline.do . The following commands are not available when using Open Signing due to Platform Security restrictions: fdb; kerninfo; chunkinfo; svrinfo; objinfo; sudo; fsck; localdrive; ramdefrag; readmem; reboot; setcritical; setpriority. Others such as chkdeps, e32header, ps, and fshell itself will run but in a restricted capacity (for example, fshell will no longer allow you to modify files in the \sys\bin directory).
* Removed commands objinfo, svrinfo, chunkinfo, readmem, fsck completely when memory access isn't present - previously they would still appear in the help but would give an error if you tried to run them.
// pipe_line.h
//
// Copyright (c) 2006 - 2010 Accenture. All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the "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:
// Accenture - Initial contribution
//
#ifndef __PIPE_LINE_H__
#define __PIPE_LINE_H__
#include <e32base.h>
#include "command_wrappers.h"
class TError;
class CPipeLine;
class MConsole;
class CCommandFactory;
namespace IoUtils
{
class CEnvironment;
}
class MPipeLineObserver
{
public:
virtual void HandlePipeLineComplete(CPipeLine& aPipeLine, const TError& aError) = 0;
};
class RPipeSection
{
public:
RPipeSection();
void Close();
HBufC* GetCommandArguments() const;
public:
class TRedirection
{
public:
enum TType
{
ENotRedirected,
EFile,
EFileAppend,
EHandle,
ENull
};
enum THandle
{
EUnknown,
EStdin,
EStdout,
EStderr
};
public:
TRedirection();
void SetFileNameL(const TDesC& aCwd, const TDesC& aName);
public:
TType iType;
IoUtils::TFileName2* iFileName;
THandle iHandle;
};
public:
TPtrC iFullName;
TPtrC iCommandName;
RArray<TPtrC> iCommandArguments;
TRedirection iStdinRedirection;
TRedirection iStdoutRedirection;
TRedirection iStderrRedirection;
private:
mutable HBufC* iCommandArgumentsBuf;
};
class CPipeLine : public CBase, public MCommandObserver
{
public:
static CPipeLine* NewL(RIoSession& aIoSession, RIoReadHandle& aStdin, RIoWriteHandle& aStdout, RIoWriteHandle& aStderr, IoUtils::CEnvironment& aEnv, CCommandFactory& aFactory, const RArray<RPipeSection>& aPipeSections, TBool aBackground, MPipeLineObserver* aObserver, TError& aErrorContext);
static CPipeLine* NewLC(RIoSession& aIoSession, RIoReadHandle& aStdin, RIoWriteHandle& aStdout, RIoWriteHandle& aStderr, IoUtils::CEnvironment& aEnv, CCommandFactory& aFactory, const RArray<RPipeSection>& aPipeSections, TBool aBackground, MPipeLineObserver* aObserver, TError& aErrorContext);
~CPipeLine();
void Kill();
TInt Suspend();
TInt Resume();
TInt BringToForeground();
void SendToBackground();
const TDesC& Name() const;
TInt Reattach(RIoEndPoint& aStdinEndPoint, RIoEndPoint& aStdoutEndPoint, RIoEndPoint& aStderrEndPoint);
TBool IsDisownable() const;
void Disown();
private:
CPipeLine(RIoSession& aIoSession, RIoReadHandle& aStdin, RIoWriteHandle& aStdout, RIoWriteHandle& aStderr, IoUtils::CEnvironment& aEnv, CCommandFactory& aFactory, MPipeLineObserver* aObserver);
void ConstructL(const RArray<RPipeSection>& aPipeSections, TBool aBackground, TError& aErrorContext);
static TInt CompletionCallBack(TAny* aSelf);
private: // From MCommandObserver.
virtual void HandleCommandComplete(MCommand& aCommand, TInt aError);
private:
class RPipedCommand
{
public:
RPipedCommand();
void Close();
public:
MCommand* iCommand;
TInt iCompletionError;
HBufC* iCommandName;
TBool iStdinRedirected;
TBool iStdoutRedirected;
TBool iStderrRedirected;
};
private:
TPtrC iName;
RIoSession& iIoSession;
RIoReadHandle& iStdin;
RIoWriteHandle& iStdout;
RIoWriteHandle& iStderr;
IoUtils::CEnvironment& iEnv;
CCommandFactory& iFactory;
MPipeLineObserver* iObserver;
RArray<RPipedCommand> iCommands;
CAsyncCallBack* iCompletionCallBack;
TError iCompletionError;
};
#endif // __PIPE_LINE_H__