xref: /glogg/src/session.h (revision fdcf994b6c66596cefa40a95e9e7bcfd96801710)
1d96f3f21SNicolas Bonnefon /*
28964a9adSNicolas Bonnefon  * Copyright (C) 2013, 2014 Nicolas Bonnefon and other contributors
3d96f3f21SNicolas Bonnefon  *
4d96f3f21SNicolas Bonnefon  * This file is part of glogg.
5d96f3f21SNicolas Bonnefon  *
6d96f3f21SNicolas Bonnefon  * glogg is free software: you can redistribute it and/or modify
7d96f3f21SNicolas Bonnefon  * it under the terms of the GNU General Public License as published by
8d96f3f21SNicolas Bonnefon  * the Free Software Foundation, either version 3 of the License, or
9d96f3f21SNicolas Bonnefon  * (at your option) any later version.
10d96f3f21SNicolas Bonnefon  *
11d96f3f21SNicolas Bonnefon  * glogg is distributed in the hope that it will be useful,
12d96f3f21SNicolas Bonnefon  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13d96f3f21SNicolas Bonnefon  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14d96f3f21SNicolas Bonnefon  * GNU General Public License for more details.
15d96f3f21SNicolas Bonnefon  *
16d96f3f21SNicolas Bonnefon  * You should have received a copy of the GNU General Public License
17d96f3f21SNicolas Bonnefon  * along with glogg.  If not, see <http://www.gnu.org/licenses/>.
18d96f3f21SNicolas Bonnefon  */
19d96f3f21SNicolas Bonnefon 
20d96f3f21SNicolas Bonnefon #ifndef SESSION_H
21d96f3f21SNicolas Bonnefon #define SESSION_H
22d96f3f21SNicolas Bonnefon 
23d96f3f21SNicolas Bonnefon #include <memory>
24d96f3f21SNicolas Bonnefon #include <unordered_map>
25d96f3f21SNicolas Bonnefon #include <string>
268964a9adSNicolas Bonnefon #include <vector>
278964a9adSNicolas Bonnefon #include <utility>
28*28399ec3SJonathan Wakely #include <functional>
29d96f3f21SNicolas Bonnefon 
3078b9e3f6SNicolas Bonnefon #include <QDateTime>
31b76966a6SNicolas Bonnefon #include <QByteArray>
3278b9e3f6SNicolas Bonnefon 
33b423cd88SNicolas Bonnefon #include "quickfindpattern.h"
34b423cd88SNicolas Bonnefon 
35d96f3f21SNicolas Bonnefon class ViewInterface;
36a44d09bcSNicolas Bonnefon class ViewContextInterface;
37d96f3f21SNicolas Bonnefon class LogData;
38d96f3f21SNicolas Bonnefon class LogFilteredData;
391b5e406eSNicolas Bonnefon class SavedSearches;
40d96f3f21SNicolas Bonnefon 
41a3b56311SNicolas Bonnefon // File unreadable error
42a3b56311SNicolas Bonnefon class FileUnreadableErr {};
43a3b56311SNicolas Bonnefon 
44d96f3f21SNicolas Bonnefon // The session is responsible for maintaining the list of open log files
45d96f3f21SNicolas Bonnefon // and their association with Views.
46d96f3f21SNicolas Bonnefon // It also maintains the domain objects which are common to all log files
471b5e406eSNicolas Bonnefon // (SavedSearches, FileHistory, QFPattern...)
48d96f3f21SNicolas Bonnefon class Session {
49d96f3f21SNicolas Bonnefon   public:
50d96f3f21SNicolas Bonnefon     Session();
51d96f3f21SNicolas Bonnefon     ~Session();
52d96f3f21SNicolas Bonnefon 
53d96f3f21SNicolas Bonnefon     // No copy/assignment please
54d96f3f21SNicolas Bonnefon     Session( const Session& ) = delete;
55d96f3f21SNicolas Bonnefon     Session& operator =( const Session& ) = delete;
56d96f3f21SNicolas Bonnefon 
57d96f3f21SNicolas Bonnefon     // Return the view associated to a file if it is open
58d96f3f21SNicolas Bonnefon     // The filename must be strictly identical to trigger a match
59d96f3f21SNicolas Bonnefon     // (no match in case of e.g. relative vs. absolute pathname.
60f0708ca8SNicolas Bonnefon     ViewInterface* getViewIfOpen( const std::string& file_name ) const;
6178b9e3f6SNicolas Bonnefon     // Open a new file, starts its asynchronous loading, and construct a new
6278b9e3f6SNicolas Bonnefon     // view for it (the caller passes a factory to build the concrete view)
63d96f3f21SNicolas Bonnefon     // The ownership of the view is given to the caller
64d96f3f21SNicolas Bonnefon     // Throw exceptions if the file is already open or if it cannot be open.
65f0708ca8SNicolas Bonnefon     ViewInterface* open( const std::string& file_name,
66f0708ca8SNicolas Bonnefon             std::function<ViewInterface*()> view_factory );
67d96f3f21SNicolas Bonnefon     // Close the file identified by the view passed
68d96f3f21SNicolas Bonnefon     // Throw an exception if it does not exist.
69d96f3f21SNicolas Bonnefon     void close( const ViewInterface* view );
70b57881faSNicolas Bonnefon 
718964a9adSNicolas Bonnefon     // Open all the files listed in the stored session
728964a9adSNicolas Bonnefon     // (see ::open)
738964a9adSNicolas Bonnefon     // returns a vector of pairs (file_name, view) and the index of the
748964a9adSNicolas Bonnefon     // current file (or -1 if none).
758964a9adSNicolas Bonnefon     std::vector<std::pair<std::string, ViewInterface*>> restore(
768964a9adSNicolas Bonnefon             std::function<ViewInterface*()> view_factory,
778964a9adSNicolas Bonnefon             int *current_file_index );
78b57881faSNicolas Bonnefon     // Save the session to persistent storage. An ordered list of
79a44d09bcSNicolas Bonnefon     // (view, topline, ViewContextInterface) is passed, this is because only
80b76966a6SNicolas Bonnefon     // the main window know the order in which the views are presented to
81b76966a6SNicolas Bonnefon     // the user (it might have changed since file were opened).
82b76966a6SNicolas Bonnefon     // Also, the geometry information is passed as an opaque string.
83a44d09bcSNicolas Bonnefon     void save( std::vector<
84a44d09bcSNicolas Bonnefon                    std::tuple<const ViewInterface*, uint64_t, std::shared_ptr<const ViewContextInterface>>
85b76966a6SNicolas Bonnefon                > view_list,
86b76966a6SNicolas Bonnefon            const QByteArray& geometry );
87b76966a6SNicolas Bonnefon 
88b76966a6SNicolas Bonnefon     // Get the geometry string from persistent storage for this session.
89b76966a6SNicolas Bonnefon     void storedGeometry( QByteArray* geometry ) const;
90b57881faSNicolas Bonnefon 
910e97f16dSNicolas Bonnefon     // Get the file name for the passed view.
920e97f16dSNicolas Bonnefon     std::string getFilename( const ViewInterface* view ) const;
9378b9e3f6SNicolas Bonnefon     // Get the size (in bytes) and number of lines in the current file.
9478b9e3f6SNicolas Bonnefon     // The file is identified by the view attached to it.
9578b9e3f6SNicolas Bonnefon     void getFileInfo( const ViewInterface* view, uint64_t* fileSize,
9678b9e3f6SNicolas Bonnefon             uint32_t* fileNbLine, QDateTime* lastModified ) const;
97b423cd88SNicolas Bonnefon     // Get a (non-const) reference to the QuickFind pattern.
getQuickFindPattern()98b423cd88SNicolas Bonnefon     std::shared_ptr<QuickFindPattern> getQuickFindPattern() const
99b423cd88SNicolas Bonnefon     { return quickFindPattern_; }
100d96f3f21SNicolas Bonnefon 
101d96f3f21SNicolas Bonnefon   private:
102d96f3f21SNicolas Bonnefon     struct OpenFile {
103d96f3f21SNicolas Bonnefon         std::string fileName;
104d96f3f21SNicolas Bonnefon         std::shared_ptr<LogData> logData;
105d96f3f21SNicolas Bonnefon         std::shared_ptr<LogFilteredData> logFilteredData;
106d96f3f21SNicolas Bonnefon         ViewInterface* view;
107d96f3f21SNicolas Bonnefon     };
108d96f3f21SNicolas Bonnefon 
10978b9e3f6SNicolas Bonnefon     // Open a file without checking if it is existing/readable
11078b9e3f6SNicolas Bonnefon     ViewInterface* openAlways( const std::string& file_name,
111a44d09bcSNicolas Bonnefon             std::function<ViewInterface*()> view_factory,
112a44d09bcSNicolas Bonnefon             const char* view_context );
11378b9e3f6SNicolas Bonnefon     // Find an open file from its associated view
11478b9e3f6SNicolas Bonnefon     OpenFile* findOpenFileFromView( const ViewInterface* view );
11578b9e3f6SNicolas Bonnefon     const OpenFile* findOpenFileFromView( const ViewInterface* view ) const;
116039481acSNicolas Bonnefon 
11778b9e3f6SNicolas Bonnefon     // List of open files
11878b9e3f6SNicolas Bonnefon     typedef std::unordered_map<const ViewInterface*, OpenFile> OpenFileMap;
1191b5e406eSNicolas Bonnefon     OpenFileMap openFiles_;
1201b5e406eSNicolas Bonnefon 
1211b5e406eSNicolas Bonnefon     // Global search history
1221b5e406eSNicolas Bonnefon     std::shared_ptr<SavedSearches> savedSearches_;
123b423cd88SNicolas Bonnefon 
124b423cd88SNicolas Bonnefon     // Global quickfind pattern
125b423cd88SNicolas Bonnefon     std::shared_ptr<QuickFindPattern> quickFindPattern_;
126d96f3f21SNicolas Bonnefon };
127d96f3f21SNicolas Bonnefon 
128d96f3f21SNicolas Bonnefon #endif
129