本文整理汇总了C++中models::ArtworkMetadata类的典型用法代码示例。如果您正苦于以下问题:C++ ArtworkMetadata类的具体用法?C++ ArtworkMetadata怎么用?C++ ArtworkMetadata使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了ArtworkMetadata类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: afterImportHandler
void MetadataIOCoordinator::afterImportHandler(const QVector<Models::ArtworkMetadata*> &itemsToRead, bool ignoreBackups) {
Models::SettingsModel *settingsModel = m_CommandManager->getSettingsModel();
const QHash<QString, ImportDataResult> &importResult = m_ReadingWorker->getImportResult();
const QVector<QPair<int, int> > &rangesToUpdate = m_ReadingWorker->getRangesToUpdate();
if (!ignoreBackups && settingsModel->getSaveBackups()) {
LOG_DEBUG << "Restoring the backups...";
int size = itemsToRead.size();
for (int i = 0; i < size; ++i) {
Models::ArtworkMetadata *metadata = itemsToRead.at(i);
const QString &filepath = metadata->getFilepath();
if (importResult.contains(filepath)) {
const ImportDataResult &importResultItem = importResult.value(filepath);
MetadataSavingCopy copy(importResultItem.BackupDict);
copy.saveToMetadata(metadata);
}
}
} else {
LOG_DEBUG << "Skipped restoring the backups";
}
if (!getHasErrors()) {
m_CommandManager->addToLibrary(itemsToRead);
}
m_CommandManager->updateArtworks(rangesToUpdate);
m_CommandManager->submitForSpellCheck(itemsToRead);
m_CommandManager->submitForWarningsCheck(itemsToRead);
}
示例2: readingFinishedHandler
void MetadataIOCoordinator::readingFinishedHandler(bool ignoreBackups) {
Q_ASSERT(m_CanProcessResults);
m_CanProcessResults = false;
const QHash<QString, ImportDataResult> &importResult = m_ReadingWorker->getImportResult();
const QVector<Models::ArtworkMetadata*> &itemsToRead = m_ReadingWorker->getArtworksToImport();
qDebug() << "Setting imported metadata...";
int size = itemsToRead.size();
for (int i = 0; i < size; ++i) {
Models::ArtworkMetadata *metadata = itemsToRead.at(i);
const QString &filepath = metadata->getFilepath();
if (importResult.contains(filepath)) {
const ImportDataResult &importResultItem = importResult.value(filepath);
metadata->initialize(importResultItem.Title,
importResultItem.Description,
importResultItem.Keywords);
metadata->setSize(importResultItem.Size);
}
}
afterImportHandler(itemsToRead, ignoreBackups);
qDebug() << "Metadata import finished";
emit metadataReadingFinished();
}
示例3: filterDescriptionTest
void FilteredModelTests::filterDescriptionTest() {
DECLARE_MODELS_AND_GENERATE(10);
Models::SettingsModel settingsModel;
settingsModel.setSearchUsingAnd(false);
commandManagerMock.InjectDependency(&settingsModel);
for (int i = 0; i < 10; ++i) {
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(i);
if (i % 2) {
metadata->initialize("title", "description", QStringList() << "keyword1" << "keyword2");
} else {
metadata->initialize("", "", QStringList());
}
}
filteredItemsModel.setSearchTerm("desc");
QCOMPARE(filteredItemsModel.getItemsCount(), 5);
filteredItemsModel.setSearchTerm("!desc");
QCOMPARE(filteredItemsModel.getItemsCount(), 0);
filteredItemsModel.setSearchTerm("description");
QCOMPARE(filteredItemsModel.getItemsCount(), 5);
// strict match does not work for description/title
filteredItemsModel.setSearchTerm("!description");
QCOMPARE(filteredItemsModel.getItemsCount(), 0);
}
示例4: filterTitleAndKeywordsTest
void FilteredModelTests::filterTitleAndKeywordsTest() {
DECLARE_MODELS_AND_GENERATE(10);
Models::SettingsModel settingsModel;
settingsModel.setSearchUsingAnd(false);
commandManagerMock.InjectDependency(&settingsModel);
for (int i = 0; i < 10; ++i) {
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(i);
if (i % 2 == 0) {
metadata->initialize("title", "description", QStringList() << "keyword1" << "mess1");
} else {
metadata->initialize("title", "description", QStringList() << "keyword2" << "mess2");
}
}
filteredItemsModel.setSearchTerm("keyword1 tit");
QCOMPARE(filteredItemsModel.getItemsCount(), 10);
filteredItemsModel.setSearchTerm("!keyword tit");
QCOMPARE(filteredItemsModel.getItemsCount(), 10);
settingsModel.setSearchUsingAnd(true);
filteredItemsModel.setSearchTerm("!keyword tit");
QCOMPARE(filteredItemsModel.getItemsCount(), 0);
filteredItemsModel.setSearchTerm("!keyword2 title");
QCOMPARE(filteredItemsModel.getItemsCount(), 5);
}
示例5: readingFinishedHandler
void MetadataIOCoordinator::readingFinishedHandler(bool ignoreBackups) {
Q_ASSERT(m_CanProcessResults);
m_CanProcessResults = false;
const QHash<QString, ImportDataResult> &importResult = m_ReadingWorker->getImportResult();
const QVector<Models::ArtworkMetadata*> &itemsToRead = m_ReadingWorker->getItemsToRead();
LOG_DEBUG << "Setting imported metadata...";
int size = itemsToRead.size();
for (int i = 0; i < size; ++i) {
Models::ArtworkMetadata *metadata = itemsToRead.at(i);
const QString &filepath = metadata->getFilepath();
if (importResult.contains(filepath)) {
const ImportDataResult &importResultItem = importResult.value(filepath);
metadata->initialize(importResultItem.Title,
importResultItem.Description,
importResultItem.Keywords);
Models::ImageArtwork *image = dynamic_cast<Models::ImageArtwork*>(metadata);
if (image != NULL) {
image->setImageSize(importResultItem.ImageSize);
image->setDateTimeOriginal(importResultItem.DateTimeOriginal);
}
metadata->setFileSize(importResultItem.FileSize);
}
}
afterImportHandler(itemsToRead, ignoreBackups);
LOG_DEBUG << "Metadata import finished";
emit metadataReadingFinished();
}
示例6: finished
void Exiv2ReadingWorker::process() {
LOG_DEBUG << "Worker #" << m_WorkerIndex << "started";
bool anyError = false;
int size = m_ItemsToRead.size();
for (int i = 0; i < size; ++i) {
if (m_Stopped) { break; }
Models::ArtworkMetadata *artwork = m_ItemsToRead.at(i);
const QString &filepath = artwork->getFilepath();
ImportDataResult importResult;
try {
if (readMetadata(artwork, importResult)) {
Q_ASSERT(!m_ImportResult.contains(filepath));
m_ImportResult.insert(filepath, importResult);
}
}
catch(Exiv2::Error &error) {
anyError = true;
LOG_WARNING << "Worker" << m_WorkerIndex << "Exiv2 error:" << error.what();
}
catch(...) {
anyError = true;
LOG_WARNING << "Worker" << m_WorkerIndex << "Reading error for item" << filepath;
}
}
LOG_INFO << "Worker #" << m_WorkerIndex << "finished";
emit finished(anyError);
}
示例7: clearEmptyKeywordsTest
void FilteredModelTests::clearEmptyKeywordsTest() {
DECLARE_MODELS_AND_GENERATE(1);
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(0);
metadata->clearKeywords();
commandManagerMock.resetAnyCommandProcessed();
filteredItemsModel.clearKeywords(0);
QVERIFY(!commandManagerMock.anyCommandProcessed());
}
示例8: removeMetadataMarksAsModifiedTest
void FilteredModelTests::removeMetadataMarksAsModifiedTest() {
DECLARE_MODELS_AND_GENERATE(1);
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(0);
QVERIFY(!metadata->isModified());
metadata->setIsSelected(true);
filteredItemsModel.removeMetadataInSelected();
QVERIFY(metadata->isModified());
}
示例9:
void Commands::CommandManager::submitForSpellCheck(const QVector<Models::ArtworkMetadata *> &items) const {
if ((m_SettingsModel != NULL) &&
m_SettingsModel->getUseSpellCheck() &&
(m_SpellCheckerService != NULL) &&
!items.isEmpty()) {
QVector<Common::BasicKeywordsModel *> itemsToSubmit;
int count = items.length();
itemsToSubmit.reserve(count);
for (int i = 0; i < count; ++i) {
Models::ArtworkMetadata *metadata = items.at(i);
itemsToSubmit << metadata->getBasicModel();
}
this->submitForSpellCheck(itemsToSubmit);
}
}
示例10: caseSensitiveTest
void ReplaceTests::caseSensitiveTest() {
const int itemsToGenerate = 10;
DECLARE_MODELS_AND_GENERATE(itemsToGenerate);
QString replaceFrom = "rePLace";
QString replaceTo = "Replaced";
QString initString = "ReplaceMe";
QString finalString = "ReplacedMe";
auto flags = Common::SearchFlags::Description |
Common::SearchFlags::Title |
Common::SearchFlags::Keywords;
for (int i = 0; i < itemsToGenerate; i++) {
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(i);
metadata->initialize(initString, initString, QStringList() << initString);
}
auto artWorksInfo = filteredItemsModel.getSearchablePreviewOriginalItems(replaceFrom, flags);
std::shared_ptr<Commands::FindAndReplaceCommand> replaceCommand(
new Commands::FindAndReplaceCommand(artWorksInfo, replaceFrom, replaceTo, flags));
auto result = commandManagerMock.processCommand(replaceCommand);
for (int i = 0; i < itemsToGenerate; i++) {
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(i);
QCOMPARE(metadata->getDescription(), finalString);
QCOMPARE(metadata->getTitle(), finalString);
QCOMPARE(metadata->getKeywords()[0], finalString);
QVERIFY(metadata->isModified());
}
}
示例11: setSelectedForZippingTest
void FilteredModelTests::setSelectedForZippingTest() {
DECLARE_MODELS_AND_GENERATE(10);
Models::ZipArchiver zipArchiver;
commandManagerMock.InjectDependency(&zipArchiver);
for (int i = 0; i < 10; ++i) {
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(i);
metadata->initialize("title", "description", QStringList() << "keyword1" << "keyword2");
if (i % 2) {
metadata->setIsSelected(true);
}
}
filteredItemsModel.setSelectedForZipping();
const QVector<Models::ArtworkMetadata*> &artworks = zipArchiver.getArtworkList();
QCOMPARE(artworks.length(), 5);
}
示例12: removeMetadataDeletesMetadataTest
void FilteredModelTests::removeMetadataDeletesMetadataTest() {
DECLARE_MODELS_AND_GENERATE(10);
for (int i = 0; i < 10; ++i) {
Models::ArtworkMetadata *metadata = artItemsModelMock.getArtwork(i);
metadata->initialize("title", "description", QStringList() << "keyword1" << "keyword2");
metadata->setIsSelected(true);
}
filteredItemsModel.removeMetadataInSelected();
for (int i = 0; i < 10; ++i) {
Mocks::ArtworkMetadataMock *metadata = artItemsModelMock.getMockArtwork(i);
QVERIFY(metadata->isDescriptionEmpty());
QVERIFY(metadata->isTitleEmpty());
QVERIFY(metadata->areKeywordsEmpty());
QVERIFY(metadata->isModified());
}
}
示例13: modifyArtworksItem
std::shared_ptr<Commands::ICommandResult> Commands::PasteKeywordsCommand::execute(const ICommandManager *commandManagerInterface) const {
LOG_INFO << "Pasting" << m_KeywordsList.length() << "keywords to" << m_MetadataElements.size() << "item(s)";
CommandManager *commandManager = (CommandManager*)commandManagerInterface;
QVector<int> indicesToUpdate;
std::vector<UndoRedo::ArtworkMetadataBackup> artworksBackups;
QVector<Models::ArtworkMetadata*> itemsToSave;
size_t size = m_MetadataElements.size();
indicesToUpdate.reserve((int)size);
artworksBackups.reserve(size);
itemsToSave.reserve((int)size);
for (size_t i = 0; i < size; ++i) {
const Models::MetadataElement &element = m_MetadataElements.at(i);
Models::ArtworkMetadata *metadata = element.getOrigin();
indicesToUpdate.append(element.getOriginalIndex());
artworksBackups.emplace_back(metadata);
metadata->appendKeywords(m_KeywordsList);
itemsToSave.append(metadata);
}
if (size > 0) {
commandManager->submitForSpellCheck(itemsToSave);
commandManager->submitForWarningsCheck(itemsToSave);
commandManager->saveArtworksBackups(itemsToSave);
std::unique_ptr<UndoRedo::IHistoryItem> modifyArtworksItem(new UndoRedo::ModifyArtworksHistoryItem(artworksBackups, indicesToUpdate,
UndoRedo::PasteModificationType));
commandManager->recordHistoryItem(modifyArtworksItem);
} else {
LOG_WARNING << "Pasted zero real words!";
}
std::shared_ptr<PasteKeywordsCommandResult> result(new PasteKeywordsCommandResult(indicesToUpdate));
return result;
}
示例14: filterAcceptsRow
bool WarningsModel::filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const {
Q_UNUSED(sourceParent);
QAbstractItemModel *sourceItemModel = sourceModel();
Models::ArtItemsModel *artItemsModel = dynamic_cast<Models::ArtItemsModel *>(sourceItemModel);
Q_ASSERT(artItemsModel != NULL);
Models::ArtworkMetadata *metadata = artItemsModel->getArtwork(sourceRow);
bool rowIsOk = false;
if (metadata != NULL) {
Common::WarningFlags warningsFlags = metadata->getWarningsFlags();
bool anyWarnings = warningsFlags != Common::WarningFlags::None;
rowIsOk = anyWarnings;
if (m_ShowOnlySelected) {
rowIsOk = metadata->isSelected() && anyWarnings;
}
}
return rowIsOk;
}
示例15: continueWithoutReading
void MetadataIOCoordinator::continueWithoutReading() {
LOG_DEBUG << "Setting technical data";
const QHash<QString, ImportDataResult> &importResult = m_ReadingWorker->getImportResult();
const QVector<Models::ArtworkMetadata*> &itemsToRead = m_ReadingWorker->getItemsToRead();
int size = itemsToRead.size();
for (int i = 0; i < size; ++i) {
Models::ArtworkMetadata *metadata = itemsToRead.at(i);
const QString &filepath = metadata->getFilepath();
if (importResult.contains(filepath)) {
const ImportDataResult &importResultItem = importResult.value(filepath);
Models::ImageArtwork *image = dynamic_cast<Models::ImageArtwork*>(metadata);
if (image != NULL) {
image->setImageSize(importResultItem.ImageSize);
image->setDateTimeOriginal(importResultItem.DateTimeOriginal);
}
metadata->setFileSize(importResultItem.FileSize);
}
}
}