aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/Screen.cc3
-rw-r--r--src/Slit.cc133
-rw-r--r--src/Slit.hh27
-rw-r--r--src/fluxbox.cc8
-rw-r--r--src/fluxbox.hh3
5 files changed, 96 insertions, 78 deletions
diff --git a/src/Screen.cc b/src/Screen.cc
index 24e086c..6ddc74c 100644
--- a/src/Screen.cc
+++ b/src/Screen.cc
@@ -480,8 +480,7 @@ BScreen::BScreen(FbTk::ResourceManager_base &rm,
480 changeWorkspaceID(first_desktop); 480 changeWorkspaceID(first_desktop);
481 481
482#ifdef USE_SLIT 482#ifdef USE_SLIT
483 m_slit.reset(new Slit(*this, *layerManager().getLayer(ResourceLayer::DESKTOP), 483 m_slit.reset(new Slit(*this, *layerManager().getLayer(ResourceLayer::DESKTOP)));
484 fluxbox->getSlitlistFilename().c_str()));
485#endif // USE_SLIT 484#endif // USE_SLIT
486 485
487 XFlush(disp); 486 XFlush(disp);
diff --git a/src/Slit.cc b/src/Slit.cc
index 6b4344e..210c2a5 100644
--- a/src/Slit.cc
+++ b/src/Slit.cc
@@ -164,7 +164,67 @@ private:
164unsigned int Slit::s_eventmask = SubstructureRedirectMask | ButtonPressMask | 164unsigned int Slit::s_eventmask = SubstructureRedirectMask | ButtonPressMask |
165 EnterWindowMask | LeaveWindowMask | ExposureMask; 165 EnterWindowMask | LeaveWindowMask | ExposureMask;
166 166
167Slit::Slit(BScreen &scr, FbTk::Layer &layer, const char *filename) 167void Slit::SlitClientsRes::setFromLua(lua::state &l) {
168 lua::stack_sentry s(l, -1);
169 l.checkstack(1);
170
171 // to avoid modifying the master copy until we are sure the new list is ok
172 SlitClients copy(*this);
173 // this will be the new list once we are done
174 SlitClients t;
175
176 if(l.type(-1) != lua::TTABLE) {
177 std::cerr << "Cannot convert to a client list from lua type "
178 << l.type_name(l.type(-1)) << std::endl;
179 return;
180 }
181 for(size_t i = 1; l.rawgeti(-1, i), !l.isnil(-1); l.pop(), ++i) {
182 if(l.type(-1) != lua::TSTRING && l.type(-1) != lua::TNUMBER) {
183 std::cerr << "Cannot convert to a client name from lua type "
184 << l.type_name(l.type(-1)) << std::endl;
185 continue;
186 }
187 const std::string &name = l.tostring(-1);
188 // look for a matching window
189 bool found = false;
190 for(SlitClients::iterator j = copy.begin(); j != copy.end(); ++j) {
191 if((*j)->matchName().logical() == name) {
192 t.push_back(*j);
193 copy.erase(j);
194 found = true;
195 break;
196 }
197 }
198 if(!found) {
199 // no matching window, create a placeholder
200 t.push_back( new SlitClient(name.c_str()) );
201 }
202 } l.pop();
203
204 // move remaining non-placeholder clients to the new list
205 while(!copy.empty()) {
206 if(copy.front()->window() != None)
207 t.push_back(copy.front());
208 copy.pop_front();
209 }
210 SlitClients::operator=(t);
211
212 l.pop();
213}
214
215void Slit::SlitClientsRes::pushToLua(lua::state &l) const {
216 l.checkstack(2);
217 l.createtable(size());
218 lua::stack_sentry s(l);
219
220 int j = 1;
221 for(const_iterator i = begin(); i != end(); ++i) {
222 l.pushstring((*i)->matchName().logical());
223 l.rawseti(-2, j++);
224 }
225}
226
227Slit::Slit(BScreen &scr, FbTk::Layer &layer)
168 : m_hidden(false), m_visible(false), 228 : m_hidden(false), m_visible(false),
169 m_screen(scr), 229 m_screen(scr),
170 m_clientlist_menu(scr.menuTheme(), 230 m_clientlist_menu(scr.menuTheme(),
@@ -188,7 +248,7 @@ Slit::Slit(BScreen &scr, FbTk::Layer &layer, const char *filename)
188 m_slit_theme(new SlitTheme(scr.rootWindow().screenNumber())), 248 m_slit_theme(new SlitTheme(scr.rootWindow().screenNumber())),
189 m_strut(0), 249 m_strut(0),
190 // resources 250 // resources
191 // lock in first resource 251 m_client_list(scr.resourceManager(), scr.name() + ".slit.clientList"),
192 m_rc_kde_dockapp(scr.resourceManager(), true, scr.name() + ".slit.acceptKdeDockapps"), 252 m_rc_kde_dockapp(scr.resourceManager(), true, scr.name() + ".slit.acceptKdeDockapps"),
193 m_rc_auto_hide(scr.resourceManager(), false, scr.name() + ".slit.autoHide"), 253 m_rc_auto_hide(scr.resourceManager(), false, scr.name() + ".slit.autoHide"),
194 // TODO: this resource name must change 254 // TODO: this resource name must change
@@ -245,11 +305,6 @@ Slit::Slit(BScreen &scr, FbTk::Layer &layer, const char *filename)
245 305
246 moveToLayer(static_cast<int>(*m_rc_layernum)); 306 moveToLayer(static_cast<int>(*m_rc_layernum));
247 307
248
249
250 // Get client list for sorting purposes
251 loadClientList(filename);
252
253 setupMenu(); 308 setupMenu();
254} 309}
255 310
@@ -802,7 +857,6 @@ void Slit::reposition() {
802 857
803 858
804void Slit::shutdown() { 859void Slit::shutdown() {
805 saveClientList();
806 while (!m_client_list.empty()) 860 while (!m_client_list.empty())
807 removeClient(m_client_list.front(), true, true); 861 removeClient(m_client_list.front(), true, true);
808} 862}
@@ -826,6 +880,8 @@ void Slit::clientUp(SlitClient* client) {
826 break; 880 break;
827 } 881 }
828 } 882 }
883
884 saveClientList();
829} 885}
830 886
831void Slit::clientDown(SlitClient* client) { 887void Slit::clientDown(SlitClient* client) {
@@ -847,6 +903,8 @@ void Slit::clientDown(SlitClient* client) {
847 break; 903 break;
848 } 904 }
849 } 905 }
906
907 saveClientList();
850} 908}
851 909
852void Slit::cycleClientsUp() { 910void Slit::cycleClientsUp() {
@@ -859,6 +917,8 @@ void Slit::cycleClientsUp() {
859 m_client_list.erase(it); 917 m_client_list.erase(it);
860 m_client_list.push_back(client); 918 m_client_list.push_back(client);
861 reconfigure(); 919 reconfigure();
920
921 saveClientList();
862} 922}
863 923
864void Slit::cycleClientsDown() { 924void Slit::cycleClientsDown() {
@@ -870,6 +930,8 @@ void Slit::cycleClientsDown() {
870 m_client_list.remove(client); 930 m_client_list.remove(client);
871 m_client_list.push_front(client); 931 m_client_list.push_front(client);
872 reconfigure(); 932 reconfigure();
933
934 saveClientList();
873} 935}
874 936
875void Slit::handleEvent(XEvent &event) { 937void Slit::handleEvent(XEvent &event) {
@@ -1000,40 +1062,6 @@ void Slit::toggleHidden() {
1000 frame.window.move(frame.x, frame.y); 1062 frame.window.move(frame.x, frame.y);
1001} 1063}
1002 1064
1003void Slit::loadClientList(const char *filename) {
1004 if (filename == 0 || filename[0] == '\0')
1005 return;
1006
1007 // save filename so we can save client list later
1008 m_filename = filename;
1009 string real_filename= FbTk::StringUtil::expandFilename(filename);
1010
1011 struct stat buf;
1012 if (stat(real_filename.c_str(), &buf) == 0) {
1013 ifstream file(real_filename.c_str());
1014 string name;
1015 while (! file.eof()) {
1016 name = "";
1017 getline(file, name); // get the entire line
1018 if (name.empty())
1019 continue;
1020
1021 // remove whitespaces from start and end
1022 FbTk::StringUtil::removeFirstWhitespace(name);
1023
1024 // the cleaned string could still be a comment, or blank
1025 if ( name.empty() || name[0] == '#' || name[0] == '!' )
1026 continue;
1027
1028 // trailing whitespace won't affect the above test
1029 FbTk::StringUtil::removeTrailingWhitespace(name);
1030
1031 SlitClient *client = new SlitClient(name.c_str());
1032 m_client_list.push_back(client);
1033 }
1034 }
1035}
1036
1037void Slit::updateClientmenu() { 1065void Slit::updateClientmenu() {
1038 if (screen().isShuttingdown()) 1066 if (screen().isShuttingdown())
1039 return; 1067 return;
@@ -1057,30 +1085,11 @@ void Slit::updateClientmenu() {
1057 m_clientlist_menu.insert(new SlitClientMenuItem(*this, *(*it), reconfig)); 1085 m_clientlist_menu.insert(new SlitClientMenuItem(*this, *(*it), reconfig));
1058 } 1086 }
1059 1087
1060 m_clientlist_menu.insert(new FbTk::MenuSeparator());
1061 FbTk::RefCount<FbTk::Command<void> > savecmd(new FbTk::SimpleCommand<Slit>(*this, &Slit::saveClientList));
1062 m_clientlist_menu.insert(_FB_XTEXT(Slit,
1063 SaveSlitList,
1064 "Save SlitList", "Saves the current order in the slit"),
1065 savecmd);
1066
1067 m_clientlist_menu.updateMenu(); 1088 m_clientlist_menu.updateMenu();
1068} 1089}
1069 1090
1070void Slit::saveClientList() { 1091void Slit::saveClientList() {
1071 1092 Fluxbox::instance()->save_rc();
1072 ofstream file(FbTk::StringUtil::expandFilename(m_filename).c_str());
1073 SlitClients::iterator it = m_client_list.begin();
1074 SlitClients::iterator it_end = m_client_list.end();
1075 string prevName;
1076 string name;
1077 for (; it != it_end; ++it) {
1078 name = (*it)->matchName().logical();
1079 if (name != prevName)
1080 file << name.c_str() << endl;
1081
1082 prevName = name;
1083 }
1084} 1093}
1085 1094
1086void Slit::setupMenu() { 1095void Slit::setupMenu() {
diff --git a/src/Slit.hh b/src/Slit.hh
index 5c69a8c..9384ad6 100644
--- a/src/Slit.hh
+++ b/src/Slit.hh
@@ -68,7 +68,7 @@ public:
68 RIGHTBOTTOM, RIGHTCENTER, RIGHTTOP 68 RIGHTBOTTOM, RIGHTCENTER, RIGHTTOP
69 }; 69 };
70 70
71 Slit(BScreen &screen, FbTk::Layer &layer, const char *filename = 0); 71 Slit(BScreen &screen, FbTk::Layer &layer);
72 virtual ~Slit(); 72 virtual ~Slit();
73 73
74 void show() { frame.window.show(); m_visible = true; } 74 void show() { frame.window.show(); m_visible = true; }
@@ -137,7 +137,6 @@ private:
137 void setupMenu(); 137 void setupMenu();
138 138
139 void removeClient(SlitClient *client, bool remap, bool destroy); 139 void removeClient(SlitClient *client, bool remap, bool destroy);
140 void loadClientList(const char *filename);
141 void updateClientmenu(); 140 void updateClientmenu();
142 void clearStrut(); 141 void clearStrut();
143 void updateStrut(); 142 void updateStrut();
@@ -148,13 +147,11 @@ private:
148 BScreen &m_screen; 147 BScreen &m_screen;
149 FbTk::Timer m_timer; 148 FbTk::Timer m_timer;
150 149
151 SlitClients m_client_list;
152 std::auto_ptr<LayerMenu> m_layermenu; 150 std::auto_ptr<LayerMenu> m_layermenu;
153 FbMenu m_clientlist_menu, m_slitmenu; 151 FbMenu m_clientlist_menu, m_slitmenu;
154#ifdef XINERAMA 152#ifdef XINERAMA
155 XineramaHeadMenu<Slit> *m_xineramaheadmenu; 153 XineramaHeadMenu<Slit> *m_xineramaheadmenu;
156#endif // XINERAMA 154#endif // XINERAMA
157 std::string m_filename;
158 155
159 struct frame { 156 struct frame {
160 frame(const FbTk::FbWindow &parent): 157 frame(const FbTk::FbWindow &parent):
@@ -179,6 +176,28 @@ private:
179 static unsigned int s_eventmask; 176 static unsigned int s_eventmask;
180 Strut *m_strut; 177 Strut *m_strut;
181 178
179 class SlitClientsRes: public FbTk::Resource_base, public SlitClients {
180 public:
181 SlitClientsRes(FbTk::ResourceManager_base &rm, const std::string &name)
182 : FbTk::Resource_base(name, name), m_rm(rm) {
183 m_rm.addResource(*this);
184 }
185
186 ~SlitClientsRes() {
187 m_rm.removeResource(*this);
188 }
189
190 virtual void setDefaultValue() {}
191 virtual void setFromString(const char *) { assert(0); }
192 virtual std::string getString() const { assert(0); }
193 virtual void setFromLua(lua::state &l);
194 virtual void pushToLua(lua::state &l) const;
195
196 private:
197 FbTk::ResourceManager_base &m_rm;
198 };
199
200 SlitClientsRes m_client_list;
182 FbTk::BoolResource m_rc_kde_dockapp, m_rc_auto_hide, m_rc_maximize_over; 201 FbTk::BoolResource m_rc_kde_dockapp, m_rc_auto_hide, m_rc_maximize_over;
183 FbTk::Resource<Slit::Placement, FbTk::EnumTraits<Slit::Placement> > m_rc_placement; 202 FbTk::Resource<Slit::Placement, FbTk::EnumTraits<Slit::Placement> > m_rc_placement;
184 FbTk::IntResource m_rc_alpha, m_rc_on_head; 203 FbTk::IntResource m_rc_alpha, m_rc_on_head;
diff --git a/src/fluxbox.cc b/src/fluxbox.cc
index 8e9c543..177e985 100644
--- a/src/fluxbox.cc
+++ b/src/fluxbox.cc
@@ -251,7 +251,6 @@ Fluxbox::Fluxbox(int argc, char **argv,
251 m_rc_styleoverlayfile(m_resourcemanager, m_RC_PATH + "/overlay", "styleOverlay", "StyleOverlay"), 251 m_rc_styleoverlayfile(m_resourcemanager, m_RC_PATH + "/overlay", "styleOverlay", "StyleOverlay"),
252 m_rc_menufile(m_resourcemanager, m_RC_PATH + "/menu", "menuFile", "MenuFile"), 252 m_rc_menufile(m_resourcemanager, m_RC_PATH + "/menu", "menuFile", "MenuFile"),
253 m_rc_keyfile(m_resourcemanager, m_RC_PATH + "/keys", "keyFile", "KeyFile"), 253 m_rc_keyfile(m_resourcemanager, m_RC_PATH + "/keys", "keyFile", "KeyFile"),
254 m_rc_slitlistfile(m_resourcemanager, m_RC_PATH + "/slitlist", "slitlistFile", "SlitlistFile"),
255 m_rc_appsfile(m_resourcemanager, m_RC_PATH + "/apps", "appsFile", "AppsFile"), 254 m_rc_appsfile(m_resourcemanager, m_RC_PATH + "/apps", "appsFile", "AppsFile"),
256 m_rc_tabs_attach_area(m_resourcemanager, ATTACH_AREA_WINDOW, "tabsAttachArea", "TabsAttachArea"), 255 m_rc_tabs_attach_area(m_resourcemanager, ATTACH_AREA_WINDOW, "tabsAttachArea", "TabsAttachArea"),
257 m_rc_cache_life(m_resourcemanager, 5, "cacheLife", "CacheLife"), 256 m_rc_cache_life(m_resourcemanager, 5, "cacheLife", "CacheLife"),
@@ -1183,13 +1182,6 @@ void Fluxbox::load_rc() {
1183 1182
1184 FbTk::Transparent::usePseudoTransparent(*m_rc_pseudotrans); 1183 FbTk::Transparent::usePseudoTransparent(*m_rc_pseudotrans);
1185 1184
1186 if (!m_rc_slitlistfile->empty()) {
1187 *m_rc_slitlistfile = StringUtil::expandFilename(*m_rc_slitlistfile);
1188 } else {
1189 string filename = getDefaultDataFilename("slitlist");
1190 m_rc_slitlistfile.setFromString(filename.c_str());
1191 }
1192
1193 *m_rc_colors_per_channel = FbTk::Util::clamp(*m_rc_colors_per_channel, 2, 6); 1185 *m_rc_colors_per_channel = FbTk::Util::clamp(*m_rc_colors_per_channel, 2, 6);
1194 1186
1195 if (m_rc_stylefile->empty()) 1187 if (m_rc_stylefile->empty())
diff --git a/src/fluxbox.hh b/src/fluxbox.hh
index 2e0aabb..97ea211 100644
--- a/src/fluxbox.hh
+++ b/src/fluxbox.hh
@@ -121,7 +121,6 @@ public:
121 const std::string &getStyleOverlayFilename() const { return *m_rc_styleoverlayfile; } 121 const std::string &getStyleOverlayFilename() const { return *m_rc_styleoverlayfile; }
122 122
123 const std::string &getMenuFilename() const { return *m_rc_menufile; } 123 const std::string &getMenuFilename() const { return *m_rc_menufile; }
124 const std::string &getSlitlistFilename() const { return *m_rc_slitlistfile; }
125 const std::string &getAppsFilename() const { return *m_rc_appsfile; } 124 const std::string &getAppsFilename() const { return *m_rc_appsfile; }
126 const std::string &getKeysFilename() const { return *m_rc_keyfile; } 125 const std::string &getKeysFilename() const { return *m_rc_keyfile; }
127 int colorsPerChannel() const { return *m_rc_colors_per_channel; } 126 int colorsPerChannel() const { return *m_rc_colors_per_channel; }
@@ -241,7 +240,7 @@ private:
241 m_rc_tabs_padding; 240 m_rc_tabs_padding;
242 FbTk::StringResource m_rc_stylefile, 241 FbTk::StringResource m_rc_stylefile,
243 m_rc_styleoverlayfile, 242 m_rc_styleoverlayfile,
244 m_rc_menufile, m_rc_keyfile, m_rc_slitlistfile, 243 m_rc_menufile, m_rc_keyfile,
245 m_rc_appsfile; 244 m_rc_appsfile;
246 245
247 246