Files @ r23756:111ac5dfb696
Branch filter:

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

translators
Update: Translations from eints
croatian: 3 changes by VoyagerOne
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
r23607:36c15679007d
r23607:36c15679007d
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
r23607:36c15679007d
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
r23615:089d5615f68e
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
r23532:dc91fcd293f5
r23532:dc91fcd293f5
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23553:9f01781fc43d
r22434:b6a9d97303fc
r23520:20bbc807b0eb
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23536:ce42deb0b32d
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23536:ce42deb0b32d
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23553:9f01781fc43d
r22434:b6a9d97303fc
r23530:3c94d05f840c
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23553:9f01781fc43d
r22434:b6a9d97303fc
r23529:c3623e1b8808
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23553:9f01781fc43d
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23553:9f01781fc43d
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23517:1a32c3c14728
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r23518:3531e6987951
r22434:b6a9d97303fc
r22434:b6a9d97303fc
r22446:e215802a4b89
r22437:0d2a25485d75
r22437:0d2a25485d75
r23538:8df50944b27a
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
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(nullptr), grfconfig(nullptr),
			grf_compatibility(GLC_NOT_FOUND), gamelog_action(nullptr), 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 != nullptr;
	}

	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];
	bool operator< (const FiosItem &other) const;
};

/** 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()
	{
		/*C++17: return &*/ this->files.emplace_back();
		return &this->files.back();
	}

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

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

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

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

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

	inline const FiosItem &operator[](size_t 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[](size_t 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.shrink_to_fit();
	}

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

	std::vector<FiosItem> 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);

#endif /* FIOS_H */