This is the mail archive of the guile@cygnus.com mailing list for the guile project.
Index Nav: | [Date Index] [Subject Index] [Author Index] [Thread Index] | |
---|---|---|
Message Nav: | [Date Prev] [Date Next] | [Thread Prev] [Thread Next] |
Ok, I've changed this around to use the alist format, added most of the suggested additions, and included an example submission for guile itself. Happy reading! :) ==mail.txt== This is the revised format for email entries; new bits include: Moved to an alist format. mailing-list: for describing mailing lists associated with the project. help-wanted and testers-wanted are now descriptions, rather than true or false values. This is so you can describe exactly what you want help with (porting, new features, etc...) and what really needs to be tested (the ports, the new features, etc...). author has been removed, and replaced with authors. I'd think that, in a lot of cases, it's very rare for a free-software project to have just one person who deserves mention. contact has been replaced with maintainer, and now includes a name as well as an email address. This isn't folded into authors; the reasoning for this can be easily seen from guile itself, which has several people who should be credited as authors, but most of these shouldn't really be included as contacts (Aubrey Jaffer works on scm, for example). So, you'd have (not exhaustive, a more complete one is given at the end): (authors "Aubrey Jaffer") (maintainer (email "Jim Blandy" "jimb@red-bean.com")) A sample for guile itself is included. ==end new bits== Contributors: lotsa people on the list (sorry, but I'm not in the grep through my mail archive kinda mood right now... in any case, suggestions were and are appreciated). Conventions: The format for a submission is an alist. Not only is it easy to parse, but should be pretty easy for schemers to deal with :). For each field, you have: (field description) field is the field being modified. the description is a collection of strings and/or markup directives. Notes: It's not going to be possible to completely avoid human intervention with submissions. For example, there's nothing stopping some a-hole from sending a couple of thousand projects with names like "aaaaa", "aaaab", etc; if everything goes in, you could easily exhaust disk space on the server, as well as making the actual list itself unusable (and probably a tremendous hassle to fix). What will be needed is a handful of volunteers to act as trusted intermediates for initial submissions; basically, it would just involve each initial submission to be sent to a few of those people, each able to verify the submission. This doesn't prevent mailbombs (though the fact that every person doesn't get every submission helps a little), but then nothing really does except for the existance of a working brain (which probably should be a prerequisite for net access, but sadly that isn't the case). Markup Directives: There are a few markup directives to make it easy to represent the different types of information you'd like to put in a project description. (url loc [text]): this describes a Uniform Resource Locator. loc is the url itself, while text is the optional description for the link in a webpage. An example would be (url "http://home.thezone.net/~gharvey/guile" "Greg's Guile Page") Which will output the html: <a href="http://home.thezone.net/~gharvey/guile">Greg's Guile Page</a>. Or plaintext: http://home.thezone.net/~gharvey/guile [Greg's Guile Page] If no text is given, the link itself will be used. (email name addr): this gives a person and an email address for that person. (possibly one of url or email should be modified to be consistant with each other? (email addr name) seems a little odd, though). Commands: %start : appears at the beginning of each mail; possibly superfluous, but makes it easier to get right to the important stuff without having to grovel over mail headers. This is the only thing not being moved to the alist thing. (name project-name): Must be unique. If it isn't, you'll get back an unable to update message (since you won't have the correct password). (password pass): this is an optional password for the entry (the alternative is gnupg signed messages, though this is likely to be implemented first). If given on the first email it sets the password (rather than randomly generating one); in subsequent mails, it's used to verify the modification. A second password entry will set a new password. The rest of the commands will totally modify the given field of the record. ;;; Not really sure if undo is a great idea, since I'm not quite sure ;;; how you'd do that with any given database (I'm not database guy) (undo): this should only be given alone, and will reset the project entry to it's state before the last update. For example, say you've written a Ford Pinto simulator, and you release v1.2 (am I the only person who finds periods occasionally very annoying when talking about software... at least a parenthical addition makes it sane to add the period ;). So, you send a message as follows: %start ((name "Pinto Simulator") (password "pinto forever!") (status "The current version is 1.2, and includes numerous reality " "enhancements."))) Unfortunately, this version is a little too realistic, as you quickly start getting reports of computers exploding into flames while running the Pinto Simulator. So, you can just send the message: %start ((name "Pinto Simulator") (password (pinto forever!)) (undo)) Which is probably more convienient than having to repeat the previous status (if you even remember what the previous status was), and gives you more time to run for the fire extinguisher. (location (url loc [text])): this should be a pointer to the homepage of the project, or the distribution if no page is available. (catagory cat): this will be one of a set of pre-defined catagories. Basically, things like Application/Game or Library (module?) (description desc): this should be a brief description (no more than a paragraph) of the project. (authors name ...): the main authors of the project. Each entry should be a name, and optionally an email address for the author. Basically, for each author, you either have a string, or an (email name mail). (maintainer name): the current maintainer of the project. (mailing-list description): if the project has a mailing list, it should go there. (status description) : the status of the project (maybe this should be called news? I'd expect that you'd want to update this whenever something interesting happens) (help-wanted description): indicates whether additional programmers are wanted/needed. (testers-wanted description): indicates whether the project wants people to test certain things (of course you want people to use it, but you may really need someone to test the port to Foonix). (license description): describe the licensing of the package (i.e. GPL). (requires description): things required to use the project. (keywords description): this provides a set of key words that can optionally refer to the project. See guile below for an example. Basically, choose these to cover *major* features/uses when the single catagory isn't quite enough. Other features: A full modification history should be kept (and accessable from the page) for the status field. The rest should probably get at least 2 levels of undo information, which don't necessarily need to be made available for public consumption. It might be a good idea to allow just bare words (i.e none of that quoting) for entries, so you could do: ((name Greg's Fantastical Guile Thing)) Spacing is a problem here, though, if plaintext is to be generated. Sample: This is a sample entry for guile itself (authors taken from the distribution's AUTHORS file... you probably wouldn't want to include this many... rather, just include major authors, and a link an authors file). Also, I'm not quite sure if that's the actually correct method of subscribing to guile@cygnus.com (it's been a while, and I've since changed computers and had a major hd crash). %start ((name "guile") (password "Greg is a froody guy") (catagory "Core") (keywords "Extension Language" "Scheme" "Interpreter") (description "The Guile blurb that I don't feel like looking up right " "now") (location (url "http://www.guile.org" "The Guile Webpage")) (authors "Aubrey Jaffer, George Carrette, Radey Shouman, Gary Houston, " "Tom Lord, Anthony Green, Mikael Djurfeldt, Mark Galassi, " "Marius Vollmer, R. Kent Dybvig, Roland Orre, Michael " "N. Livshin") (maintainer (email "Jim Blandy" "jimb@red-bean.com")) (mailing-list (email "Guile mailing list" "guile@cygnus.com") " is the main list for guile, used for " "both general discussion and user questions; " (email "bug-guile" bug-guile@gnu.org) " is the list for reporting bugs; " (email "guile-sources" "guile-sources@gnu.org") " is for posting guile sources. " "To subscribe to the guile list, send mail to " (email "guile-request" "guile-request@cygnus.com") ", with Subject: subscribe your-email-address " "To subscribe to bug-guile or guile-sources, " "send mail to " (email "bug-guile-request" "bug-guile-request@gnu.org") " or " (email "guile-sources-request" "guile-sources-request@gnu.org") " with Subject: subscribe your-email-address.") (status "The current release of guile is 1.3; it is still undergoing " "many changes, but is stable enough for everyday use. Planned " "features include an object system, an enhanced module system " "and native threads support") (help-wanted "Cool hackage always appreciated.") (testers-wanted "Go for it!") (license "GPL, with an exception to allow non-GPL'd programs to " "link to the library without becoming derivitive works.")) -- Greg