# HG changeset patch # User Tom Sutcliffe # Date 1284507950 -3600 # Node ID 264162c6ed9178e746652619819f92c24906976a # Parent b06038904ef8adddee9b2533e27c053d0c16b089# Parent 377ac716dabb6d7fdc4d8aa9f09dc440b4d91a5d merge diff -r b06038904ef8 -r 264162c6ed91 core/builtins/gobble.cif --- a/core/builtins/gobble.cif Wed Sep 15 00:44:34 2010 +0100 +++ b/core/builtins/gobble.cif Wed Sep 15 00:45:50 2010 +0100 @@ -14,11 +14,11 @@ ==short-description -A tool for purposefully wasting persistent storage space. +A tool for purposefully wasting disk space. ==long-description -If the specified file does not already exist, it will be created. If it does exist, it will be grown. +If the specified file does not already exist, it will be created. If it does exist, it will be grown by the amount specified. ==see-also @@ -28,13 +28,17 @@ Display more detailed output. +==option bool n no-write + +By default the file is filled with a pattern of 'x' characters. Specify this option to only set the file size and not to actually write to it. Useful if you want to test low disk space without introducing delays (and wear to the disk) of actually writing lots of data. + ==argument filename file_name The file to create or to append to. -==argument uint amount +==argument uint amount optional -The total number of bytes to consume. +The total number of bytes to consume. If zero or not specified, the file size is set to fill the free space on the disk. ==argument uint block_size optional diff -r b06038904ef8 -r 264162c6ed91 core/builtins/gobble.cpp --- a/core/builtins/gobble.cpp Wed Sep 15 00:44:34 2010 +0100 +++ b/core/builtins/gobble.cpp Wed Sep 15 00:45:50 2010 +0100 @@ -11,6 +11,7 @@ // #include "gobble.h" +#include CCommandBase* CCmdGobble::NewLC() @@ -38,9 +39,20 @@ void CCmdGobble::DoRunL() { - if (iAmount < iBlockSize) + RFs& fs = FsL(); + if (iAmount == 0) { - LeaveIfErr(KErrArgument, _L("The amount to consume must be less than the block size (%d)"), iBlockSize); + TInt drive = EDriveC; + if (iFileName.Length() == 0) LeaveIfErr(KErrBadName, _L("Bad file name")); + RFs::CharToDrive(iFileName[0], drive); + TVolumeInfo volInfo; + LeaveIfErr(fs.Volume(volInfo, drive), _L("Couldn't get volume information for drive %c"), iFileName[0]); + iAmount = volInfo.iFree; + } + + if (!iNoWrite && iAmount < iBlockSize) + { + LeaveIfErr(KErrArgument, _L("The amount to consume must be greater than the block size (%d)"), iBlockSize); } if (iAmount & 0x80000000) { @@ -50,7 +62,6 @@ { LeaveIfErr(KErrArgument, _L("The block size is too large (maximum is %d)"), KMaxTInt); } - RFs& fs = FsL(); fs.MkDirAll(iFileName); RFile file; TInt err = file.Open(fs, iFileName, EFileWrite); @@ -58,51 +69,64 @@ { err = file.Create(fs, iFileName, EFileWrite); } - User::LeaveIfError(err); + LeaveIfErr(err, _L("Couldn't create file %S"), &iFileName); CleanupClosePushL(file); - TInt pos = 0; - User::LeaveIfError(file.Seek(ESeekEnd, pos)); - HBufC8* buf = HBufC8::NewLC(iBlockSize); - TPtr8 ptr(buf->Des()); - ptr.Fill(TChar('x'), iBlockSize); - - TInt toWrite = static_cast(iAmount); - do + if (iNoWrite) + { + TInt size = 0; + LeaveIfErr(file.Size(size), _L("Couldn't get file size")); + size += iAmount; + LeaveIfErr(file.SetSize(size), _L("Couldn't set filesize to %d"), size); + } + else { - TInt writeSize; - if (toWrite > static_cast(iBlockSize)) + TInt pos = 0; + User::LeaveIfError(file.Seek(ESeekEnd, pos)); + HBufC8* buf = HBufC8::NewLC(iBlockSize); + TPtr8 ptr(buf->Des()); + ptr.Fill(TChar('x'), iBlockSize); + + TInt toWrite = static_cast(iAmount); + do { - writeSize = static_cast(iBlockSize); - } - else - { - writeSize = toWrite; + TInt writeSize; + if (toWrite > static_cast(iBlockSize)) + { + writeSize = static_cast(iBlockSize); + } + else + { + writeSize = toWrite; + } + ptr.SetLength(writeSize); + err = file.Write(ptr); + if (err == KErrNone) + { + if (iVerbose) + { + Printf(_L("\rWrote %d"), iAmount - toWrite); + } + toWrite -= writeSize; + } } - ptr.SetLength(writeSize); - err = file.Write(ptr); - if (err == KErrNone) - { - if (iVerbose) - { - Printf(_L("\rWrote %d"), iAmount - toWrite); - } - toWrite -= writeSize; - } - } while ((err == KErrNone) && (toWrite > 0)); if (iVerbose) { Printf(_L("\rWrote %d"), iAmount - toWrite); } - - CleanupStack::PopAndDestroy(2, &file); + CleanupStack::PopAndDestroy(buf); + } + CleanupStack::PopAndDestroy(&file); } void CCmdGobble::OptionsL(RCommandOptionList& aOptions) { _LIT(KCmdOptVerbose, "verbose"); aOptions.AppendBoolL(iVerbose, KCmdOptVerbose); + + _LIT(KCmdOptNoWrite, "no-write"); + aOptions.AppendBoolL(iNoWrite, KCmdOptNoWrite); } void CCmdGobble::ArgumentsL(RCommandArgumentList& aArguments) diff -r b06038904ef8 -r 264162c6ed91 core/builtins/gobble.h --- a/core/builtins/gobble.h Wed Sep 15 00:44:34 2010 +0100 +++ b/core/builtins/gobble.h Wed Sep 15 00:45:50 2010 +0100 @@ -32,4 +32,5 @@ TUint iAmount; TUint iBlockSize; TBool iVerbose; + TBool iNoWrite; }; diff -r b06038904ef8 -r 264162c6ed91 core/builtins/help.cif --- a/core/builtins/help.cif Wed Sep 15 00:44:34 2010 +0100 +++ b/core/builtins/help.cif Wed Sep 15 00:45:50 2010 +0100 @@ -18,7 +18,7 @@ ==long-description -Lists fshell's built-in and alias commands (e.g. C is an alias for C). Also lists external commands, DLLs that have a UID2 of 0x102864C8 and EXEs that have a UID2 of 0x102835BE. +Lists fshell's built-in and alias commands (e.g. C is an alias for C). Also lists external commands, that is EXEs that have a UID2 of 0x102835BE (FSHELL_UID2_FSHELL_EXE). ==option bool c count diff -r b06038904ef8 -r 264162c6ed91 core/builtins/sleep.cif --- a/core/builtins/sleep.cif Wed Sep 15 00:44:34 2010 +0100 +++ b/core/builtins/sleep.cif Wed Sep 15 00:45:50 2010 +0100 @@ -18,8 +18,7 @@ ==argument uint duration optional -The length of time to sleep for in seconds. If not specified, sleeps indefinately. - +The length of time to sleep for in seconds. If not specified, sleeps indefinitely. ==copyright diff -r b06038904ef8 -r 264162c6ed91 core/src/commands.cpp --- a/core/src/commands.cpp Wed Sep 15 00:44:34 2010 +0100 +++ b/core/src/commands.cpp Wed Sep 15 00:45:50 2010 +0100 @@ -83,11 +83,24 @@ RArray commands; CleanupClosePushL(commands); gShell->CommandFactory().ListCommandsL(commands); - iFormatter = CTextFormatter::NewL(Stdout()); - iFormatter->ColumnizeL(0, 2, commands.Array()); + if (!Stdout().AttachedToConsole()) + { + // Print them one per line (like how ls does it when not attached to a console) + for (TInt i = 0; i < commands.Count(); i++) + { + // The async writing is a legacy from when help was a local command. We don't need to observe it now. + Printf(_L("%S\r\n"), &commands[i]); + } + Complete(); + } + else + { + iFormatter = CTextFormatter::NewL(Stdout()); + iFormatter->ColumnizeL(0, 2, commands.Array()); + Stdout().Write(iFormatter->Descriptor(), iStatus); + SetActive(); + } CleanupStack::PopAndDestroy(&commands); - Stdout().Write(iFormatter->Descriptor(), iStatus); - SetActive(); } } @@ -3622,7 +3635,6 @@ if (iTimeout) { - timer.After(timerStat, iTimeout * 1000 * 1000); User::WaitForRequest(waitStatus, timerStat); if (iMeasure) endTime = User::NTickCount(); diff -r b06038904ef8 -r 264162c6ed91 documentation/change_history.pod --- a/documentation/change_history.pod Wed Sep 15 00:44:34 2010 +0100 +++ b/documentation/change_history.pod Wed Sep 15 00:45:50 2010 +0100 @@ -42,7 +42,7 @@ =item * -Fixed a defect in iosrv.exe that caused a panic if a foreground read object was attached to a different end point. This was due to the read object being notified of a change in foreground before its iEndPoint member was updated. This member is now updated before attempting the attach, and is set to NULL in the event of a leave (resulting in the read object being left in an unattached state). +Fixed a defect in iosrv.exe that caused a panic if a foreground read object was attached to a different end point. This was due to the read object being notified of a change in foreground before its iEndPoint member was updated. This member is now updated before attempting the attach, and is set to NULL in the event of a leave (resulting in the read object being left in an unattached state). Fixed race condition and hang in C. =item * @@ -50,7 +50,7 @@ =item * -Added C<--codesegs> option to L. +Added C<--codesegs> option to L and C<--no-write> option to L. =item * @@ -60,6 +60,10 @@ fshell's current working directory is now normalised (via new TFileName2::Normalize function) so that the case matches what's on the filesystem). +=item * + +Fixed crash in L C<--timeout> option. + =back =head2 Release 000.2-000.5 diff -r b06038904ef8 -r 264162c6ed91 libraries/iosrv/client/command_base.cpp --- a/libraries/iosrv/client/command_base.cpp Wed Sep 15 00:44:34 2010 +0100 +++ b/libraries/iosrv/client/command_base.cpp Wed Sep 15 00:45:50 2010 +0100 @@ -1994,7 +1994,7 @@ _LIT(KFormFeed, "\f"); _LIT(KHorizontalTab, "\t"); _LIT(KVerticalTab, "\v"); - _LIT(KNewLine, "\n"); + _LIT(KLineFeed, "\n"); _LIT(KCarriageReturn, "\r"); if (!aLex.Eos()) { @@ -2017,7 +2017,7 @@ aBuf.AppendL(KVerticalTab); break; case 'n': - aBuf.AppendL(KNewLine); + aBuf.AppendL(KLineFeed); break; case 'r': aBuf.AppendL(KCarriageReturn);