#include <string>
#include <map>
#include <memory>
-//#include <experimental/optional>
-#include "windowmanager-client.hpp"
+#include <mutex>
+#include "wm_client.hpp"
#include "request.hpp"
+#include "wm_error.hpp"
-namespace wm {
+namespace wm
+{
/* using std::experimental::nullopt;
using std::experimental::optional; */
-class AppList {
-public:
+class AppList
+{
+ public:
AppList();
virtual ~AppList();
AppList(const AppList &obj) = delete;
// Client Database Interface
- void addClient(const std::string &appid, const std::string &role);
+ /* TODO: consider, which is better WMClient as parameter or not
+ If the WMClient should be more flexible, I think this param should be WMClient class
+ */
+ void addClient(const std::string &appid, unsigned layer, unsigned surface, const std::string &role);
void removeClient(const std::string &appid);
- bool contains(const std::string &appid);
- int countClient();
+ bool contains(const std::string &appid) const;
+ int countClient() const;
std::shared_ptr<WMClient> lookUpClient(const std::string &appid);
+ void removeSurface(unsigned surface);
+ std::string getAppID(unsigned surface, const std::string &role, bool *found) const;
// Request Interface
- unsigned currentSequenceNumber();
- unsigned getSequenceNumber(const std::string &appid);
+ unsigned currentRequestNumber() const;
+ unsigned getRequestNumber(const std::string &appid) const;
unsigned addAllocateRequest(WMRequest req);
- /* TODO: consider, which is better WMClient or std::string appid?
- if appid is key to manage resources, it is better to select std::string
- otherwise WMClient is better, IMO */
- bool requestFinished();
- bool setAction(unsigned req_num, const struct WMAction &action);
- bool setAction(unsigned req_num, const std::string &appid, const std::string &role, const std::string &area, bool visible = true);
- bool setEndDrawFinished(unsigned req_num, const std::string &appid, const std::string &role);
- bool endDrawFullfilled(unsigned req_num);
- void removeRequest(unsigned req_num);
- void next();
- bool haveRequest();
+ WMError setAction(unsigned req_num, const struct WMAction &action);
+ WMError setAction(unsigned req_num, const std::string &appid, const std::string &role, const std::string &area, bool visible = true);
+ bool setEndDrawFinished(unsigned req_num, const std::string &appid, const std::string &role);
+ bool endDrawFullfilled(unsigned req_num);
+ void removeRequest(unsigned req_num);
+ void next();
+ bool haveRequest() const;
- struct WMTrigger getRequest(unsigned req_num);
- const std::vector<struct WMAction>& getActions(unsigned req_num);
+ struct WMTrigger getRequest(unsigned req_num, bool* found);
+ const std::vector<struct WMAction> &getActions(unsigned req_num, bool* found);
- void client_dump();
- void req_dump();
+ void clientDump();
+ void reqDump();
-private:
- std::vector<WMRequest> req_list;
- std::unordered_map<std::string, std::shared_ptr<WMClient>> client_list;
- unsigned current_seq;
+ private:
+ std::vector<WMRequest> req_list;
+ std::unordered_map<std::string, std::shared_ptr<WMClient>> app2client;
+ unsigned current_req;
+ std::mutex mtx;
};
-}
+} // namespace wm
#endif // ALLOCATE_LIST_HPP
\ No newline at end of file