Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl Monk, Perl Meditation
 
PerlMonks  

Re^4: Why does Perl have typeglobs? (pads)

by LanX (Archbishop)
on Jul 10, 2014 at 22:18 UTC ( #1093142=note: print w/replies, xml ) Need Help??


in reply to Re^3: Why does Perl have typeglobs? (pads)
in thread Why does Perl have typeglobs?

> 3) a hash by "$sigil.$name" (where the values are of various types)

which is what padwalker returns in a hash.

> but that might not be the best choice in C (and we don't have a complete set of sigils).

I wasn't sure about the pad (thats why I said "at least").

Actually pads are organized more or less like AoA with the first sub-array holding the Sigil+Name keys for each "column". (recursive functions have a row for each recursion, reference Panther book)

But I don't see why changing the first AV with the "sigiled" keys to a HV with indexes to the value AVs shouldt be a problem in C.

> Where did you read the word "need"?

Implicitly. It's an interpretation of how you replied.

You may have meant it differently, but others may not, hence the correction.

Cheers Rolf

(addicted to the Perl Programming Language)

  • Comment on Re^4: Why does Perl have typeglobs? (pads)

Replies are listed 'Best First'.
Re^5: Why does Perl have typeglobs? (C, HV)
by tye (Sage) on Jul 10, 2014 at 23:12 UTC

    > Where did you read the word "need"?

    Implicitly. It's an interpretation of how you replied.

    Perhaps you should read to the end?

    What's an obvious way to implement that?

    "An obvious way" is very much not "the only way".

    But I don't see why changing the first AV with the "sigiled" keys to a HV with indexes to the value AVs shouldt be a problem in C.

    Because, as I noted, we don't have sigils for every type of slot in a typeglob. The "in C" part was about there being different value types. To have a value type that could be any of the 6 or so typeglob slot types would be at least complex. It would be complex enough that I would have qualms about that choice.

    It turns out that a Perl 5 SV can already be any of those types. But SVs didn't even exist in Perl 4 so they couldn't be how typeglobs were implemented (in Perl 1.0).

    The polymorphic SVs are indeed quite complex. The "normal" SV types have much better motivation for how they were done, to my mind, because an SV can transition between those different flavors. Stuffing formats and "IO"s into the polymorphic SV family of structs makes much less sense to me. I couldn't find any part of the Perl source code where this fact was actually useful (I didn't spend that long trying, though) and yet it adds significant complexity, IMHO.

    Searching for "PVFM" in the Perl source code mostly finds places where such are not supported.

    I'm glad Larry didn't start off trying to implement fully polymorphic SVs in Perl 1.

    - tye        

Log In?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://1093142]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others imbibing at the Monastery: (5)
As of 2019-08-24 18:23 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found

    Notices?