[erlang-questions] Can't run my command line Erlang program
Anthony Molinaro
anthonym@REDACTED
Fri Nov 15 08:52:08 CET 2013
You can add them to your .plt with something like
# dialyzer --add_to_plt --apps crypto stdlib proper ...
Which should get rid of the warnings.
-Anthony
On Nov 14, 2013, at 8:03 PM, Andrew Pennebaker <andrew.pennebaker@REDACTED> wrote:
> Is there a way to clear the "unknown functions" from dialyzer output? They tend to distract from any warnings I'm trying to find.
>
> $ make lint
> erlc -Wall +debug_info ios7crypt.erl
> dialyzer *.beam --build_plt --quiet
> dialyzer *.beam
> Checking whether the PLT /Users/andrew/.dialyzer_plt is up-to-date... yes
> Proceeding with analysis...
> Unknown functions:
> crypto:exor/2
> erlang:binary_to_list/1
> erlang:get_module_info/1
> erlang:get_module_info/2
> erlang:list_to_integer/2
> erlang:now/0
> getopt:parse/2
> getopt:usage/2
> init:get_plain_arguments/0
> init:stop/0
> io:format/1
> io:format/2
> io_lib:format/2
> proper:forall/2
> proper:quickcheck/1
> proper_types:int/0
> proper_types:list/1
> random:seed/3
> random:uniform/1
> string:concat/2
> string:substr/3
> done in 0m0.17s
> done (passed successfully)
>
>
> On Thu, Nov 14, 2013 at 10:59 PM, Andrew Pennebaker <andrew.pennebaker@REDACTED> wrote:
>> I think I was trying to account for errors in parsing integers. In any case, I think my program still works fine without this check, especially as we agree that dialyzer proves it's unnecessary.
>>
>> https://github.com/mcandre/ios7crypt/commit/8d7f7760b15ffa48a5113356803f620f3935c256#diff-7f4a95d512e55854e52ac3744eaafeb1L52
>>
>>
>> On Thu, Nov 14, 2013 at 8:00 PM, Kostis Sagonas <kostis@REDACTED> wrote:
>>> On 11/15/2013 01:46 AM, Andrew Pennebaker wrote:
>>>> In particular, I'm confused what dialyzer doesn't like about line 60.
>>>>
>>>> 59 FirstOne = case is_binary(FirstTemp) of
>>>> 60 true -> binary_to_list(FirstTemp);
>>>> 61 false -> FirstOneRaw
>>>> 62 end,
>>>>
>>>> Not sure what's wrong. I tried using `_` instead of `false`, but got the
>>>> same warning. Should I use an if/else instead of case?
>>>
>>> Dialyzer is telling you that it thinks FirstTemp will never be a binary in your program, so the case statement you have there is unnecessary. So, effectively it tells you that you can rewrite the code above to:
>>>
>>> FirstOne = FirstOneRaw,
>>>
>>> The question is why do you expect that FirstTemp may be a binary at that point?
>>>
>>> Kostis
>>
>>
>>
>> --
>> Cheers,
>>
>> Andrew Pennebaker
>> www.yellosoft.us
>
>
>
> --
> Cheers,
>
> Andrew Pennebaker
> www.yellosoft.us
> _______________________________________________
> erlang-questions mailing list
> erlang-questions@REDACTED
> http://erlang.org/mailman/listinfo/erlang-questions
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://erlang.org/pipermail/erlang-questions/attachments/20131114/6b5abad5/attachment.htm>
More information about the erlang-questions
mailing list