[erlang-patches] Return end locations in erl_scan
Anthony Ramine
n.oxyde@REDACTED
Wed Mar 20 15:26:52 CET 2013
I forgot an important point: epp sitting between erl_scan and
erl_parse complicate things, as the text value of a token may
not correspond to what is actually written in the source file.
Regards,
--
Anthony Ramine
Le 20 mars 2013 à 15:22, Anthony Ramine a écrit :
> It doesn't, as my patch doesn't rely on the 'text' option of
> erl_scan being set.
>
> Currently, when the compiler parses a file, it does not keep
> in memory the text values of every token. I can understand
> why you thought it's redundant if you were thinking the
> start + the length would suffice. But now you are suggesting
> I keep track of every text value to avoid having both a start
> and an end.
>
> The lexer does not need to do extra work to keep track of end
> locations, otherwise how would it know the start location of
> the next token? It already has in memory, at some point, the
> end location of each token it scans. All this patch does is
> make it available when it returns.
>
> Furthermore, let's put back this patch in the context of
> diagnostics and thus parse ranges:
>
> You are right when you say that {'+',[{line,1},{column,1},{'end',{1,2}}]}
> and {'+',[{line,1},{column,1},{length,1}]} are equivalent.
>
> Just the same, {integer,[{line,1},{column,1},{'end',{1,2}}],1} and
> {integer,[{line,1},{column,1},{length,1}],1} are also equivalent.
>
> But how can I compute the locations range of "1 + 2"? You are
> suggesting that I try to compute the length of this thing, by
> substracting the start locations of "2" and "1" and then adding
> the length of "2". That would give me the whole length of the
> {op,...,'+',...,...} node. But what about nodes that span more
> than one line? To cover these cases, you are suggesting I keep
> track of the text of the tokens. Should I compute the text of
> the whole node? What about memory usage? That would be a pain
> in the ass for huge files, like erl_parse.erl.
>
> By keeping track of the end location, I introduce nearly no
> additional overhead in the scanner, and I can keep things simple
> and constant in memory usage while computing the location ranges
> of AST nodes in the parser.
>
> I don't see how this information can be computed easily (and
> correctly) by either keeping the length or the text values, but
> feel free to prove me wrong on this.
>
> Also, feel free to tell me if I'm not clear enough, I'm enjoying
> this conversation a lot and would love to receive constructive
> feedback again.
>
> Regards,
>
> --
> Anthony Ramine
>
> Le 20 mars 2013 à 14:06, Vlad Dumitrescu a écrit :
>
>> Hi,
>>
>> The multiline elements could be handled with the help of an utility that given a string and a (starting) position can compute the end position. I would hope that the implementation already has it in one form or another.
>>
>> regards,
>> Vlad
>>
>>
>>
>> On Wed, Mar 20, 2013 at 2:00 PM, Anthony Ramine <n.oxyde@REDACTED> wrote:
>> Hi Vlad,
>>
>> Thanks for the quick reply.
>>
>> The length of the token is defined as its length in characters. That is all
>> fine for most tokens that are on a single line, but things go to hell when
>> you take into account multiline strings, atoms and chars.
>>
>> --
>> Anthony Ramine
>>
>> Le 20 mars 2013 à 13:49, Vlad Dumitrescu a écrit :
>>
>>> Hi Anthony,
>>>
>>> Don't the tokens have a start position and a length? Why do you need an explicit end position?
>>>
>>> regards,
>>> Vlad
>>>
>>>
>>>
>>> On Wed, Mar 20, 2013 at 1:44 PM, Anthony Ramine <n.oxyde@REDACTED> wrote:
>>> Hi,
>>>
>>> Replying on list because I think it's important.
>>>
>>> As I said to someone I don't remember the name, this patch is only a
>>> necessary step to what my final goal is: Clang-like diagnostics for
>>> Erlang compilation [1]. Is that something the OTP team wouldn't like
>>> to see?
>>>
>>> How is the end location in tokens redundant? I need the end locations
>>> of each tokens to be able to compute the location ranges of each node
>>> in the AST, see my work-in-progress commit for more informations [2].
>>>
>>> That being said, I am interested in having your feedback about the
>>> implementation.
>>>
>>> Regards,
>>>
>>> [1] http://clang.llvm.org/diagnostics.html
>>> [2] https://github.com/nox/otp/commit/2c8038c#diff-1
>>>
>>> PS: Sorry Hans for replying twice, I failed the Cc header.
>>>
>>> --
>>> Anthony Ramine
>>>
>>> Le 20 mars 2013 à 13:23, Hans Bolinder a écrit :
>>>
>>>> Hi Anthony,
>>>>
>>>> Sorry for not replying sooner.
>>>>
>>>> We'll most likely reject you patch. I asked Vlad Dumitrescu about it,
>>>> and he agrees with me that the functionality (the end location of
>>>> tokens) is redundant.
>>>>
>>>> Apart from that: when it comes to the implementation there are a few
>>>> things I don't approve of, but I need to take a closer look before
>>>> saying anything more. You've put in a good effort here, and I intend
>>>> to elaborate a little more on the implementation when I find the time
>>>> to investigate in more detail.
>>>>
>>>> Best regards,
>>>>
>>>> Hans Bolinder, Erlang/OTP team, Ericsson
>>>
>>> _______________________________________________
>>> erlang-patches mailing list
>>> erlang-patches@REDACTED
>>> http://erlang.org/mailman/listinfo/erlang-patches
>>>
>>
>>
>
More information about the erlang-patches
mailing list