pcsx2: Replace ScopedArray with unique_ptr

Same functionality, but we don't have to maintain code ourselves.
This commit is contained in:
Jonathan Li 2015-12-23 12:38:34 +00:00
parent e472713c62
commit e7ca031d1e
9 changed files with 25 additions and 26 deletions

View File

@ -23,6 +23,7 @@
#elif defined(__APPLE__)
# include <aio.h>
#endif
#include <memory>
class AsyncFileReader
{
@ -147,12 +148,12 @@ class BlockdumpFileReader : public AsyncFileReader
wxFileInputStream* m_file;
// total number of blocks in the ISO image (including all parts)
u32 m_blocks;
s32 m_blockofs;
u32 m_blocks;
s32 m_blockofs;
// index table
ScopedArray<u32> m_dtable;
int m_dtablesize;
std::unique_ptr<u32[]> m_dtable;
int m_dtablesize;
int m_lresult;

View File

@ -86,7 +86,7 @@ bool BlockdumpFileReader::Open(const wxString& fileName)
pxAssert( (datalen % (m_blocksize + 4)) == 0);
m_dtablesize = datalen / (m_blocksize + 4);
m_dtable = new u32[m_dtablesize];
m_dtable = std::unique_ptr<u32[]>(new u32[m_dtablesize]);
m_file->SeekI(BlockDumpHeaderSize);
@ -95,14 +95,14 @@ bool BlockdumpFileReader::Open(const wxString& fileName)
u32 has = 0;
int i = 0;
ScopedArray<u8> buffer(bs);
std::unique_ptr<u8[]> buffer(new u8[bs]);
do {
m_file->Read(buffer.GetPtr(), bs);
m_file->Read(buffer.get(), bs);
has = m_file->LastRead();
while (i < m_dtablesize && off < has)
{
m_dtable[i++] = *(u32*)(buffer.GetPtr() + off);
m_dtable[i++] = *reinterpret_cast<u32*>(buffer.get() + off);
off += 4;
off += m_blocksize;
}

View File

@ -27,11 +27,11 @@
#include <time.h>
#include <wx/datetime.h>
#include <exception>
#include <memory>
#include "IsoFS/IsoFS.h"
#include "IsoFS/IsoFSCDVD.h"
#include "CDVDisoReader.h"
#include "Utilities/ScopedPtr.h"
#include "DebugTools/SymbolMap.h"
#include "AppConfig.h"
@ -82,14 +82,14 @@ static int CheckDiskTypeFS(int baseType)
int size = file.getLength();
ScopedArray<char> buffer((int)file.getLength()+1);
file.read((u8*)(buffer.GetPtr()),size);
std::unique_ptr<char[]> buffer(new char[file.getLength() + 1]);
file.read(buffer.get(),size);
buffer[size]='\0';
char* pos = strstr(buffer.GetPtr(), "BOOT2");
char* pos = strstr(buffer.get(), "BOOT2");
if (pos == NULL)
{
pos = strstr(buffer.GetPtr(), "BOOT");
pos = strstr(buffer.get(), "BOOT");
if (pos == NULL) return CDVD_TYPE_ILLEGAL;
return CDVD_TYPE_PSCD;
}

View File

@ -19,6 +19,7 @@
#include "wx/wfstream.h"
#include "AsyncFileReader.h"
#include "CompressedFileReader.h"
#include <memory>
enum isoType
{
@ -113,8 +114,8 @@ protected:
u32 m_blocks;
// dtable / dtablesize are used when reading blockdumps
ScopedArray<u32> m_dtable;
int m_dtablesize;
std::unique_ptr<u32[]> m_dtable;
int m_dtablesize;
ScopedPtr<wxFileOutputStream> m_outstream;

View File

@ -114,7 +114,7 @@ void OutputIsoFile::WriteSector(const u8* src, uint lsn)
void OutputIsoFile::Close()
{
m_dtable.Delete();
m_dtable.reset(nullptr);
_init();
}

View File

@ -17,6 +17,7 @@
#include "App.h"
#include <array>
#include <memory>
BEGIN_DECLARE_EVENT_TYPES()
DECLARE_EVENT_TYPE(pxEvt_DockConsole, -1)
@ -214,12 +215,6 @@ protected:
// a similar effect)
ScopedPtr<ConsoleTestThread> m_threadlogger;
// ----------------------------------------------------------------------------
// Window and Menu Object Handles
// ----------------------------------------------------------------------------
ScopedArray<wxMenuItem*> m_sourceChecks;
public:
// ctor & dtor
ConsoleLogFrame( MainEmuFrame *pParent, const wxString& szTitle, ConLogConfig& options );

View File

@ -203,7 +203,7 @@ static bool traceLogEnabled( const wxString& ident )
// --------------------------------------------------------------------------------------
Panels::LogOptionsPanel::LogOptionsPanel(wxWindow* parent )
: BaseApplicableConfigPanel( parent )
, m_checks( traceLogCount )
, m_checks( new pxCheckBox*[traceLogCount] )
{
wxStaticBoxSizer& s_misc = *new wxStaticBoxSizer( wxHORIZONTAL, this, L"Misc" );

View File

@ -17,6 +17,7 @@
#include "AppCommon.h"
#include "ApplyState.h"
#include <memory>
namespace Panels
{
@ -79,7 +80,7 @@ namespace Panels
pxCheckBox* m_masterEnabler;
ScopedArray<pxCheckBox*> m_checks;
std::unique_ptr<pxCheckBox*[]> m_checks;
public:
LogOptionsPanel( wxWindow* parent );

View File

@ -21,6 +21,7 @@
#include "ps2/BiosTools.h"
#include <memory>
#include <wx/stdpaths.h>
using namespace Dialogs;
@ -107,13 +108,13 @@ Panels::LanguageSelectionPanel::LanguageSelectionPanel( wxWindow* parent, bool s
i18n_EnumeratePackages( m_langs );
int size = m_langs.size();
ScopedArray<wxString> compiled( size );
std::unique_ptr<wxString[]> compiled( new wxString[size] );
for( int i=0; i<size; ++i )
compiled[i].Printf( L"%s", m_langs[i].englishName.c_str() );
m_picker = new wxComboBox( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize,
size, compiled.GetPtr(), wxCB_READONLY);
size, compiled.get(), wxCB_READONLY);
*this += 5;
*this += m_picker | pxSizerFlags::StdSpace();