markdownbuffer.cpp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. #include "markdownbuffer.h"
  2. #include <QDir>
  3. #include <widgets/markdownviewwindow.h>
  4. #include <notebook/node.h>
  5. #include <utils/pathutils.h>
  6. #include <buffer/bufferprovider.h>
  7. using namespace vnotex;
  8. MarkdownBuffer::MarkdownBuffer(const BufferParameters &p_parameters,
  9. QObject *p_parent)
  10. : Buffer(p_parameters, p_parent)
  11. {
  12. fetchInitialImages();
  13. }
  14. ViewWindow *MarkdownBuffer::createViewWindowInternal(const QSharedPointer<FileOpenParameters> &p_paras, QWidget *p_parent)
  15. {
  16. Q_UNUSED(p_paras);
  17. return new MarkdownViewWindow(p_parent);
  18. }
  19. QString MarkdownBuffer::insertImage(const QString &p_srcImagePath, const QString &p_imageFileName)
  20. {
  21. return m_provider->insertImage(p_srcImagePath, p_imageFileName);
  22. }
  23. QString MarkdownBuffer::insertImage(const QImage &p_image, const QString &p_imageFileName)
  24. {
  25. return m_provider->insertImage(p_image, p_imageFileName);
  26. }
  27. void MarkdownBuffer::fetchInitialImages()
  28. {
  29. Q_ASSERT(m_initialImages.isEmpty());
  30. vte::MarkdownLink::TypeFlags linkFlags = vte::MarkdownLink::TypeFlag::LocalRelativeInternal | vte::MarkdownLink::TypeFlag::Remote;
  31. m_initialImages = vte::MarkdownUtils::fetchImagesFromMarkdownText(getContent(),
  32. getResourcePath(),
  33. linkFlags);
  34. }
  35. void MarkdownBuffer::addInsertedImage(const QString &p_imagePath, const QString &p_urlInLink)
  36. {
  37. vte::MarkdownLink link;
  38. link.m_path = p_imagePath;
  39. link.m_urlInLink = p_urlInLink;
  40. // There are two types: local internal and remote for image host.
  41. link.m_type = PathUtils::isLocalFile(p_imagePath) ? vte::MarkdownLink::TypeFlag::LocalRelativeInternal : vte::MarkdownLink::TypeFlag::Remote;
  42. m_insertedImages.append(link);
  43. }
  44. QHash<QString, bool> MarkdownBuffer::clearObsoleteImages()
  45. {
  46. QHash<QString, bool> obsoleteImages;
  47. Q_ASSERT(!isModified());
  48. const bool discarded = state() & StateFlag::Discarded;
  49. const vte::MarkdownLink::TypeFlags linkFlags = vte::MarkdownLink::TypeFlag::LocalRelativeInternal | vte::MarkdownLink::TypeFlag::Remote;
  50. const auto latestImages =
  51. vte::MarkdownUtils::fetchImagesFromMarkdownText(!discarded ? getContent() : m_provider->read(),
  52. getResourcePath(),
  53. linkFlags);
  54. QSet<QString> latestImagesPath;
  55. for (const auto &link : latestImages) {
  56. if (link.m_type & vte::MarkdownLink::TypeFlag::Remote) {
  57. latestImagesPath.insert(link.m_path);
  58. } else {
  59. latestImagesPath.insert(PathUtils::normalizePath(link.m_path));
  60. }
  61. }
  62. for (const auto &link : m_insertedImages) {
  63. if (!(link.m_type & linkFlags)) {
  64. continue;
  65. }
  66. const bool isRemote = link.m_type & vte::MarkdownLink::TypeFlag::Remote;
  67. const auto linkPath = isRemote ? link.m_path : PathUtils::normalizePath(link.m_path);
  68. if (!latestImagesPath.contains(linkPath)) {
  69. obsoleteImages.insert(link.m_path, isRemote);
  70. }
  71. }
  72. m_insertedImages.clear();
  73. for (const auto &link : m_initialImages) {
  74. Q_ASSERT(link.m_type & linkFlags);
  75. const bool isRemote = link.m_type & vte::MarkdownLink::TypeFlag::Remote;
  76. const auto linkPath = isRemote ? link.m_path : PathUtils::normalizePath(link.m_path);
  77. if (!latestImagesPath.contains(linkPath)) {
  78. obsoleteImages.insert(link.m_path, isRemote);
  79. }
  80. }
  81. m_initialImages = latestImages;
  82. return obsoleteImages;
  83. }
  84. void MarkdownBuffer::removeImage(const QString &p_imagePath)
  85. {
  86. qDebug() << "remove obsolete image" << p_imagePath;
  87. m_provider->removeImage(p_imagePath);
  88. }