edn/sources/appl/BufferManager.hpp

103 lines
3.2 KiB
C++
Raw Permalink Normal View History

2016-05-02 22:01:55 +02:00
/** @file
* @author Edouard DUPIN
* @copyright 2010, Edouard DUPIN, all right reserved
* @license GPL v3 (see license file)
*/
2016-05-02 22:01:55 +02:00
#pragma once
2016-10-03 22:01:55 +02:00
#include <appl/Buffer.hpp>
#include <appl/globalMsg.hpp>
#include <ewol/widget/Widget.hpp>
#include <gale/resource/Resource.hpp>
namespace appl {
class BufferManager;
using BufferManagerShared = ememory::SharedPtr<appl::BufferManager>;
using BufferManagerWeak = ememory::WeakPtr<appl::BufferManager>;
// TODO: This is a service ...
class BufferManager : public ewol::Object {
2018-09-29 21:59:06 +02:00
public:
esignal::Signal<ememory::SharedPtr<appl::Buffer>> signalNewBuffer;
esignal::Signal<ememory::SharedPtr<appl::Buffer>> signalSelectFile;
2016-08-04 22:23:19 +02:00
esignal::Signal<> signalTextSelectionChange;
esignal::Signal<ememory::SharedPtr<appl::Buffer>> signalRemoveBuffer;
protected:
BufferManager();
2014-05-20 21:35:41 +02:00
public:
2018-08-24 23:56:19 +02:00
DECLARE_SINGLE_FACTORY(BufferManager, "???BufferManager???");
virtual ~BufferManager();
2013-10-29 21:13:45 +01:00
private:
2017-10-09 10:25:41 +02:00
etk::Vector<ememory::SharedPtr<appl::Buffer>> m_list; // list of all buffer curently open
public:
2013-10-29 21:13:45 +01:00
/**
* @brief Get a specific buffer with his name (can create a new buffer).
* @param[in] _fileName Name of the file to open.
* @param[in] _createIfNeeded Create the buffer if not existed.
* @return a pointer on the buffer
*/
2018-09-29 21:59:06 +02:00
ememory::SharedPtr<appl::Buffer> get(const etk::Path& _fileName, bool _createIfNeeded=false);
2013-10-29 21:13:45 +01:00
/**
* @brief Load a specific file, event if it not existed:
* @param[in] _fileName Name of the file to open or create.
*/
2018-09-29 21:59:06 +02:00
void open(const etk::Path& _fileName);
/**
* @brief Check if a buffer is already open.
* @param[in] _fileName name of the file.
* @return true if the buffer is already open.
*/
2018-09-29 21:59:06 +02:00
bool exist(const etk::Path& _fileName);
2013-11-07 21:08:57 +01:00
/**
* @brief Get count of all buffer availlable.
* @return Number of buffer
*/
int32_t size() const {
2013-11-07 21:08:57 +01:00
return m_list.size();
}
/**
* @brief Get a pointer on a buffer Id (never remember this ID!!!).
* @param[in] _id Number of buffer
* @return pointer on the buffer
*/
2016-07-19 22:03:39 +02:00
ememory::SharedPtr<appl::Buffer> get(int32_t _id);
/**
* @brief Create a new buffer empty.
2018-06-19 22:31:29 +02:00
* @return Created buffer or null.
*/
2016-07-19 22:03:39 +02:00
ememory::SharedPtr<appl::Buffer> createNewBuffer();
2013-11-07 21:08:57 +01:00
private:
2016-07-19 22:03:39 +02:00
ememory::SharedPtr<appl::Buffer> m_bufferSelected;
2013-11-07 21:08:57 +01:00
public:
/**
* @brief Set the current buffer selected
* @param[in] _bufferSelected Pointer on the buffer selected
*/
2016-07-19 22:03:39 +02:00
void setBufferSelected(ememory::SharedPtr<appl::Buffer> _bufferSelected);
2013-11-07 21:08:57 +01:00
/**
* @brief Get the current buffer selected
* @return Pointer on the buffer selected
*/
2016-07-19 22:03:39 +02:00
ememory::SharedPtr<appl::Buffer> getBufferSelected() {
2013-11-07 21:08:57 +01:00
return m_bufferSelected;
};
private:
2016-07-19 22:03:39 +02:00
void requestDestroyFromChild(const ememory::SharedPtr<Object>& _child);
2014-10-23 23:52:19 +02:00
public:
// generic iterators:
2017-10-09 10:25:41 +02:00
const etk::Vector<ememory::SharedPtr<appl::Buffer>>::Iterator begin() const {
2014-10-23 23:52:19 +02:00
return m_list.begin();
}
2017-10-09 10:25:41 +02:00
const etk::Vector<ememory::SharedPtr<appl::Buffer>>::Iterator end() const {
2016-07-19 22:03:39 +02:00
return m_list.end();
}
2017-10-09 10:25:41 +02:00
etk::Vector<ememory::SharedPtr<appl::Buffer>>::Iterator begin() {
2016-07-19 22:03:39 +02:00
return m_list.begin();
}
2017-10-09 10:25:41 +02:00
etk::Vector<ememory::SharedPtr<appl::Buffer>>::Iterator end() {
2014-10-23 23:52:19 +02:00
return m_list.end();
}
};
2016-05-02 22:01:55 +02:00
}