Perl 6 mailing list summary for the month of June, 2006

   Summary updates

    This post continues with the task of addressing the Perl 6 summary backlog.
    The following schedule is planned for the remaining updates:

    * 13 August: July
    * 20 August: August to date

    After the 20th of August I hope to return the summaries to a weekly
    schedule.


 perl6-users

  class introspection and extension <http://xrl.us/qc4r>

    Max Demmelbauer is in the process of porting his web-framework project to
    Perl6 had had a question on how he could serialize objects and extend a
    class. Thomas Wittek offered an example of syntax and gave links to the
    documents the information was derived from. Conrad Schneiker noted that he
    and other people on the #perl6 IRC channel would be happy to help if the
    mailing list didn't yield answers.

  Conditionally included list elements <http://xrl.us/qc4s>

    A. Pagaltzis asked if Perl 6 has a construct to express conditionally
    included list elements, which require several steps in Perl 5. A couple of
    people responded with suggestions.

  Revised Perl++ Wiki Proposal / $1k bounty <http://xrl.us/qc4t>

    Discussion on the prize for a Perl 6 wiki written in Perl 6 continued (RE:
    $1,000 prize for Perl 6 Wiki written in Perl 6 <http://xrl.us/qc4u>), with
    Ovid clarifying what the Perl Foundation would require in order to get
    involved.

    This led to Conrad Schneiker starting this thread, outlining his revised
    proposal: namely, to install twiki and gradually convert it to Perl 6. The
    prize would be offered to the group or person who performed a series of
    tasks Conrad listed. There was some discussion on the new proposal.

    Meanwhile, the original thread spawned several other conversations:

    * Name of this wiki <http://xrl.us/qc4v>
    * Perl++ Wikicosm <http://xrl.us/qc4w>
    * OT: wiki engine architecture <http://xrl.us/qc4x>
    * OT: "my wiki syntax is better than yours" <http://xrl.us/qc4y>

    May's summary <http://xrl.us/qc4z> contains a description with how the wiki
    project began.

  Multi Method Questions <http://xrl.us/qc42>

    Chris Yocum had some questions about multi keyword and multimethods in
    general. Steffen Schwigon advised reading S06. Steffen then asked when his
    examples would be used in practice. Several people responded.

    The next thread <http://xrl.us/qc43> grew out of the discussion.

  Can foo("123") dispatch to foo(Int) (was: Multi Method Questions)
  <http://xrl.us/qc43>

    This thread grew out of Multi Method Questions <http://xrl.us/qc42>, with
    Markus Laire asking for clarification. The discussion continued in
    perl6-language.

 perl6-language

  Synchronized / Thread syntax in Perl 6 <http://xrl.us/prkj>

    John Drago asked if the syntax for synchronized and threaded restrictions
    had been worked out. This led to a discussion on the term 'synchronized'
    and alternative phrases, such as 'is serial', 'locked' and 'is exclusive'.
    A number of people, including Larry Wall, replied with syntax suggestions.

  Concurrency: hypothetical variables and atomic blocks <http://xrl.us/prkk>

    Jonathan Lang asked how an atomic block differs from one where all
    variables are hypotheticalized, and why the 'retry' exit statement would be
    needed. Several people noted differences, which led to a lengthy discussion
    on different types of locking.

  About default options ':ratchet' and ':sigspace' on rules
  <http://xrl.us/qc44>

    Shu-chun Weng, who is working on 'MiniPerl6' in Pugs, uses a Perl 6 grammar
    to describe `Pugs::Grammar::MiniPerl6` and had two suggestions on how rules
    could be changed to make them easier to write: ignore spaces where they are
    irrelevant, and change `:P5/\s+/` to use `\s*`. Patrick R. Michaud had
    examples of why ignoring whitespace might be problematic, and recommended
    using a token statement instead. Information about the
    `Pugs::Compiler::Rule`'s parsing was added by Audrey Tang to S05 in r9442.

  Perl5 -> Perl 6 Translations Design Document <http://xrl.us/qc45>

    Sage La Torra was working on a design document detailing translations and
    asked for review. Jonathan Worthington found a possible edge case, and
    Larry Wall clarified. Several other people had minor suggestions.

  ~~ with * <http://xrl.us/qc46>

    Daniel Hulme wrote about the two positions on how smart-matching against
    booleans should work. Larry Wall added some clarification on `when .true`,
    `when True`, and deprecated `when true`. Eric had some further thoughts on
    booleans.

  statement-ending } with if <http://xrl.us/qc47>

    Daniel Hulme asked if someone could explain how `}` on a line can end a
    statement (as described in S04), but can also be used in an uncuddled else.

  YAPC::NA Synopsis Hackathon <http://xrl.us/qc48>

    Uri Guttman proposed a synopsis edit hackathon at YAPC::NA Chicago.

  easier duck typing in .can <http://xrl.us/qc49>

    Yuval Kogman suggested that `.can` would be extended to allow
    `$object.can(Class)` and `$object.can(Role)`. Sam Vilain wanted to know why
    `.does` or `.isa` couldn't be used in this context. Yuval explained that
    this would be useful if you do not control an $object's class.

  Parrot 0.4.5 Released! <http://xrl.us/qc5a>

    Leopold Toetsch announced the release of Parrot 0.4.5.

  lvalue functions and lvalue parameters <http://xrl.us/qc5b>

    Daniel Hulme had a question concerning the workings of lvalues. Jonathan
    Scott Duff offered his opinion on what he would expect in each of the cases
    Daniel presented. Sam Vilain also weighed in.

  bind variable name to type <http://xrl.us/qc5c>

    Daniel Hulme asked if it would be useful to have a way of 'binding' a
    variable name to a given type in a specific lexical scope, so that every
    time a variable with that name is declared within the scope it receives the
    same type.

  Classy logging for Classes <http://xrl.us/qc5d>

    Szilakszi B?lint posted a request to collect ideas on how optional logging
    could be added to classes. Yuval Kogman added a suggestion, but added that
    he felt the most useful logs are manually added to give the most meaningful
    information.

  type name 'str' in Synopsis <http://xrl.us/qc5e>

    Darren Duncan noticed in S12 that the 'Enums' section refers to a 'str'
    type but S06 does not. He suggested updating the documentation.

  features of and declaring Mapping|Set|Hash values|variables
  <http://xrl.us/qc5f>

    Darren Duncan has seen similarities between features of the Set type,
    Mapping type and the Hash type and wondered if some features could be
    expanded. Sam Vilain commented on several of the points.

  Delegating and defining a method at the same time <http://xrl.us/qc5g>

    Adriano Ferreira asked what would happen if a class both handles something
    via `has` and also uses `meth` to introduce an alternate definition.

  [svn:perl6-synopsis] r9725 - doc/trunk/design/syn <http://xrl.us/qc5h>

    In response to Audrey Tang's commit, Aaron Crane noted that he understood
    why 'environmental' had been changed to 'contextual' but questioned whether
    'contextual' was the best alternative because 'contexts' already have a
    meaning. He proposed 'ambient variables'. Audrey responded that a context
    is passed along with your calls, and in that sense 'want' is a contextual
    variable.

 perl6-internals

  [perl #38594] [BUG] source line numbers <http://xrl.us/qc5i>

    In February, Leopold Toetsch noted in ticket [perl #38594]
    <http://xrl.us/qc5j> that source line information is off by at least one on
    several instructions in PASM/PIR. Vishal Soni started to look in to the bug
    in June, and in July the patch was applied.

  namespace bug 2? <http://xrl.us/qc5k>

    In April, Will Coleda reported that `find_global` is affected by the
    .namespace directive, when he thought it should only be affected by the
    .HLL directive, and Chip Salzenberg made a correction.

    In June, Leopold Toetsch noted that `NameSpace.parent()` is now
    implemented. There was a brief discussion on this new feature.

  [perl #38964] .sub names can't be Unicode. <http://xrl.us/qc5m>

    Will Coleda created a ticket ([perl #38964] <http://xrl.us/qc5n>) because
    `.sub` names written in unicode gave errors. Leopold Toetsch fixed it in
    r12863 and noted that additional tests would be welcome.

  [perl #39244] [PATCH] Initialize I and N registers. <http://xrl.us/prnv>

    Andy Dougherty created ticket [perl #39244] <http://xrl.us/qc5o> to offer a
    patch to initialize I and N registers, because they are 0 in DEBUGGING
    builds, but in non-debugging builds they are not consistently set. Leopold
    Toetsch applied a modified version of the patch.

  [perl #39245] [PATCH] Update Platforms -- Late May 2006 <http://xrl.us/prnw>

    In May, Andy Dougherty created ticket [perl #39245] <http://xrl.us/qc5p> to
    introduce a patch to include updates from his Solaris 8 results, and to
    update the `PLATFORMS` document in general. Leopold Toetsch applied the
    patch in June.

  [perl #39255] Revision 12862 fails tests on OS X <http://xrl.us/qc5q>

    Tim Bunce authored ticket [perl #39255] <http://xrl.us/qc5r> to report
    failing tests. These were previously known issues, according to Will
    Coleda, but he was later able to report that as of r12867 they were fixed.

  Parroters in Frappr <http://xrl.us/qc5s>

    Alberto Sim?es reported that there is a map of people working on Parrot and
    invited people to add themselves to it.

  grammar: difference between rule, token and regex <http://xrl.us/qc5t>

    Rene H. M?ller asked for a clarification on the differences between rule,
    token and regex. Jerry Gay suggested S05 for information on the recent
    changes on these topics. Patrick R. Michaud also provided a quick summary.

  [perl #39272] failures in languages/tcl/t/cmd_lsort.t <http://xrl.us/qc5u>

    Will Coleda created ticket [perl #39272] <http://xrl.us/qc5v> to report
    failing tests that he was unable to isolate.

  STM frontend design docs <http://xrl.us/qc5w>

    Charles Reiss included a design for the PASM-visible interface to software
    transactional memory, which is also available at <http://xrl.us/qc5x>. He
    requested comments. Leopold Toetsch replied.

  [perl #39313] [TODO] or [BUG] improve PMC compiler <http://xrl.us/qc5y>

    In ticket [perl #39313] <http://xrl.us/qc5z>, Leopold Toetsch described
    some code which is just ignored by the PMC compiler and invited patches.
    Klaas-Jan Stol identified the location of the problem but could not fix it.
    Joshua Juran added some comments as well.

  Inconsistent find_global 'not found' handling <http://xrl.us/qc52>

    Bob Rogers reported that if a namespace key with a single component is not
    found, Parrot reports the error, but if the namespace name is compound, a
    null PMC is returned. He supplied a patch to make it throw an error as
    well.

  [perl #39329] Check to make sure PMC_str_val, etc. are used appropriately
  <http://xrl.us/qc53>

    Matt Diephouse wrote ticket [perl #39329] <http://xrl.us/qc54> to note that
    `PMC_str_val` and relatives are not guaranteed to work for subclasses.

  [perl #39378] Pheme Segfault with Keyed Class Names <http://xrl.us/qc55>

    Chromatic penned report [perl #39378] <http://xrl.us/qc56> to describe a
    failure he encountered with tests after applying a patch to port Pheme's
    class names to the new keyed style. Leopold Toetsch felt that it might be a
    GC bug. A fix was applied in r12950.

  [svn ci] .Net to PIR translator <http://xrl.us/qc57>

    Jonathan Worthington posted the URL of his dissertation
    <http://xrl.us/qc58> on translating .Net assemblies to PIR.

  A question about .begin_eh <http://xrl.us/qc59>

    Bob Rogers requested some clarification of a portion of
    `pdd23_exceptions.pod` from late May, dealing with `.begin_eh`. He wondered
    if this meant that the current process of searching for an
    Exception_Handler object on the control stack would be replaced with a
    search through sub metadata when an error is thrown, and asked about how it
    would interact with `pushaction`. Chip Salzenberg agreed that Bob's
    interpretation of the plan was correct and noted that no resolution had
    been reached with `pushaction`. A discussion on the merits of different
    ways of handling it ensued.

  [perl #39425] [TODO] namespaces: store_global variant <http://xrl.us/qc6a>

    Will Coleda created ticket [perl #39425] <http://xrl.us/qc6b> to request a
    `store_global` opcode that accepts a multi-element NS key. Jonathan
    Worthington implemented it.

  [perl #39426] [BUG] Can't build with cygwin. <http://xrl.us/qc6c>

    In [perl #39426] <http://xrl.us/qc6d>, Will Coleda reported that the Cygwin
    build fails in r12926.

  [perl #39430] Method cache not always invalidated <http://xrl.us/qc6e>

    Jonathan Worthington created ticket [perl #39430] <http://xrl.us/qc6f> to
    report that `Parrot_store_global` and `store_sub` call
    `Parrot_invalidate_method_cache` but `Parrot_store_global_p` and
    `store_sub_p` do not.

  [perl #39454] [TODO] [easy] $svn keyword expansion$ <http://xrl.us/qc6g>

    In ticket [perl #39454] <http://xrl.us/qc6h>, Will Coleda suggested that
    someone clean up the repository to correct unexpanded svn `Id` tags.

  Re: [perl #38788] make test results <http://xrl.us/qc6i>

    Ryan Hinton reported that r12936 was failing. This was in response to Will
    Coleda's request for a check against r12926 or later, which was in itself a
    reply to a FreeBSD failure report from March ([perl #38788]
    <http://xrl.us/qc6j>).

  resumable exceptions <http://xrl.us/qc6k>

    Chip Salzenberg wondered if Parrot exceptions were resumable, and if it was
    important if they were. Larry Wall said that he did not feel it was
    necessary to include special code to make exceptions resumable, but noted
    that documentation was missing. John M. Dlugosz, previously in favor of
    resumption, related the story of his conversion. Larry replied about how
    his initial termination stance had been modified.

  [perl #39483] [TODO] fix PGE::OpTable comments, test. <http://xrl.us/qc6m>

    Will Coleda created ticket [perl #39483] <http://xrl.us/qc6n> to suggest a
    fix. He thought it looked like double '#' were needed for comments. Patrick
    R. Michaud did not have the same experience with r12990.

  Readonly PMCs and types <http://xrl.us/qc6o>

    Leopold Toetsch responded to an IRC comment on the type number and type
    name of read-only PMC variants. Klaas-Jan Stol, Chromatic and Larry Wall
    offered their opinions.

  [perl #38146] [TODO] OS.pmc - file copy 38146 <http://xrl.us/qc6p>

    In January, Will Coleda created ticket [perl #38146] <http://xrl.us/qc6q>
    to request that OS.pmc provide a `copy(source_file.target)` and a
    `copy(array_of_source_files.targetDir)`. There was a long discussion on
    whether this should be done.

    In June, Vishal Soni wrote about an attempt to implement the request in
    this ticket. Leopold Toetsch and Vishal discussed the requirements and
    implementation.

  threading creation syntax proposal <http://xrl.us/qc6r>

    Charles Reiss included a proposal to change the syntax for the creation of
    threads, to move away from the three-tiered threading system. Jonathan
    Worthington had a few comments, which Charles responded to.

  [perl #39552] Segfault on FreeBSD during make <http://xrl.us/qc6s>

    David Landgren reported in ticket [perl #39552] <http://xrl.us/qc6t> that
    he was getting a segmentation fault when trying to gmake the latest sync.
    Leopold Toetsch thought it sounded like a conflict with an existing
    installed Parrot, and suggested the removal of any installed Parrot
    libraries.

  [perl #39597] Problems with string constants in method calls
  <http://xrl.us/qc6u>

    In ticket [perl #39597] <http://xrl.us/qc6v>, Matt Diephouse noted that a
    portion of `languages/tcl/src/class/tclcommand.pir` is giving problems for
    Parrot. He later identified `pbc_merge` as the source of the problem, which
    Jonathan Worthington confirmed and fixed in r13020.

  lexical lookup and OUTER:: <http://xrl.us/qc6w>

    Jerry Gay proposed that a three-argument form of find_lex be employed to
    specify where to start finding lexicals in support of `OUTER::` from S04;
    the third parameter would be an integer specifying the level in the chain
    where the lookup should start. Discussion led to the suggestion of an
    opcode.

    Nicholas Clark wanted to know if it was logical to write opcodes such as
    this one in Parrot assembler. Audrey Tang replied, and there were
    additional followups.

  [perl #39615] [TODO] get_outer op not defined in PDDs <http://xrl.us/qc6x>

    Jerry Gay noted in ticket [perl #39615] <http://xrl.us/qc6y> that there are
    tests for `get_outer` in `t/op/lexicals.t` but the opcode is not documented
    anywhere. He thought it should go in PDD20.

  Parrot IO <http://xrl.us/qc6z>

    Vishal Soni wondered if Parrot IO would be implemented with opcodes or PMC.
    Jonathan Worthington replied that the most recent thoughts on the topic
    were in PDD22.

  Search order for load_bytecode et al <http://xrl.us/qc62>

    Jonathan Worthington wondered if the search order for `load_bytecode`
    should be changed to look in the current working directory first, as a
    solution until it is possible to set the search order.

  Parrot Platform API <http://xrl.us/qc63>

    Vishal Soni proposed defining a Parrot platform API that all Parrot ports
    would need to implement, which would remove platform-specific code out of
    the core logic. Nicolas agreed with the proposal, while Nicholas Clark
    noted that Chip Salzenberg was at YAPC::NA and might take some time to
    reply.

  [perl #39638] [PATCH]38594 <http://xrl.us/qc64>

    Vishal Soni created [perl #39638] <http://xrl.us/qc65> to include a patch
    for `imcc.y` to fix a decrementing counter at the start of a `sub` token.

  [perl #39648] PGE - bad variable name <http://xrl.us/qc66>

    In ticket [perl #39648] <http://xrl.us/qc67>, Will Coleda posted Patrick R.
    Michaud's request that `lastpos` be renamed.

  Pm's YAPC::NA talk online <http://xrl.us/qc68>

    Patrick R. Michaud posted slides from his YAPC talks, 'Perl 6 Compiler
    Status and the Parrot Compiler Toolkit' and 'Parser, Perl 6 Rules, and the
    Parrot Grammar Engine'. Audrey Tang thanked Patrick for the talk, and
    included links to her own talk, 'Deploying Perl 6'. Will Coleda's 'Parrot
    Target Practice' slide link was also posted.

    * Perl 6 Compiler Status and the Parrot Compiler Toolkit
      <http://xrl.us/qc72>
    * Parser, Perl 6 Rules, and the Parrot Grammar Engine <http://xrl.us/qc69>
    * Deploying Perl 6 <http://xrl.us/qc7a>
    * Deploying Perl 6 <http://xrl.us/qc7b>
    * Deploying Perl 6 (HTML and images) <http://xrl.us/qc7c>
    * Parrot Target Practice <http://xrl.us/qc7d>

    Jo?o Cruz Morais had some questions concerning Patrick's talk, which
    Chromatic, Jonathan Scott Duff and Patrick answered.

  Namespaces Redux <http://xrl.us/qc7e>

    Matt Diephouse ran in to problems implementing namespace support in Tcl and
    had a few questions. Chip Salzenberg replied, and in the end it was
    determined that some of Matt's requests were already met, and that one
    should be a bug report.

  [BUG] parrot 0.4.5: Configure.pl: tru64 <http://xrl.us/qc7f>

    Jarkko Hietaniemi reported a problem with Parrot with `tgetnum` and asked
    if there was a way to add verbosity to show what commands are being run.
    Leopold Toetsch advised `perl Configure.pl --verbose-step=snprintf`, and
    Jarkko included a more detailed report. Jarkko resolved to get the admins
    to compile a newer `libreadline` after some discussion with Leopold. Will
    Coleda felt the test for readline should be improved. There were some
    discussions on how to do this.

  [perl #39663] [TODO] perl coding standards <http://xrl.us/qc7g>

    Will Coleda wrote in ticket [perl #39663] <http://xrl.us/qc7h> that Perl
    coding standards should be determined, then enforced with a `.perlcriticrc`
    file, and a test should mention files which fail to conform.

  IMCC Register Allocation Algorithm <http://xrl.us/qc7i>

    Vishal Soni suggested changing the register allocation algorithm to 'Linear
    Scan Allocation'. Chromatic thought that it would be nice to have the
    implementation to benchmark, and to have IMCC cleaned up in the process.
    Watson Ladd thought bin packing would be an even better choice.

  [perl #39669] No PIR Compiler Available for Embedded Parrot
  <http://xrl.us/qc7j>

    Chromatic created ticket [perl #39669] <http://xrl.us/qc7k> because there
    is no PIR compiler available for embedded Parrot. Leopold Toetsch said the
    PIR compiler is registered in `imcc_init()`, which should probably be
    called during the Parrot init sequence. Chromatic applied a patch as
    r13066.

  pdd23 <http://xrl.us/qc7m>

    Chip Salzenberg wrote that he had a complete exceptions PDD.

 perl6-compiler

  TGE update <http://xrl.us/qc7n>

    Allison Randal finished a round of refactoring and feature additions to
    Parrot's tree grammar engine (TGE). She posted a summary of the changes.

  Perl6 without GHC or Parrot? <http://xrl.us/qc7o>

    Andy Dougherty looked in to whether it would be possible to deploy Perl6 on
    a system which runs neither GHC nor Parrot using v6-pugs. Flavio S. Glock
    offered some installation help. There was some further discussion on the
    state of the project.

  Re: State of Perl6 Backends <http://xrl.us/qc7p>

    Audrey Tang replied to Swaroop C H's post asking about the numerous Perl6
    backends, offering clarification on the different implementations. There
    was additional discussion on the state of the implementations, with
    Chromatic also joining in. Uri Guttman mentioned the Chicago YAPC docathon
    could work on making this clearer.

  problem compiling UTF8 on Win32 <http://xrl.us/qc7q>

    A problem was reported with compiling UTF8 on Win32, but the same poster
    discovered that `PUGS_EMBED` had been set tp 'perl5' and removing the
    setting fixed the problem.

   Acknowlegements

    Yuval Kogman helped once again.

    If you appreciate Perl, consider contributing to the Perl Foundation
    <http://donate.perlfoundation.org> to help support the development of Perl.

    Thank you to everyone who has pointed out mistakes and offered suggestions
    for improving this series. Comments on this summary can be sent to Ann
    Barcomb, <[EMAIL PROTECTED]>.

 See Also

  * Perl Foundation activities <http://blog.perlfoundation.org>

  * Perl 6 Development <http://dev.perl.org/perl6>

  * Planet Perl Six <http://planetsix.perl.org/perl6>

Reply via email to