[#33161] Call/CC and Ruby iterators. — olczyk@... (Thaddeus L Olczyk)

Reading about call/cc in Scheme I get the impression that it is very

11 messages 2002/02/05

[#33242] favicon.ico — Dave Thomas <Dave@...>

19 messages 2002/02/06
[#33256] Re: favicon.ico — Leon Torres <leon@...> 2002/02/06

[#33435] Reg: tiny contest: who's faster? (add_a_gram) — grady@... (Steven Grady)

> My current solution works correctly with various inputs.

17 messages 2002/02/08

[#33500] Ruby Embedded Documentation — William Djaja Tjokroaminata <billtj@...>

Hi,

24 messages 2002/02/10
[#33502] Re: Ruby Embedded Documentation — "Lyle Johnson" <ljohnson@...> 2002/02/10

> Now, I am using Ruby on Linux, and I have downloaded Ruby version

[#33615] Name resolution in Ruby — stern@... (Alan Stern)

I've been struggling to understand how name resolution is supposed to

16 messages 2002/02/11

[#33617] choice of HTML templating system — Paul Brannan <paul@...>

I am not a web developer, nor do I pretend to be one.

23 messages 2002/02/11

[#33619] make first letter lowercase — sebi@... (sebi)

hello,

20 messages 2002/02/11
[#33620] Re: [newbie] make first letter lowercase — Tobias Reif <tobiasreif@...> 2002/02/11

sebi wrote:

[#33624] Re: [newbie] make first letter lowercase — "Jeff 'japhy' Pinyan" <jeffp@...> 2002/02/11

On Feb 11, Tobias Reif said:

[#33632] Re: [newbie] make first letter lowercase — Mathieu Bouchard <matju@...> 2002/02/12

[#33731] simple XML parsing (greedy / non-greedy — Ron Jeffries <ronjeffries@...>

Suppose I had this text

14 messages 2002/02/13

[#33743] qualms about respond_to? idiom — David Alan Black <dblack@...>

Hi --

28 messages 2002/02/13
[#33751] Re: qualms about respond_to? idiom — Dave Thomas <Dave@...> 2002/02/13

David Alan Black <dblack@candle.superlink.net> writes:

[#33754] Re: qualms about respond_to? idiom — David Alan Black <dblack@...> 2002/02/13

Hi --

[#33848] "Powered by Ruby" banner — Yuri Leikind <YuriLeikind@...>

Hello Ruby folks,

78 messages 2002/02/14
[#33909] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/14

On Thu, 14 Feb 2002, Yuri Leikind wrote:

[#33916] RE: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

A modest submission:

[#33929] Re: "Powered by Ruby" banner — yet another bill smith <bigbill.smith@...> 2002/02/15

Kent Dahl wrote:

[#33932] OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 5:54 AM, "yet another bill smith" <bigbill.smith@verizon.net>

[#33933] RE: OT Netscape 4.x? was Re: "Powered by Ruby" banner — "Jack Dempsey" <dempsejn@...> 2002/02/15

i just don't understand why it didn't show up! dhtml/javascript, ok, but a

[#33937] Re: OT Netscape 4.x? was Re: "Powered by Ruby" banner — Chris Gehlker <gehlker@...> 2002/02/15

On 2/15/02 7:16 AM, "Jack Dempsey" <dempsejn@georgetown.edu> wrote:

[#33989] Re: OT OmniWeb [was: Netscape 4.x?] — Sean Russell <ser@...> 2002/02/16

Chris Gehlker wrote:

[#33991] Re: OT OmniWeb [was: Netscape 4.x?] — Rob Partington <rjp@...> 2002/02/16

In message <3c6e5e01_1@spamkiller.newsgroups.com>,

[#33993] Re: OT OmniWeb [was: Netscape 4.x?] — Thomas Hurst <tom.hurst@...> 2002/02/16

* Rob Partington (rjp@browser.org) wrote:

[#33925] Re: "Powered by Ruby" banner — Martin Maciaszek <mmaciaszek@...> 2002/02/15

In article <3C6CFCCA.5AD5CA67@scnsoft.com>, Yuri Leikind wrote:

[#33956] Re: "Powered by Ruby" banner — Leon Torres <leon@...> 2002/02/15

On Fri, 15 Feb 2002, Martin Maciaszek wrote:

[#33851] Ruby and .NET — Patrik Sundberg <ps@...>

I have been reading a bit about .NET for the last couple of days and must say

53 messages 2002/02/14

[#34024] Compiled companion language for Ruby? — Erik Terpstra <erik@...>

Hmmm, seems that my previous post was in a different thread, I'll try

12 messages 2002/02/16

[#34036] The GUI Returns — "Horacio Lopez" <vruz@...>

Hello all,

33 messages 2002/02/17

[#34162] Epic4/Ruby — Thomas Hurst <tom.hurst@...>

Rejoice, for you no longer have to put up with that evil excuse for a

34 messages 2002/02/18

[#34185] Operator overloading and multiple arguments — ptkwt@...1.aracnet.com (Phil Tomson)

I'm trying to overload the '<=' operator in a class in order to use it for

10 messages 2002/02/18

[#34217] Ruby for web development — beripome@... (Billy)

Hi all,

21 messages 2002/02/19

[#34350] FAQ for comp.lang.ruby — "Hal E. Fulton" <hal9000@...>

RUBY NEWSGROUP FAQ -- Welcome to comp.lang.ruby! (Revised 2001-2-18)

15 messages 2002/02/20

[#34375] Setting the Ruby continued — <jostein.berntsen@...>

Hi,

24 messages 2002/02/20
[#34384] Re: Setting the Ruby continued — Paulo Schreiner <paulo@...> 2002/02/20

Also VERY important:

[#34467] recursive require — Ron Jeffries <ronjeffries@...>

I'm having a really odd thing happen with two files that mutually

18 messages 2002/02/21

[#34503] special characters — Tobias Reif <tobiasreif@...>

Hi all,

13 messages 2002/02/22

[#34517] Windows Installer Ruby 166-0 available — Andrew Hunt <andy@...>

16 messages 2002/02/22

[#34597] rdoc/xml questions — Dave Thomas <Dave@...>

24 messages 2002/02/23

[#34631] Object/Memory Management — "Sean O'Dell" <sean@...>

I'm new to Ruby and the community here (I've been learning Ruby for a grand

44 messages 2002/02/23

[#34682] duplicate method name — Ron Jeffries <ronjeffries@...>

I just found a case in a test file where i had two tests of the same

16 messages 2002/02/24
[#34687] Re: duplicate method name — s@... (Stefan Schmiedl) 2002/02/24

Hi Ron.

[#34791] Style Question — Ron Jeffries <ronjeffries@...>

So I'm building this set theory library. The "only" object is supposed

13 messages 2002/02/25

[#34912] RCR?: parallel to until: as_soon_as — Tobias Reif <tobiasreif@...>

Hi,

18 messages 2002/02/26

[#34972] OT A Question on work styles — Chris Gehlker <gehlker@...>

As a Mac baby I just had to step through ruby in GDB *from the command line*

20 messages 2002/02/28

[#35015] Time Comparison — "Sean O'Dell" <sean@...>

I am using the time object to compare times between two files and I'm

21 messages 2002/02/28

Re: IOWA troubles (was Re: choice of HTML templating system)

From: Julian Fitzell <julian@...4.com>
Date: 2002-02-14 00:45:35 UTC
List: ruby-talk #33820
Thomas Hurst wrote:
> * Julian Fitzell (julian@beta4.com) wrote:
>>Thomas Hurst wrote:
> Well, the thing is, what's the point in serving content if the one
> way of specifying it's location is a meaningless jumble of characters?

Well, there's still a point... it just means you can't bookmark it as 
easily :) Seriously, though, this is a problem that we try to address as 
  well as we can. The squeak rewrite of Iowa (called Seaside) changes 
the URI to include an /action portion.  We use this as follows:

Link in pages would go to a URI like 
http://www.server.com/calculator/1/1/act

and that would perform whatever actions are associated with that link. 
Then it forwards the browser to:

http://www.server.com/calculator/1/2/view

which would display the results.  The nice thing about this is that when 
you hit the back button, you go back to /calculator/1/1/view not 
/calculator/1/1/act which means that you don't have the "double 
submission" problem that you can get with other systems.

Anyway, it's also used to provide /inspect and /profile actions which 
allow you to inspect the page objects and do profiling respectively. 
These action are easily added so you could add actions that jumped to a 
particular page.  This might help you somewhat though you would still 
have to start a session first.


> Well, concider I want to serve fairly static content; collections of
> articles etc, with navigation elements built up from metadata from some
> backend that may do fancy things like versioning, or whatever; a URI
> schema for a one-time-object-instance you can only recreate by going
> though a set of links from the start of the site each time isn't very
> optimal for that sort of layout.  Even things like weblogs are better
> off having URI's like /article/yyyy/mm/dd/id or so.
> 
> Sorry, I haven't looked hard enough at iowa to work out how things like
> this work in it - can URI schemas like that be supported using it?

Not really.  I mean I guess there's nothing to stop you parsing the end 
of the path instead of the parameters to get data but it's much less 
generic.

>>So while you could shorten the URI a little it still needs to contain
>>some numbers to make things work smoothly.
>>
> 
> What about if you're just serving content and don't need to worry about
> state (much)?  Bog standard URI schemes which contain a path to a
> resource are really all I want

Well, then you probably don't want Iowa for that application.  The 
benefits of Iowa are really related to the transparency of state 
management and the HTTP request/response mechanism.  If all you are 
doing is displaying some rendering of database data, Iowa is not 
necessarily the best fit.

The thing is, the contents of a page (like even which components are 
being displayed) is totally variable each time the page is viewed 
(depending on the state of any number of variables) so you can't just 
specify the page name in the URI, you really need to specify a value 
that uniquely identifies that particular "instance" of a page view.  The 
decision of what action to perform is made by the object that you are 
viewing at the time you perform the action (as opposed to some other 
page that you are submitting to as in PHP, ASP, etc.) so you have to get 
back to that same object before you can figure out what action to do.

Does that make any sense?

To look at your example above, I can't just go to /article/yyyy/mm/dd/id 
because I'm not just viewing that article, I'm viewing that article 
with, for example, word wrapping turned on, a setting that only displays 
30 lines at a time with a link to the next 30 lines, etc, etc... there's 
too much state to pass around in the URI, and if you did it would be 
even uglier than it is now.

One solution is to just store all this information keyed by a session 
ID, but then when you hit the back button things get screwed up.  With 
Iowa, you can hit the back button and choose another link and program 
flow will continue as if you had clicked that link in the first place. 
The variables will all have the values that they had when you were in 
that page the last time (obviously you can explicitly store data in the 
session that represents more "global" settings).  This backtracking 
behaviour makes for a much safer experience when using a web 
application, IMO.

Note we have added several different backtracking configuration options 
in Seaside, and are considering having a set of pages marked as a 
transaction so you can backtrack to before that transaction began but 
not into the middle of it.

>>If you really cared about the URI's you could probably have a frameset
>>with just one frame or something and put the iowa page in the frame.
>>Then browsers wouldn't show the URI changing, they just show the URI
>>of the frameset - I think.
>>
> 
> Sorry, I'm afraid you're going to burn in the fiery pits of hell for all
> eternity for suggesting something 10x worse than messy URI's ;)

My god, you're right... I can't believe I actually advocated frames... 
where's that soap, I feel dirty! :)  Actually, I didn't really 
*advocate* it, just pointed out that you could do it if you cared about 
the URI's :)

I notice I deleted your comment about security which I meant to reply 
to.  I agree this is a problem.  We intend to add support for 
authentication which would help a little (for expired sessions, etc), 
and not showing the session-id in the URI (ie. putting it in a cookie) 
also helps at some level.  We've also thought about storing the IP 
address of the user and only allowing connections to their session from 
that IP.  Obviously all these items have pros and cons and need to be 
configurable.  If you have any other ideas that would help please 
mention them. We haven't really adressed this yet but we should.

In closing, I should reiterate that Iowa is great for designing web 
*applications* but not so great for desiging web *sites*.  I keep 
thinking we should be writing our web site using Iowa as a proof of 
concept, but I don't think it works very well - for the exact reason 
that you want to be able to bookmark it... it isn't really an 
application, just a bunch of static, or quasi-dynamic content.

Phew, long message, hope it clarifies some,

Julian

-- 
julian@beta4.com
Beta4 Productions (http://www.beta4.com)

In This Thread