<br><br><div><span class="gmail_quote">On 11/26/07, <b class="gmail_sendername">John Mitchell</b> <<a href="mailto:john@cepros.com">john@cepros.com</a>> 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> Not trying to throw "stop energy" 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're fine. I'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 <<a href="mailto:jesse@guardiani.us">jesse@guardiani.us
</a>> wrote:<br>><br>><br>> On 11/26/07, Igor Stoppa <<a href="mailto:igor.stoppa@nokia.com">igor.stoppa@nokia.com</a>> wrote:<br>> ><br>> > > On demand sounds great in theory, but let's think about it for a
<br>> > > second:<br>> > > How do you start on-demand a web app? (HTTPD daemon)<br>> > > How do you play the next track when the current track finishes<br>> > > playing? (Kagu daemon, or FastCGI Kagu daemon + HTTPD daemon)
<br>> ><br>> > Yes, that's the intrinsic problem of using an http-based approach.<br>> > You rely on the http daemon being nice.<br>><br>><br>> You gain a lot from having an HTTP daemon though. You gain a consistent GUI
<br>> (html + browser) and a common development methodology (web application<br>> development) that many programmers are already intimately familiar with.<br>><br><br> 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't have a world wide web. And it'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;">> You also gain the ability to use a high level language for GUI work while
<br>> still having a very fast startup time (theoretically, I haven't tried it<br>> yet).<br><br> 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'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's just too slow. Maybe that will change some day. But
<br>web applications don't need excessive javascript to function. They work just <br>fine without it.<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;">
><br>> You gain the ability to use CSS for application theming.<br>><br>> You also gain portability. No more wondering why the strange PyGtk<br>> Hildonization hack you had to do back in Bora no longer works in Chinook. In
<br>> fact, you no longer care if you're on chinook, bora, gregale, or the<br>> internet at large. It doesn't matter. All you need is a web server and a web<br>> browser and you're good to go.<br>>
<br> 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's not just broken compatibility though, it's also startup time and portability. Both suffer on maemo currently when using a high level language like python. Not saying it can't be done, just that I don'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't.<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;">
> > > Kagu is used very similar to a daemon. It runs as long as you're<br>> > > playing music. And if that's all you use an n800 for then it's always<br>> > > running. It might even be in the background if you're taking notes or
<br>> > > browsing the web. The difference is that it has a GUI right now. I'd<br>> > > like to make that portion optional to save some memory/CPU when you<br>> > > aren't using it. I'd also like to make startup time faster, and I'd
<br>> > > like to make a web frontend for it.<br><br> 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. 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'd have a whole library of easy to develop/port/use web applications for maemo.<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;">
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: "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." 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'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'd all benefit, and maemo would have one killer application to rule them all.<br><br><br> <br></div><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
> Hey, there's a useful bit of info! Thanks! I forgot all about that. So the<br>> Kagu daemon could be started via dbus and kill itself when it runs out of<br>> useful work to do. The frontend could then run using the normal mod_php
<br>> mentality (page based) and start the backend automatically using dbus when<br>> it needs it, continuing to query via dbus any time it needs to communicate.<br>><br>><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'm still interested in finger driven UI. But the browser offers that today. It's not
<br>as polished as I'd like, but perhaps if we use it more it'll become more polished.<br><br>I like maemo's browser. I think it's really really impressive. And I think it can become<br>even more impressive with time. It'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>