<html>
 <body>
  <div style="font-family: Verdana, Arial, Helvetica, Sans-Serif;">
   <table bgcolor="#f9f3c9" width="100%" cellpadding="8" style="border: 1px #c9c399 solid;">
    <tr>
     <td>
      This is an automatically generated e-mail. To reply, visit:
      <a href="http://svn.reviewboard.kde.org/r/5638/">http://svn.reviewboard.kde.org/r/5638/</a>
     </td>
    </tr>
   </table>
   <br />


<table bgcolor="#fefadf" width="100%" cellspacing="0" cellpadding="8" style="background-image: url('http://svn.reviewboard.kde.orgrb/images/review_request_box_top_bg.png'); background-position: left top; background-repeat: repeat-x; border: 1px black solid;">
 <tr>
  <td>

<div>Review request for kwin and Plasma.</div>
<div>By Chani Armitage.</div>





<h1 style="color: #575012; font-size: 10pt; margin-top: 1.5em;">Description </h1>
<table width="100%" bgcolor="#ffffff" cellspacing="0" cellpadding="10" style="border: 1px solid #b8b5a0">
 <tr>
  <td>
   <pre style="margin: 0; padding: 0; white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;">so, this is the activity session code.
it&#39;s not 100% complete, because kwin has to fake a few things until the activities service gets its new api - but ivan&#39;s working on that. :) there won&#39;t be any UI for it until that api&#39;s in anyways.

kwin handles the mapping from activity id -&gt; windows -&gt; session ids, because I had to call it anyways, and it&#39;s much easier to calculate from inside kwin.

The good:
it can save and restore processes and their windows&#39; activity associations
all the regular xsmp stuff seems to be working, except cancel.
I&#39;ve done it by merely adding a few dbus methods, no changes to xsmp itself
ksmserver doesn&#39;t know or care what activities are; even the kwin code is separated out into &quot;find the clients for this activity&quot; and &quot;save a session for these clients&quot;

The bad:
since ksmserver doesn&#39;t tell the wm or clients that anything special is happening, it can&#39;t tell kwin &quot;save the subsession data&quot;, or tell clients &quot;close only window foo&quot;. for kwin this is actually a nice excuse to have it do the mapping work, but for clients it means we can&#39;t close anything until we&#39;re ready to close everything. Clients would have to be made context-aware either way to react to such a request; for 4.7 I might see if I can do it by extending xsmp or augmenting it with more dbus (instead of having the client do all the work after the session&#39;s closed, as I originally planned).

kwrite&#39;s cancel button doesn&#39;t cancel the session-close. it works on logout, so there must be a bug in my code.

session data isn&#39;t deleted when an activity is deleted (I forgot). I&#39;d like to get this patch in ASAP though, and add simple details like that later - the patch is already quite big enough ;)

The ugly:
there are some sync issues in here.
first of all, we have a conflict between save-on-close and save-regularly. all xsmp stuff is save-on-close, whereas the activity service and plasma (and other modern apps) save quite often. If you open an activity and then X crashes, you&#39;ve lost all session data for that activity. :(

I&#39;m planning to try fixing that by saving (but not quitting) the login session when an activity is opened/closed. I&#39;m not sure how well it&#39;d work, but it should at least keep the correct list of processes to start.

the second sync issue comes from the fact that a window can be open on a closed activity. I&#39;ll probably prevent the user from adding a window to a closed activity, but windows that are already shared across activities... well, they could behave in unexpected ways. I think I&#39;d like to do more tests before deciding how to handle that - but one thing that could help, perhaps, is storing the kwin session info in one big pool for all closed activities instead of a separate group for each activity.</pre>
  </td>
 </tr>
</table>


<h1 style="color: #575012; font-size: 10pt; margin-top: 1.5em;">Testing </h1>
<table width="100%" bgcolor="#ffffff" cellspacing="0" cellpadding="10" style="border: 1px solid #b8b5a0">
 <tr>
  <td>
   <pre style="margin: 0; padding: 0; white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;">I can use dbus to save/restore an activity, like I showed in my screencast ( http://chani.wordpress.com/2010/10/04/activities-fun-with-screencast ). I haven&#39;t done much testing of multi-window processes, though, or saving and restoring multiple activities.</pre>
  </td>
 </tr>
</table>




<h1 style="color: #575012; font-size: 10pt; margin-top: 1.5em;">Diffs</b> </h1>
<ul style="margin-left: 3em; padding-left: 0;">

 <li>trunk/KDE/kdebase/workspace/ksmserver/server.h <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/ksmserver/legacy.cpp <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/ksmserver/org.kde.KSMServerInterface.xml <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/ksmserver/server.cpp <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/ksmserver/shutdown.cpp <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/ksmserver/startup.cpp <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/kwin/org.kde.KWin.xml <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/kwin/sm.cpp <span style="color: grey">(1186160)</span></li>

 <li>trunk/KDE/kdebase/workspace/kwin/workspace.h <span style="color: grey">(1186160)</span></li>

</ul>

<p><a href="http://svn.reviewboard.kde.org/r/5638/diff/" style="margin-left: 3em;">View Diff</a></p>




  </td>
 </tr>
</table>




  </div>
 </body>
</html>