Files @ r23516:763b689dacfc
Branch filter:

Location: cpp/openttd-patchpack/source/src/fios.h - annotation

Henry Wilson
Codechange: [core] Implement SmallVector using std::vector

The public and protected interface to SmallVector are unchanged
SmallVector now requires that items be default constructible
This isn't an issue since some contained items were previously created
uninitialized.

Temporary default constructors are added to the following structs
- SmallPair
- SmallStackItem
- GRFPresence

Where vector<bool> is required, transition immediately to std::vector
to avoid returning proxy object references.
r5475:3f5cd13d1b63
r5475:3f5cd13d1b63
r12768:980ae0491352
r12768:980ae0491352
r12768:980ae0491352
r12768:980ae0491352
r12768:980ae0491352
r12768:980ae0491352
r12768:980ae0491352
r6179:c0508e7aefec
r6179:c0508e7aefec
r5475:3f5cd13d1b63
r5475:3f5cd13d1b63
r5475:3f5cd13d1b63
r15288:c9665f6c8c50
r15329:105580ad3516
r15330:4bbcc5af5e21
r19556:51f34458ed8a
r8264:d493cb51fe8a
r15324:eb6642b7b379
r23063:0ce21787e61f
r23063:0ce21787e61f
r23063:0ce21787e61f
r23063:0ce21787e61f
r23063:0ce21787e61f
r23063:0ce21787e61f
r23063:0ce21787e61f
r15329:105580ad3516
r15329:105580ad3516
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15325:2c8e92d40538
r15326:d5a6f99c5425
r15325:2c8e92d40538
r15327:dd42e0009eb3
r15327:dd42e0009eb3
r15329:105580ad3516
r15329:105580ad3516
r15330:4bbcc5af5e21
r15330:4bbcc5af5e21
r15330:4bbcc5af5e21
r18219:9a85d923ce33
r18219:9a85d923ce33
r18219:9a85d923ce33
r20983:4b9faf9002d5
r20983:4b9faf9002d5
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15333:1a68a37087d2
r16052:fbe493ecffbd
r16052:fbe493ecffbd
r16052:fbe493ecffbd
r16052:fbe493ecffbd
r16052:fbe493ecffbd
r16052:fbe493ecffbd
r16052:fbe493ecffbd
r16052:fbe493ecffbd
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15333:1a68a37087d2
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15324:eb6642b7b379
r15173:a59afd6301a6
r7805:7b5af263f275
r22522:211f98bf45cf
r22522:211f98bf45cf
r22522:211f98bf45cf
r7805:7b5af263f275
r7805:7b5af263f275
r7805:7b5af263f275
r7805:7b5af263f275
r19944:25a78576fb5e
r7805:7b5af263f275
r7805:7b5af263f275
r22522:211f98bf45cf
r7805:7b5af263f275
r7805:7b5af263f275
r17710:a85ce5ffdabf
r8151:3983fe61f8f0
r9031:07843023862f
r8151:3983fe61f8f0
r8151:3983fe61f8f0
r11254:47f8fdc610df
r8151:3983fe61f8f0
r8151:3983fe61f8f0
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22446:e215802a4b89
r22437:0d2a25485d75
r22437:0d2a25485d75
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r15173:a59afd6301a6
r9409:e2f52fd75f31
r9409:e2f52fd75f31
r9409:e2f52fd75f31
r9409:e2f52fd75f31
r9409:e2f52fd75f31
r15287:234038b24f99
r9409:e2f52fd75f31
r5475:3f5cd13d1b63
r15287:234038b24f99
r8149:8a97dd280f35
r22446:e215802a4b89
r5475:3f5cd13d1b63
r22446:e215802a4b89
r22446:e215802a4b89
r22446:e215802a4b89
r17710:a85ce5ffdabf
r11251:26edb2b90360
r17710:a85ce5ffdabf
r10771:bbad5384e0a7
r5475:3f5cd13d1b63
r21390:b979565a1681
r21390:b979565a1681
r17710:a85ce5ffdabf
r22446:e215802a4b89
r5475:3f5cd13d1b63
r13020:bcf841558612
r5475:3f5cd13d1b63
r5475:3f5cd13d1b63
/* $Id$ */

/*
 * This file is part of OpenTTD.
 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
 */

/** @file fios.h Declarations for savegames operations */

#ifndef FIOS_H
#define FIOS_H

#include "gfx_type.h"
#include "company_base.h"
#include "newgrf_config.h"
#include "network/core/tcp_content.h"


/** Special values for save-load window for the data parameter of #InvalidateWindowData. */
enum SaveLoadInvalidateWindowData {
	SLIWD_RESCAN_FILES,          ///< Rescan all files (when changed directory, ...)
	SLIWD_SELECTION_CHANGES,     ///< File selection has changed (user click, ...)
	SLIWD_FILTER_CHANGES,        ///< The filename filter has changed (via the editbox)
};

typedef SmallMap<uint, CompanyProperties *> CompanyPropertiesMap;

/**
 * Container for loading in mode SL_LOAD_CHECK.
 */
struct LoadCheckData {
	bool checkable;     ///< True if the savegame could be checked by SL_LOAD_CHECK. (Old savegames are not checkable.)
	StringID error;     ///< Error message from loading. INVALID_STRING_ID if no error.
	char *error_data;   ///< Data to pass to SetDParamStr when displaying #error.

	uint32 map_size_x, map_size_y;
	Date current_date;

	GameSettings settings;

	CompanyPropertiesMap companies;               ///< Company information.

	GRFConfig *grfconfig;                         ///< NewGrf configuration from save.
	GRFListCompatibility grf_compatibility;       ///< Summary state of NewGrfs, whether missing files or only compatible found.

	struct LoggedAction *gamelog_action;          ///< Gamelog actions
	uint gamelog_actions;                         ///< Number of gamelog actions

	LoadCheckData() : error_data(NULL), grfconfig(NULL),
			grf_compatibility(GLC_NOT_FOUND), gamelog_action(NULL), gamelog_actions(0)
	{
		this->Clear();
	}

	/**
	 * Don't leak memory at program exit
	 */
	~LoadCheckData()
	{
		this->Clear();
	}

	/**
	 * Check whether loading the game resulted in errors.
	 * @return true if errors were encountered.
	 */
	bool HasErrors()
	{
		return this->checkable && this->error != INVALID_STRING_ID;
	}

	/**
	 * Check whether the game uses any NewGrfs.
	 * @return true if NewGrfs are used.
	 */
	bool HasNewGrfs()
	{
		return this->checkable && this->error == INVALID_STRING_ID && this->grfconfig != NULL;
	}

	void Clear();
};

extern LoadCheckData _load_check_data;


enum FileSlots {
	/**
	 * Slot used for the GRF scanning and such.
	 * This slot is used for all temporary accesses to files when scanning/testing files,
	 * and thus cannot be used for files, which are continuously accessed during a game.
	 */
	CONFIG_SLOT    =  0,
	/** Slot for the sound. */
	SOUND_SLOT     =  1,
	/** First slot usable for (New)GRFs used during the game. */
	FIRST_GRF_SLOT =  2,
	/** Maximum number of slots. */
	MAX_FILE_SLOTS = 128,
};

/** Deals with finding savegames */
struct FiosItem {
	FiosType type;
	uint64 mtime;
	char title[64];
	char name[MAX_PATH];
};

/** List of file information. */
class FileList {
public:
	~FileList();

	/**
	 * Construct a new entry in the file list.
	 * @return Pointer to the new items to be initialized.
	 */
	inline FiosItem *Append()
	{
		return this->files.Append();
	}

	/**
	 * Get the number of files in the list.
	 * @return The number of files stored in the list.
	 */
	inline uint Length() const
	{
		return this->files.Length();
	}

	/**
	 * Get a pointer to the first file information.
	 * @return Address of the first file information.
	 */
	inline const FiosItem *Begin() const
	{
		return this->files.Begin();
	}

	/**
	 * Get a pointer behind the last file information.
	 * @return Address behind the last file information.
	 */
	inline const FiosItem *End() const
	{
		return this->files.End();
	}

	/**
	 * Get a pointer to the indicated file information. File information must exist.
	 * @return Address of the indicated existing file information.
	 */
	inline const FiosItem *Get(uint index) const
	{
		return this->files.Get(index);
	}

	/**
	 * Get a pointer to the indicated file information. File information must exist.
	 * @return Address of the indicated existing file information.
	 */
	inline FiosItem *Get(uint index)
	{
		return this->files.Get(index);
	}

	inline const FiosItem &operator[](uint index) const
	{
		return this->files[index];
	}

	/**
	 * Get a reference to the indicated file information. File information must exist.
	 * @return The requested file information.
	 */
	inline FiosItem &operator[](uint index)
	{
		return this->files[index];
	}

	/** Remove all items from the list. */
	inline void Clear()
	{
		this->files.Clear();
	}

	/** Compact the list down to the smallest block size boundary. */
	inline void Compact()
	{
		this->files.Compact();
	}

	void BuildFileList(AbstractFileType abstract_filetype, SaveLoadOperation fop);
	const FiosItem *FindItem(const char *file);

	SmallVector<FiosItem, 32> files; ///< The list of files.
};

enum SortingBits {
	SORT_ASCENDING  = 0,
	SORT_DESCENDING = 1,
	SORT_BY_DATE    = 0,
	SORT_BY_NAME    = 2
};
DECLARE_ENUM_AS_BIT_SET(SortingBits)

/* Variables to display file lists */
extern SortingBits _savegame_sort_order;

void ShowSaveLoadDialog(AbstractFileType abstract_filetype, SaveLoadOperation fop);

void FiosGetSavegameList(SaveLoadOperation fop, FileList &file_list);
void FiosGetScenarioList(SaveLoadOperation fop, FileList &file_list);
void FiosGetHeightmapList(SaveLoadOperation fop, FileList &file_list);

const char *FiosBrowseTo(const FiosItem *item);

StringID FiosGetDescText(const char **path, uint64 *total_free);
bool FiosDelete(const char *name);
void FiosMakeHeightmapName(char *buf, const char *name, const char *last);
void FiosMakeSavegameName(char *buf, const char *name, const char *last);

FiosType FiosGetSavegameListCallback(SaveLoadOperation fop, const char *file, const char *ext, char *title, const char *last);

int CDECL CompareFiosItems(const FiosItem *a, const FiosItem *b);

#endif /* FIOS_H */