caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
* [announce] O'Browser : OCaml on browsers
@ 2008-11-17 16:20 Benjamin Canou
  2008-11-18  3:43 ` [Caml-list] " Kuba Ober
                   ` (4 more replies)
  0 siblings, 5 replies; 14+ messages in thread
From: Benjamin Canou @ 2008-11-17 16:20 UTC (permalink / raw)
  To: caml-list

  Hi,

O'Browser is an implementation of the OCaml virtual machine in 
JavaScript, designed to run in web browsers.
It features a runtime library compatible with OCaml's standard one 
(including OOP and concurrent threads) and bindings of some JavaScript 
functions to manipulate the DOM primitives.

The distribution is available at [1] and an online version of the 
tutorial is reachable at [2].

Please note that this is an early version, in particular the DOM 
interface module is neither pretty nor well typed.
However, it can already be used to create little applets or scripts (as 
in the tutorial [2], the examples of the distribution [3] or my webpage 
[4]) and we'll be glad to receive your comments or bug reports.

Have fun.

  Benjamin Canou.

[1] http://www.pps.jussieu.fr/~canou/obrowser-0.1.tar.bz2
[2] http://www.pps.jussieu.fr/~canou/obrowser/tutorial
[3] http://www.pps.jussieu.fr/~canou/obrowser/examples.html
[4] http://www.pps.jussieu.fr/~canou/


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-17 16:20 [announce] O'Browser : OCaml on browsers Benjamin Canou
@ 2008-11-18  3:43 ` Kuba Ober
  2008-11-18  7:33   ` David Teller
  2008-11-18  8:18 ` Jon Harrop
                   ` (3 subsequent siblings)
  4 siblings, 1 reply; 14+ messages in thread
From: Kuba Ober @ 2008-11-18  3:43 UTC (permalink / raw)
  To: caml-list

On Monday 17 November 2008, Benjamin Canou wrote:

> O'Browser is an implementation of the OCaml virtual machine in
> JavaScript, designed to run in web browsers.
> It features a runtime library compatible with OCaml's standard one
> (including OOP and concurrent threads) and bindings of some JavaScript
> functions to manipulate the DOM primitives.
[...]
> Please note that this is an early version, in particular the DOM
> interface module is neither pretty nor well typed.
> However, it can already be used to create little applets or scripts (as
> in the tutorial [2], the examples of the distribution [3] or my webpage
> [4]) and we'll be glad to receive your comments or bug reports.

And the reason is?....

Pardon the question, but is this meant to be "useful" in the future,
or is it just a fun experiment (in which case the next target should
be brainfuck).

My question (why and what for?) is serious, though.

Cheers, Kuba


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-18  3:43 ` [Caml-list] " Kuba Ober
@ 2008-11-18  7:33   ` David Teller
  2008-11-18 18:15     ` Kuba Ober
  0 siblings, 1 reply; 14+ messages in thread
From: David Teller @ 2008-11-18  7:33 UTC (permalink / raw)
  To: Kuba Ober; +Cc: caml-list

On Mon, 2008-11-17 at 22:43 -0500, Kuba Ober wrote:
> > Please note that this is an early version, in particular the DOM
> > interface module is neither pretty nor well typed.
> > However, it can already be used to create little applets or scripts (as
> > in the tutorial [2], the examples of the distribution [3] or my webpage
> > [4]) and we'll be glad to receive your comments or bug reports.
> 
> And the reason is?....

To me, the fact that you can write portable lightweight applets sounds
like a good enough reason. That and the fact that I can see this being
used by stuff like Ocsigen to make for (even) richer client-server
applications.

Just my two cents,
 David
-- 
David Teller-Rajchenbach
 Security of Distributed Systems
  http://www.univ-orleans.fr/lifo/Members/David.Teller
 Angry researcher: French Universities need reforms, but the LRU act brings liquidations. 


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-17 16:20 [announce] O'Browser : OCaml on browsers Benjamin Canou
  2008-11-18  3:43 ` [Caml-list] " Kuba Ober
@ 2008-11-18  8:18 ` Jon Harrop
  2008-11-18 18:18   ` Kuba Ober
  2008-11-18  8:33 ` Florian Hars
                   ` (2 subsequent siblings)
  4 siblings, 1 reply; 14+ messages in thread
From: Jon Harrop @ 2008-11-18  8:18 UTC (permalink / raw)
  To: caml-list

On Monday 17 November 2008 16:20:50 Benjamin Canou wrote:
>   Hi,
>
> O'Browser is an implementation of the OCaml virtual machine in
> JavaScript, designed to run in web browsers.
> It features a runtime library compatible with OCaml's standard one
> (including OOP and concurrent threads) and bindings of some JavaScript
> functions to manipulate the DOM primitives.
>
> The distribution is available at [1] and an online version of the
> tutorial is reachable at [2].
>
> Please note that this is an early version, in particular the DOM
> interface module is neither pretty nor well typed.
> However, it can already be used to create little applets or scripts (as
> in the tutorial [2], the examples of the distribution [3] or my webpage
> [4]) and we'll be glad to receive your comments or bug reports.

This is a really awesome project! Performance is fine on a decent browser. 
Times taken to highlight syntax_common.ml on this machine:

Chrome:     0.5s
Firefox:    1.1s
IE7:        5.7s
Konqueror: 17.5s

Looks like you've got an OCaml bytecode interpreter written in Javascript. 
Could you write a compiler and call eval to get better performance?

I've been thinking about run-time generating code using LLVM that runs in 
OCaml's VM recently. Using that to implement Javascript on top of OCaml's VM 
would be interesting...

Anyway, I think that's a really great piece of work!

-- 
Dr Jon Harrop, Flying Frog Consultancy Ltd.
http://www.ffconsultancy.com/?e


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-17 16:20 [announce] O'Browser : OCaml on browsers Benjamin Canou
  2008-11-18  3:43 ` [Caml-list] " Kuba Ober
  2008-11-18  8:18 ` Jon Harrop
@ 2008-11-18  8:33 ` Florian Hars
  2008-11-18  9:12 ` Paolo Donadeo
  2008-11-18  9:14 ` Burgisser Francois
  4 siblings, 0 replies; 14+ messages in thread
From: Florian Hars @ 2008-11-18  8:33 UTC (permalink / raw)
  To: Benjamin Canou; +Cc: caml-list

Benjamin Canou schrieb:
> Please note that this is an early version, in particular the DOM
> interface module is neither pretty nor well typed.

If you enhance these APIs, you should probably try to coordinate it
with whatever might happen in http://code.google.com/p/ocamljs/
so that source code will be as compatible as possible.

Yours, Florian. 


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-17 16:20 [announce] O'Browser : OCaml on browsers Benjamin Canou
                   ` (2 preceding siblings ...)
  2008-11-18  8:33 ` Florian Hars
@ 2008-11-18  9:12 ` Paolo Donadeo
  2008-11-18  9:14 ` Burgisser Francois
  4 siblings, 0 replies; 14+ messages in thread
From: Paolo Donadeo @ 2008-11-18  9:12 UTC (permalink / raw)
  To: OCaml mailing list

> O'Browser is an implementation of the OCaml virtual machine in JavaScript,
> designed to run in web browsers.

What can I say? WOW, great idea!


-- 
Paolo
~
~
:wq


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-17 16:20 [announce] O'Browser : OCaml on browsers Benjamin Canou
                   ` (3 preceding siblings ...)
  2008-11-18  9:12 ` Paolo Donadeo
@ 2008-11-18  9:14 ` Burgisser Francois
  2008-11-18  9:40   ` Gabriel Kerneis
  4 siblings, 1 reply; 14+ messages in thread
From: Burgisser Francois @ 2008-11-18  9:14 UTC (permalink / raw)
  To: caml-list

Hi,

Good idea but maybe a browser plugin to manipulate DOM would be much more
efficient.
Still pretty instructive.

Franz

On 11/18/08 1:20 AM, "Benjamin Canou" <benjamin.canou@gmail.com> wrote:

>   Hi,
> 
> O'Browser is an implementation of the OCaml virtual machine in
> JavaScript, designed to run in web browsers.
> It features a runtime library compatible with OCaml's standard one
> (including OOP and concurrent threads) and bindings of some JavaScript
> functions to manipulate the DOM primitives.
> 
> The distribution is available at [1] and an online version of the
> tutorial is reachable at [2].
> 
> Please note that this is an early version, in particular the DOM
> interface module is neither pretty nor well typed.
> However, it can already be used to create little applets or scripts (as
> in the tutorial [2], the examples of the distribution [3] or my webpage
> [4]) and we'll be glad to receive your comments or bug reports.
> 
> Have fun.
> 
>   Benjamin Canou.
> 
> [1] http://www.pps.jussieu.fr/~canou/obrowser-0.1.tar.bz2
> [2] http://www.pps.jussieu.fr/~canou/obrowser/tutorial
> [3] http://www.pps.jussieu.fr/~canou/obrowser/examples.html
> [4] http://www.pps.jussieu.fr/~canou/
> 
> _______________________________________________
> Caml-list mailing list. Subscription management:
> http://yquem.inria.fr/cgi-bin/mailman/listinfo/caml-list
> Archives: http://caml.inria.fr
> Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
> Bug reports: http://caml.inria.fr/bin/caml-bugs



^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-18  9:14 ` Burgisser Francois
@ 2008-11-18  9:40   ` Gabriel Kerneis
  0 siblings, 0 replies; 14+ messages in thread
From: Gabriel Kerneis @ 2008-11-18  9:40 UTC (permalink / raw)
  To: Burgisser Francois; +Cc: caml-list

On Tue, Nov 18, 2008 at 06:14:45PM +0900, Burgisser Francois wrote:
> Good idea but maybe a browser plugin to manipulate DOM would be much more
> efficient.

But, sadly, much less portable.

-- 
Gabriel


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-18  7:33   ` David Teller
@ 2008-11-18 18:15     ` Kuba Ober
  2008-11-18 18:32       ` Vincent Balat
  0 siblings, 1 reply; 14+ messages in thread
From: Kuba Ober @ 2008-11-18 18:15 UTC (permalink / raw)
  To: caml-list

On Tuesday 18 November 2008, you wrote:
> On Mon, 2008-11-17 at 22:43 -0500, Kuba Ober wrote:
> > > Please note that this is an early version, in particular the DOM
> > > interface module is neither pretty nor well typed.
> > > However, it can already be used to create little applets or scripts (as
> > > in the tutorial [2], the examples of the distribution [3] or my webpage
> > > [4]) and we'll be glad to receive your comments or bug reports.
> >
> > And the reason is?....
>
> To me, the fact that you can write portable lightweight applets sounds
> like a good enough reason. That and the fact that I can see this being
> used by stuff like Ocsigen to make for (even) richer client-server
> applications.

I presume that one can have some Javascript library to abstract out platform
differences, but to have a whole new language? Well, of course what works
works, the question is if the performance is any good.

Cheers, Kuba


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-18  8:18 ` Jon Harrop
@ 2008-11-18 18:18   ` Kuba Ober
  0 siblings, 0 replies; 14+ messages in thread
From: Kuba Ober @ 2008-11-18 18:18 UTC (permalink / raw)
  To: caml-list

On Tuesday 18 November 2008, Jon Harrop wrote:
> On Monday 17 November 2008 16:20:50 Benjamin Canou wrote:
> >   Hi,
> >
> > O'Browser is an implementation of the OCaml virtual machine in
> > JavaScript, designed to run in web browsers.
> > It features a runtime library compatible with OCaml's standard one
> > (including OOP and concurrent threads) and bindings of some JavaScript
> > functions to manipulate the DOM primitives.
> >
> > The distribution is available at [1] and an online version of the
> > tutorial is reachable at [2].
> >
> > Please note that this is an early version, in particular the DOM
> > interface module is neither pretty nor well typed.
> > However, it can already be used to create little applets or scripts (as
> > in the tutorial [2], the examples of the distribution [3] or my webpage
> > [4]) and we'll be glad to receive your comments or bug reports.
>
> This is a really awesome project! Performance is fine on a decent browser.
> Times taken to highlight syntax_common.ml on this machine:
>
> Chrome:     0.5s
> Firefox:    1.1s
> IE7:        5.7s
> Konqueror: 17.5s
>
> Looks like you've got an OCaml bytecode interpreter written in Javascript.
> Could you write a compiler and call eval to get better performance?

That's what I was gonna suggest: if one could sorta-kinda macro-expand
bytecode interpreter running on some bytecode, then JIT platforms such
as tracemonkey could dramatically improve the performance of such code.

Cheers, Kuba


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-18 18:15     ` Kuba Ober
@ 2008-11-18 18:32       ` Vincent Balat
  2008-11-18 20:01         ` David Thomas
  0 siblings, 1 reply; 14+ messages in thread
From: Vincent Balat @ 2008-11-18 18:32 UTC (permalink / raw)
  To: caml-list; +Cc: Kuba Ober, caml-list

Hi,

On Tuesday 18 November 2008 19:15:28 Kuba Ober wrote:
> On Tuesday 18 November 2008, you wrote:
> > On Mon, 2008-11-17 at 22:43 -0500, Kuba Ober wrote:
> > > > Please note that this is an early version, in particular the DOM
> > > > interface module is neither pretty nor well typed.
> > > > However, it can already be used to create little applets or scripts
> > > > (as in the tutorial [2], the examples of the distribution [3] or my
> > > > webpage [4]) and we'll be glad to receive your comments or bug
> > > > reports.
> > >
> > > And the reason is?....
> >
> > To me, the fact that you can write portable lightweight applets sounds
> > like a good enough reason. That and the fact that I can see this being
> > used by stuff like Ocsigen to make for (even) richer client-server
> > applications.
>
> I presume that one can have some Javascript library to abstract out
> platform differences, but to have a whole new language? Well, of course
> what works works, the question is if the performance is any good.

Our final goal is of course to write the whole Web application in OCaml (both 
server and client sides). And thus to get the same static guarantees for the 
code beeing executed on the browser as we have on server side with Ocsigen 
(for example valid xhtml, etc).

To run OCaml on a browser, there are several solutions: 
For example you can use a compiler to js (see for example ocamljs), or a 
plugin. O'Browser is an alternative. It seems to be efficient enough for most 
uses. For tasks requiring very high efficiency, the only solution is a plugin
_and_ a very efficient xhtml/css rendering engine.

Cheers,
Vincent Balat


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-18 18:32       ` Vincent Balat
@ 2008-11-18 20:01         ` David Thomas
  2008-11-21 15:27           ` Benjamin Canou
  0 siblings, 1 reply; 14+ messages in thread
From: David Thomas @ 2008-11-18 20:01 UTC (permalink / raw)
  To: caml-list

I'd like to see a plugin that makes available to JS a function to execute ocaml bytecode.  There could be a standard way to check for support, and the pure javascript interpreter could be loaded if it is missing (for those browsers/computers on which performance is reasonable).



--- On Tue, 11/18/08, Vincent Balat <vincent.balat@pps.jussieu.fr> wrote:

> From: Vincent Balat <vincent.balat@pps.jussieu.fr>
> Subject: Re: [Caml-list] [announce] O'Browser : OCaml on browsers
> To: caml-list@yquem.inria.fr
> Cc: caml-list@inria.fr
> Date: Tuesday, November 18, 2008, 10:32 AM
> Hi,
> 
> On Tuesday 18 November 2008 19:15:28 Kuba Ober wrote:
> > On Tuesday 18 November 2008, you wrote:
> > > On Mon, 2008-11-17 at 22:43 -0500, Kuba Ober
> wrote:
> > > > > Please note that this is an early
> version, in particular the DOM
> > > > > interface module is neither pretty nor
> well typed.
> > > > > However, it can already be used to
> create little applets or scripts
> > > > > (as in the tutorial [2], the examples
> of the distribution [3] or my
> > > > > webpage [4]) and we'll be glad to
> receive your comments or bug
> > > > > reports.
> > > >
> > > > And the reason is?....
> > >
> > > To me, the fact that you can write portable
> lightweight applets sounds
> > > like a good enough reason. That and the fact that
> I can see this being
> > > used by stuff like Ocsigen to make for (even)
> richer client-server
> > > applications.
> >
> > I presume that one can have some Javascript library to
> abstract out
> > platform differences, but to have a whole new
> language? Well, of course
> > what works works, the question is if the performance
> is any good.
> 
> Our final goal is of course to write the whole Web
> application in OCaml (both 
> server and client sides). And thus to get the same static
> guarantees for the 
> code beeing executed on the browser as we have on server
> side with Ocsigen 
> (for example valid xhtml, etc).
> 
> To run OCaml on a browser, there are several solutions: 
> For example you can use a compiler to js (see for example
> ocamljs), or a 
> plugin. O'Browser is an alternative. It seems to be
> efficient enough for most 
> uses. For tasks requiring very high efficiency, the only
> solution is a plugin
> _and_ a very efficient xhtml/css rendering engine.
> 
> Cheers,
> Vincent Balat
> 
> _______________________________________________
> Caml-list mailing list. Subscription management:
> http://yquem.inria.fr/cgi-bin/mailman/listinfo/caml-list
> Archives: http://caml.inria.fr
> Beginner's list:
> http://groups.yahoo.com/group/ocaml_beginners
> Bug reports: http://caml.inria.fr/bin/caml-bugs


      


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-18 20:01         ` David Thomas
@ 2008-11-21 15:27           ` Benjamin Canou
  2008-11-30 12:09             ` William Le Ferrand
  0 siblings, 1 reply; 14+ messages in thread
From: Benjamin Canou @ 2008-11-21 15:27 UTC (permalink / raw)
  To: caml-list

  Hi,

>From Kuba Ober:
> Pardon the question, but is this meant to be "useful" in the future,
> or is it just a fun experiment (in which case the next target should
> be brainfuck).
Coming soon: the OCaml VM on a turing machine !

>From Burgisser Francois :
> Good idea but maybe a browser plugin to manipulate DOM would be much
> more efficient.
>From Gabriel Kerneis:
> But, sadly, much less portable.
>From Jon Harrop:
> Could you write a compiler and call eval to get better performance?
>From David Thomas:
> I'd like to see a plugin that makes available to JS a function to
> execute ocaml bytecode.

Our plan is to achieve efficiency with a (not yet available) browser
plug-in (the original bytecode interpreter or the native compiler) while
remaining portable by using the JavaScript VM where the plug-in is not
available. So we don't currently focus on optimizing (and complexifying)
too much the JavaScript version.

>From David Teller:
> To me, the fact that you can write portable lightweight applets sounds
> like a good enough reason. That and the fact that I can see this being
> used by stuff like Ocsigen to make for (even) richer client-server
> applications.

Indeed, as Vincent wrote, even if O'Browser is at this point only a
client-side scripting core, it takes place into the Ocsigen project and
will be used to interact with (OCaml) server code (in its current form
or not).

  Benjamin Canou.


^ permalink raw reply	[flat|nested] 14+ messages in thread

* Re: [Caml-list] [announce] O'Browser : OCaml on browsers
  2008-11-21 15:27           ` Benjamin Canou
@ 2008-11-30 12:09             ` William Le Ferrand
  0 siblings, 0 replies; 14+ messages in thread
From: William Le Ferrand @ 2008-11-30 12:09 UTC (permalink / raw)
  To: caml-list

[-- Attachment #1: Type: text/plain, Size: 2715 bytes --]

Hi !

Thank you for this amazing work !

I'm rewriting large parts of my website using this tool, and I may have
found two little bugs :

* get_attribute (in rtjs.js)

when get_attribute "toto" returns a boolean, value_from_string returns the
empty string (this is nasty ..)

(temporary) solution : in rtjs.js, just cast on line 33 with something like

  return value_from_string (v == null ? "" : (v+""));

* input (in js.ml)

it seems that the editable function

    editable = (
      function
          true -> (try  Node.remove_attribute node "disabled" with _  -> ())
        | false -> Node.set_attribute node "disabled" "disabled"
);

works better. (at least it works with buttons, check boxes and so on)

Thank you again !

All best,

William Le Ferrand

www.beouifi.org

2008/11/21 Benjamin Canou <benjamin.canou@gmail.com>

>  Hi,
>
> >From Kuba Ober:
> > Pardon the question, but is this meant to be "useful" in the future,
> > or is it just a fun experiment (in which case the next target should
> > be brainfuck).
> Coming soon: the OCaml VM on a turing machine !
>
> >From Burgisser Francois :
> > Good idea but maybe a browser plugin to manipulate DOM would be much
> > more efficient.
> >From Gabriel Kerneis:
> > But, sadly, much less portable.
> >From Jon Harrop:
> > Could you write a compiler and call eval to get better performance?
> >From David Thomas:
> > I'd like to see a plugin that makes available to JS a function to
> > execute ocaml bytecode.
>
> Our plan is to achieve efficiency with a (not yet available) browser
> plug-in (the original bytecode interpreter or the native compiler) while
> remaining portable by using the JavaScript VM where the plug-in is not
> available. So we don't currently focus on optimizing (and complexifying)
> too much the JavaScript version.
>
> >From David Teller:
> > To me, the fact that you can write portable lightweight applets sounds
> > like a good enough reason. That and the fact that I can see this being
> > used by stuff like Ocsigen to make for (even) richer client-server
> > applications.
>
> Indeed, as Vincent wrote, even if O'Browser is at this point only a
> client-side scripting core, it takes place into the Ocsigen project and
> will be used to interact with (OCaml) server code (in its current form
> or not).
>
>  Benjamin Canou.
>
> _______________________________________________
> Caml-list mailing list. Subscription management:
> http://yquem.inria.fr/cgi-bin/mailman/listinfo/caml-list
> Archives: http://caml.inria.fr
> Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
> Bug reports: http://caml.inria.fr/bin/caml-bugs
>



-- 
William Le Ferrand

E-mail : william@beouifi.org
Mobile : +33 6 84 01 52 92

[-- Attachment #2: Type: text/html, Size: 4148 bytes --]

^ permalink raw reply	[flat|nested] 14+ messages in thread

end of thread, other threads:[~2008-11-30 12:09 UTC | newest]

Thread overview: 14+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-11-17 16:20 [announce] O'Browser : OCaml on browsers Benjamin Canou
2008-11-18  3:43 ` [Caml-list] " Kuba Ober
2008-11-18  7:33   ` David Teller
2008-11-18 18:15     ` Kuba Ober
2008-11-18 18:32       ` Vincent Balat
2008-11-18 20:01         ` David Thomas
2008-11-21 15:27           ` Benjamin Canou
2008-11-30 12:09             ` William Le Ferrand
2008-11-18  8:18 ` Jon Harrop
2008-11-18 18:18   ` Kuba Ober
2008-11-18  8:33 ` Florian Hars
2008-11-18  9:12 ` Paolo Donadeo
2008-11-18  9:14 ` Burgisser Francois
2008-11-18  9:40   ` Gabriel Kerneis

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).