<br><br><div><span class="gmail_quote">On 11/26/07, <b class="gmail_sendername">John Mitchell</b> &lt;<a href="mailto:john@cepros.com">john@cepros.com</a>&gt; wrote:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
Jesse,<br><br>&nbsp;&nbsp;&nbsp;&nbsp;Not trying to throw &quot;stop energy&quot; into the mix, just reflecting on<br>some of your points. You did ask for comments. So here are a few. :-)</blockquote><div><br><br>No, you&#39;re fine. I&#39;m willing to explain my rationale.
<br><br><br></div><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">On 11/26/07, Jesse Guardiani &lt;<a href="mailto:jesse@guardiani.us">jesse@guardiani.us
</a>&gt; wrote:<br>&gt;<br>&gt;<br>&gt; On 11/26/07, Igor Stoppa &lt;<a href="mailto:igor.stoppa@nokia.com">igor.stoppa@nokia.com</a>&gt; wrote:<br>&gt; &gt;<br>&gt; &gt; &gt; On demand sounds great in theory, but let&#39;s think about it for a
<br>&gt; &gt; &gt; second:<br>&gt; &gt; &gt; How do you start on-demand a web app? (HTTPD daemon)<br>&gt; &gt; &gt; How do you play the next track when the current track finishes<br>&gt; &gt; &gt; playing? (Kagu daemon, or FastCGI Kagu daemon + HTTPD daemon)
<br>&gt; &gt;<br>&gt; &gt; Yes, that&#39;s the intrinsic problem of using an http-based approach.<br>&gt; &gt; You rely on the http daemon being nice.<br>&gt;<br>&gt;<br>&gt; You gain a lot from having an HTTP daemon though. You gain a consistent GUI
<br>&gt; (html + browser) and a common development methodology (web application<br>&gt; development) that many programmers are already intimately familiar with.<br>&gt;<br><br>&nbsp;&nbsp;&nbsp;&nbsp;I would have to disagree on the consistency point. I spent three
<br>years doing n-tier database applications development with web based<br>frontends, and getting a consistent look and feel (let alone<br>functionality) across multiple OS/browser platforms can be _very_<br>difficult. Especially with all of the various security functions that
<br>users employ to protect themselves from nefarious scripts. In the end<br>we gave up and targeted Windows only. I was very sad but we spent a<br>_huge_ number of man hours trying to make it work.</blockquote><div><br><br>
Sure. There are different frameworks and different languages and different <br>browsers, but I do web dev for a living and I manage to make it work. It <br>can be done, otherwise you wouldn&#39;t have a world wide web. And it&#39;s 
<br>really not that difficult, IMO.<br><br><br></div><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">&gt; You also gain the ability to use a high level language for GUI work while
<br>&gt; still having a very fast startup time (theoretically, I haven&#39;t tried it<br>&gt; yet).<br><br>&nbsp;&nbsp; While I agree with you for the majority of processors out there<br>(1GHz or faster with lots of memory) the Nokia tablets are not so good
<br>in comparison at client side<br>web application execution (think Web 2.0 or tons of JavaScript). Gmail<br>with AJAX is pretty hard to use on my N800 (I have since given up),<br>maybe it will be doable on my N810.</blockquote>
<div><br><br>I&#39;m aware of this. I use GMail regularly on my n800 and it works fine so long as <br>you turn off AJAX on the gmail end. I think appending ?ui=html to the URL does<br>the trick.<br><br>It *works* with AJAX. It&#39;s just too slow. Maybe that will change some day. But 
<br>web applications don&#39;t need excessive javascript to function. They work just <br>fine without it.<br><br>&nbsp;</div><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
&gt;<br>&gt; You gain the ability to use CSS for application theming.<br>&gt;<br>&gt; You also gain portability. No more wondering why the strange PyGtk<br>&gt; Hildonization hack you had to do back in Bora no longer works in Chinook. In
<br>&gt; fact, you no longer care if you&#39;re on chinook, bora, gregale, or the<br>&gt; internet at large. It doesn&#39;t matter. All you need is a web server and a web<br>&gt; browser and you&#39;re good to go.<br>&gt;
<br>&nbsp;&nbsp;&nbsp;&nbsp;I have read that GTK portability is good, and in my limited<br>experience was good across Windows, Linux, and Mac OS X. This is one<br>of the reasons I have chosen it for the applications I am working on.<br>Is the problem you are experiencing a function of the advanced
<br>interface work you are doing or is it truly a problem with the<br>GTK/Hildon environment changing? Maybe with some other developers<br>working on that problem the need for an n-tier application structure<br>will go away?
</blockquote><div><br><br>Perhaps. It&#39;s not just broken compatibility though, it&#39;s also startup time and portability. Both suffer on maemo currently when using a high level language like python. Not saying it can&#39;t be done, just that I don&#39;t really want to. python-launcher might change one aspect of this soon. And if python 
2.5 ever shipped with the default OS, I might sing a different tune. But it doesn&#39;t.<br>&nbsp;</div><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
&gt; &gt; &gt; Kagu is used very similar to a daemon. It runs as long as you&#39;re<br>&gt; &gt; &gt; playing music. And if that&#39;s all you use an n800 for then it&#39;s always<br>&gt; &gt; &gt; running. It might even be in the background if you&#39;re taking notes or
<br>&gt; &gt; &gt; browsing the web. The difference is that it has a GUI right now. I&#39;d<br>&gt; &gt; &gt; like to make that portion optional to save some memory/CPU when you<br>&gt; &gt; &gt; aren&#39;t using it. I&#39;d also like to make startup time faster, and I&#39;d
<br>&gt; &gt; &gt; like to make a web frontend for it.<br><br>&nbsp;&nbsp;&nbsp;&nbsp;Do you intend on having the server portion of your app on some<br>other system image (machine or OS, we live in a virtualized world now)<br>other than the client? If so, that sounds good. If not, I would not
<br>want all the over head of all those layers for an application on a<br>Nokia tablet.&nbsp;&nbsp;I would guess that you would have so many pieces moving<br>in that equation that playing music would suffer.</blockquote><div><br><br>
I think it can be done. And if the framework is there, then maybe other applications would use it too and we&#39;d have a whole library of easy to develop/port/use web applications for maemo.<br><br>&nbsp;</div><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
&nbsp;&nbsp;&nbsp;&nbsp;I have to be honest with you, your intention of making a web<br>frontend for Kagu seems a bit at odds with some of your stated<br>funtions for the application: &quot;Kagu is a media player with a finger<br>optimized UI with kinetic scrolling (aka inertial scrolling) written
<br>for Python 2.5 and greater.&quot; The finger optimized UI with kinetic<br>scrolling is what drew me to your application. A web GUI would have<br>neither of these features. It really sounds like you are wanting to<br>take the application in a whole new direction , or maybe even totally
<br>change the nature of the application. If so, then maybe your client<br>server vision for the application is no longer appropriate for the<br>Nokia tablet (well, the client portion might be great if someone is<br>near a fat network).
</blockquote><div><br><br>Kinetic scrolling is nice. True. But the browser already has tap and drag scrolling.<br>That&#39;s pretty close to kinetic scrolling. Who knows, maybe having more apps that<br>use the browser would force Nokia to devote more resources to browser development,
<br>making the browser faster, easier to use, and less buggy.<br><br>Then we&#39;d all benefit, and maemo would have one killer application to rule them all.<br><br><br>&nbsp;<br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
&gt; Hey, there&#39;s a useful bit of info! Thanks! I forgot all about that. So the<br>&gt; Kagu daemon could be started via dbus and kill itself when it runs out of<br>&gt; useful work to do. The frontend could then run using the normal mod_php
<br>&gt; mentality (page based) and start the backend automatically using dbus when<br>&gt; it needs it, continuing to query via dbus any time it needs to communicate.<br>&gt;<br>&gt;<br><br> So maybe in the end your drive for an n-tier structure is not one
<br>born out of pain from GTK/Hildon, but out of a desire for different<br>functionality than the current finger driven GUI focus?</blockquote><div><br><br>No, I&#39;m still interested in finger driven UI. But the browser offers that today. It&#39;s not
<br>as polished as I&#39;d like, but perhaps if we use it more it&#39;ll become more polished.<br><br>I like maemo&#39;s browser. I think it&#39;s really really impressive. And I think it can become<br>even more impressive with time. It&#39;s an infrastructure decision. 
<br></div><br></div><br>-- <br>Jesse Guardiani<br>Software Developer / Sys Admin<br><a href="mailto:jesse@guardiani.us">jesse@guardiani.us</a>