undo-stack-obs.cpp 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. #include "undo-stack-obs.hpp"
  2. #include <util/util.hpp>
  3. #define MAX_STACK_SIZE 5000
  4. undo_stack::undo_stack(ui_ptr ui) : ui(ui) {}
  5. void undo_stack::release()
  6. {
  7. for (auto f : undo_items)
  8. if (f.d)
  9. f.d(true);
  10. for (auto f : redo_items)
  11. if (f.d)
  12. f.d(false);
  13. }
  14. void undo_stack::clear()
  15. {
  16. release();
  17. undo_items.clear();
  18. redo_items.clear();
  19. ui->actionMainUndo->setText(QTStr("Undo.Undo"));
  20. ui->actionMainRedo->setText(QTStr("Undo.Redo"));
  21. ui->actionMainUndo->setDisabled(true);
  22. ui->actionMainRedo->setDisabled(true);
  23. }
  24. void undo_stack::add_action(const QString &name, undo_redo_cb undo,
  25. undo_redo_cb redo, std::string undo_data,
  26. std::string redo_data, func d)
  27. {
  28. while (undo_items.size() >= MAX_STACK_SIZE) {
  29. undo_redo_t item = undo_items.back();
  30. if (item.d)
  31. item.d(true);
  32. undo_items.pop_back();
  33. }
  34. undo_redo_t n = {name, undo_data, redo_data, undo, redo, d};
  35. undo_items.push_front(n);
  36. clear_redo();
  37. ui->actionMainUndo->setText(QTStr("Undo.Item.Undo").arg(name));
  38. ui->actionMainUndo->setEnabled(true);
  39. ui->actionMainRedo->setText(QTStr("Undo.Redo"));
  40. ui->actionMainRedo->setDisabled(true);
  41. }
  42. void undo_stack::undo()
  43. {
  44. if (undo_items.size() == 0 || disabled)
  45. return;
  46. undo_redo_t temp = undo_items.front();
  47. temp.undo(temp.undo_data);
  48. redo_items.push_front(temp);
  49. undo_items.pop_front();
  50. ui->actionMainRedo->setText(QTStr("Undo.Item.Redo").arg(temp.name));
  51. ui->actionMainRedo->setEnabled(true);
  52. if (undo_items.size() == 0) {
  53. ui->actionMainUndo->setDisabled(true);
  54. ui->actionMainUndo->setText(QTStr("Undo.Undo"));
  55. } else {
  56. ui->actionMainUndo->setText(
  57. QTStr("Undo.Item.Undo").arg(undo_items.front().name));
  58. }
  59. }
  60. void undo_stack::redo()
  61. {
  62. if (redo_items.size() == 0 || disabled)
  63. return;
  64. undo_redo_t temp = redo_items.front();
  65. temp.redo(temp.redo_data);
  66. undo_items.push_front(temp);
  67. redo_items.pop_front();
  68. ui->actionMainUndo->setText(QTStr("Undo.Item.Undo").arg(temp.name));
  69. ui->actionMainUndo->setEnabled(true);
  70. if (redo_items.size() == 0) {
  71. ui->actionMainRedo->setDisabled(true);
  72. ui->actionMainRedo->setText(QTStr("Undo.Redo"));
  73. } else {
  74. ui->actionMainRedo->setText(
  75. QTStr("Undo.Item.Redo").arg(redo_items.front().name));
  76. }
  77. }
  78. void undo_stack::enable_undo_redo()
  79. {
  80. disabled = false;
  81. ui->actionMainUndo->setDisabled(false);
  82. ui->actionMainRedo->setDisabled(false);
  83. }
  84. void undo_stack::disable_undo_redo()
  85. {
  86. disabled = true;
  87. ui->actionMainUndo->setDisabled(true);
  88. ui->actionMainRedo->setDisabled(true);
  89. }
  90. void undo_stack::clear_redo()
  91. {
  92. for (auto f : redo_items)
  93. if (f.d)
  94. f.d(false);
  95. redo_items.clear();
  96. }