mirror of https://github.com/procxx/kepka.git
				
				
				
			Fix build for Xcode.
Also guard database compactor so that it won't work after closing.
This commit is contained in:
		
							parent
							
								
									08ff324b1b
								
							
						
					
					
						commit
						8210a51fdc
					
				|  | @ -129,7 +129,6 @@ private: | |||
| 	base::binary_guard _running; | ||||
| 	TimeMs _next = 0; | ||||
| 	int _timeout = 0; | ||||
| 	int _timerId = 0; | ||||
| 
 | ||||
| 	Qt::TimerType _type : 2; | ||||
| 	bool _adjusted : 1; | ||||
|  |  | |||
|  | @ -22,6 +22,7 @@ public: | |||
| 	CompactorObject( | ||||
| 		crl::weak_on_queue<CompactorObject> weak, | ||||
| 		crl::weak_on_queue<DatabaseObject> database, | ||||
| 		base::binary_guard guard, | ||||
| 		const QString &base, | ||||
| 		const Settings &settings, | ||||
| 		EncryptionKey &&key, | ||||
|  | @ -64,6 +65,7 @@ private: | |||
| 
 | ||||
| 	crl::weak_on_queue<CompactorObject> _weak; | ||||
| 	crl::weak_on_queue<DatabaseObject> _database; | ||||
| 	base::binary_guard _guard; | ||||
| 	QString _base; | ||||
| 	Settings _settings; | ||||
| 	EncryptionKey _key; | ||||
|  | @ -83,12 +85,14 @@ private: | |||
| CompactorObject::CompactorObject( | ||||
| 	crl::weak_on_queue<CompactorObject> weak, | ||||
| 	crl::weak_on_queue<DatabaseObject> database, | ||||
| 	base::binary_guard guard, | ||||
| 	const QString &base, | ||||
| 	const Settings &settings, | ||||
| 	EncryptionKey &&key, | ||||
| 	const Info &info) | ||||
| : _weak(std::move(weak)) | ||||
| , _database(std::move(database)) | ||||
| , _guard(std::move(guard)) | ||||
| , _base(base) | ||||
| , _settings(settings) | ||||
| , _key(std::move(key)) | ||||
|  | @ -170,8 +174,10 @@ void CompactorObject::fail() { | |||
| 
 | ||||
| void CompactorObject::done(int64 till) { | ||||
| 	const auto path = compactPath(); | ||||
| 	_database.with([=](DatabaseObject &database) { | ||||
| 	_database.with([=, good = std::move(_guard)](DatabaseObject &database) { | ||||
| 		if (good.alive()) { | ||||
| 			database.compactorDone(path, till); | ||||
| 		} | ||||
| 	}); | ||||
| } | ||||
| 
 | ||||
|  | @ -354,7 +360,7 @@ void CompactorObject::addListRecord( | |||
| 	} | ||||
| 	auto record = RecordStore(); | ||||
| 	record.key = raw.first; | ||||
| 	record.size = ReadTo<EntrySize>(raw.second.size); | ||||
| 	record.setSize(raw.second.size); | ||||
| 	record.checksum = raw.second.checksum; | ||||
| 	record.tag = raw.second.tag; | ||||
| 	record.place = raw.second.place; | ||||
|  | @ -367,11 +373,18 @@ void CompactorObject::addListRecord( | |||
| 
 | ||||
| Compactor::Compactor( | ||||
| 	crl::weak_on_queue<DatabaseObject> database, | ||||
| 	base::binary_guard guard, | ||||
| 	const QString &base, | ||||
| 	const Settings &settings, | ||||
| 	EncryptionKey &&key, | ||||
| 	const Info &info) | ||||
| : _wrapped(std::move(database), base, settings, std::move(key), info) { | ||||
| : _wrapped( | ||||
| 	std::move(database), | ||||
| 	std::move(guard), | ||||
| 	base, | ||||
| 	settings, | ||||
| 	std::move(key), | ||||
| 	info) { | ||||
| } | ||||
| 
 | ||||
| Compactor::~Compactor() = default; | ||||
|  |  | |||
|  | @ -9,6 +9,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL | |||
| 
 | ||||
| #include "storage/cache/storage_cache_types.h" | ||||
| #include <crl/crl_object_on_queue.h> | ||||
| #include <base/binary_guard.h> | ||||
| 
 | ||||
| namespace Storage { | ||||
| class EncryptionKey; | ||||
|  | @ -28,6 +29,7 @@ public: | |||
| 
 | ||||
| 	Compactor( | ||||
| 		crl::weak_on_queue<DatabaseObject> database, | ||||
| 		base::binary_guard guard, | ||||
| 		const QString &base, | ||||
| 		const Settings &settings, | ||||
| 		EncryptionKey &&key, | ||||
|  |  | |||
|  | @ -69,8 +69,8 @@ DatabaseObject::Entry::Entry( | |||
| : useTime(useTime) | ||||
| , size(size) | ||||
| , checksum(checksum) | ||||
| , tag(tag) | ||||
| , place(place) { | ||||
| , place(place) | ||||
| , tag(tag) { | ||||
| } | ||||
| 
 | ||||
| DatabaseObject::DatabaseObject( | ||||
|  | @ -488,7 +488,7 @@ template <typename Record, typename Postprocess> | |||
| bool DatabaseObject::processRecordStoreGeneric( | ||||
| 		const Record *record, | ||||
| 		Postprocess &&postprocess) { | ||||
| 	const auto size = ReadFrom(record->size); | ||||
| 	const auto size = record->getSize(); | ||||
| 	if (size <= 0 || size > _settings.maxDataSize) { | ||||
| 		return false; | ||||
| 	} | ||||
|  | @ -738,6 +738,7 @@ void DatabaseObject::clearState() { | |||
| 	_map = {}; | ||||
| 	_removing = {}; | ||||
| 	_accessed = {}; | ||||
| 	_stale = {}; | ||||
| 	_time = {}; | ||||
| 	_binlogExcessLength = 0; | ||||
| 	_totalSize = 0; | ||||
|  | @ -747,7 +748,6 @@ void DatabaseObject::clearState() { | |||
| 	_pushingStats = false; | ||||
| 	_writeBundlesTimer.cancel(); | ||||
| 	_pruneTimer.cancel(); | ||||
| 	_cleaner = CleanerWrap(); | ||||
| 	_compactor = CompactorWrap(); | ||||
| } | ||||
| 
 | ||||
|  | @ -816,7 +816,7 @@ base::optional<QString> DatabaseObject::writeKeyPlaceGeneric( | |||
| 	const auto size = size_type(value.bytes.size()); | ||||
| 	record.tag = value.tag; | ||||
| 	record.key = key; | ||||
| 	record.size = ReadTo<EntrySize>(size); | ||||
| 	record.setSize(size); | ||||
| 	record.checksum = checksum; | ||||
| 	if (const auto i = _map.find(key); i != end(_map)) { | ||||
| 		const auto &already = i->second; | ||||
|  | @ -876,7 +876,7 @@ Error DatabaseObject::writeExistingPlaceGeneric( | |||
| 		const Entry &entry) { | ||||
| 	record.key = key; | ||||
| 	record.tag = entry.tag; | ||||
| 	record.size = ReadTo<EntrySize>(entry.size); | ||||
| 	record.setSize(entry.size); | ||||
| 	record.checksum = entry.checksum; | ||||
| 	if (const auto i = _map.find(key); i != end(_map)) { | ||||
| 		const auto &already = i->second; | ||||
|  | @ -1187,8 +1187,11 @@ void DatabaseObject::checkCompactor() { | |||
| 	info.till = _binlog.size(); | ||||
| 	info.systemTime = _time.system; | ||||
| 	info.keysCount = _map.size(); | ||||
| 	auto [first, second] = base::make_binary_guard(); | ||||
| 	_compactor.guard = std::move(first); | ||||
| 	_compactor.object = std::make_unique<Compactor>( | ||||
| 		_weak, | ||||
| 		std::move(second), | ||||
| 		_path, | ||||
| 		_settings, | ||||
| 		base::duplicate(_key), | ||||
|  |  | |||
|  | @ -96,6 +96,7 @@ private: | |||
| 		int64 excessLength = 0; | ||||
| 		crl::time_type nextAttempt = 0; | ||||
| 		crl::time_type delayAfterFailure = 10 * crl::time_type(1000); | ||||
| 		base::binary_guard guard; | ||||
| 	}; | ||||
| 	using Map = std::unordered_map<Key, Entry>; | ||||
| 
 | ||||
|  |  | |||
|  | @ -12,6 +12,37 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL | |||
| namespace Storage { | ||||
| namespace Cache { | ||||
| namespace details { | ||||
| namespace { | ||||
| 
 | ||||
| template <typename Packed> | ||||
| inline Packed ReadTo(size_type count) { | ||||
| 	Expects(count >= 0 && count < (1 << (Packed().size() * 8))); | ||||
| 
 | ||||
| 	auto result = Packed(); | ||||
| 	for (auto &element : result) { | ||||
| 		element = uint8(count & 0xFF); | ||||
| 		count >>= 8; | ||||
| 	} | ||||
| 	return result; | ||||
| } | ||||
| 
 | ||||
| template <typename Packed> | ||||
| inline size_type ReadFrom(const Packed &count) { | ||||
| 	auto result = size_type(); | ||||
| 	for (auto &element : (count | ranges::view::reverse)) { | ||||
| 		result <<= 8; | ||||
| 		result |= size_type(element); | ||||
| 	} | ||||
| 	return result; | ||||
| } | ||||
| 
 | ||||
| template <typename Packed> | ||||
| inline size_type ValidateStrictCount(const Packed &count) { | ||||
| 	const auto result = ReadFrom(count); | ||||
| 	return (result != 0) ? result : -1; | ||||
| } | ||||
| 
 | ||||
| } // namespace
 | ||||
| 
 | ||||
| TaggedValue::TaggedValue(QByteArray &&bytes, uint8 tag) | ||||
| : bytes(std::move(bytes)), tag(tag) { | ||||
|  | @ -61,6 +92,14 @@ BasicHeader::BasicHeader() | |||
| , flags(0) { | ||||
| } | ||||
| 
 | ||||
| void Store::setSize(size_type size) { | ||||
| 	this->size = ReadTo<EntrySize>(size); | ||||
| } | ||||
| 
 | ||||
| size_type Store::getSize() const { | ||||
| 	return ReadFrom(size); | ||||
| } | ||||
| 
 | ||||
| MultiStore::MultiStore(size_type count) | ||||
| : type(kType) | ||||
| , count(ReadTo<RecordsCount>(count)) { | ||||
|  |  | |||
|  | @ -101,34 +101,6 @@ using PlaceId = std::array<uint8, 7>; | |||
| using EntrySize = std::array<uint8, 3>; | ||||
| using RecordsCount = std::array<uint8, 3>; | ||||
| 
 | ||||
| template <typename Packed> | ||||
| inline Packed ReadTo(size_type count) { | ||||
| 	Expects(count >= 0 && count < (1 << (Packed().size() * 8))); | ||||
| 
 | ||||
| 	auto result = Packed(); | ||||
| 	for (auto &element : result) { | ||||
| 		element = uint8(count & 0xFF); | ||||
| 		count >>= 8; | ||||
| 	} | ||||
| 	return result; | ||||
| } | ||||
| 
 | ||||
| template <typename Packed> | ||||
| inline size_type ReadFrom(const Packed &count) { | ||||
| 	auto result = size_type(); | ||||
| 	for (auto &element : (count | ranges::view::reverse)) { | ||||
| 		result <<= 8; | ||||
| 		result |= size_type(element); | ||||
| 	} | ||||
| 	return result; | ||||
| } | ||||
| 
 | ||||
| template <typename Packed> | ||||
| inline size_type ValidateStrictCount(const Packed &count) { | ||||
| 	const auto result = ReadFrom(count); | ||||
| 	return (result != 0) ? result : -1; | ||||
| } | ||||
| 
 | ||||
| constexpr auto kRecordSizeUnknown = size_type(-1); | ||||
| constexpr auto kRecordSizeInvalid = size_type(-2); | ||||
| constexpr auto kBundledRecordsLimit = (1 << (RecordsCount().size() * 8)); | ||||
|  | @ -170,6 +142,9 @@ struct EstimatedTimePoint { | |||
| struct Store { | ||||
| 	static constexpr auto kType = RecordType(0x01); | ||||
| 
 | ||||
| 	void setSize(size_type size); | ||||
| 	size_type getSize() const; | ||||
| 
 | ||||
| 	RecordType type = kType; | ||||
| 	uint8 tag = 0; | ||||
| 	EntrySize size = { { 0 } }; | ||||
|  |  | |||
|  | @ -14,8 +14,8 @@ namespace Storage { | |||
| DatabasePointer::DatabasePointer( | ||||
| 	not_null<Databases*> owner, | ||||
| 	const std::unique_ptr<Cache::Database> &value) | ||||
| : _owner(owner) | ||||
| , _value(value.get()) { | ||||
| : _value(value.get()) | ||||
| , _owner(owner) { | ||||
| } | ||||
| 
 | ||||
| DatabasePointer::DatabasePointer(DatabasePointer &&other) | ||||
|  | @ -83,7 +83,9 @@ DatabasePointer Databases::get( | |||
| } | ||||
| 
 | ||||
| void Databases::destroy(Cache::Database *database) { | ||||
| 	for (auto &[path, kept] : _map) { | ||||
| 	for (auto &entry : _map) { | ||||
| 		const auto &path = entry.first; // Need to capture it in lambda.
 | ||||
| 		auto &kept = entry.second; | ||||
| 		if (kept.database.get() == database) { | ||||
| 			Assert(!kept.destroying.alive()); | ||||
| 			auto [first, second] = base::make_binary_guard(); | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue