[rfc][icedtea-web] C++-side small fixes (RH 1121549)
Andrew Azores
aazores at redhat.com
Wed Jul 30 15:58:20 UTC 2014
On 07/30/2014 09:47 AM, Jiri Vanek wrote:
> On 07/28/2014 11:53 PM, Andrew Azores wrote:
>> On 07/28/2014 11:14 AM, Jiri Vanek wrote:
>>>
>>>> diff --git a/plugin/icedteanp/IcedTeaPluginUtils.cc
>>>> b/plugin/icedteanp/IcedTeaPluginUtils.cc
>>>> --- a/plugin/icedteanp/IcedTeaPluginUtils.cc
>>>> +++ b/plugin/icedteanp/IcedTeaPluginUtils.cc
>>>> @@ -59,6 +59,19 @@
>>>> /* Plugin async call queue */
>>>> static std::vector< PluginThreadCall* >*
>>>> pendingPluginThreadRequests = new std::vector<
>>>> PluginThreadCall* >();
>>>>
>>>> +int
>>>> +IcedTeaPluginUtilities::createLogDirectory(std::string dir)
>>>> +{
>>>> + if (!IcedTeaPluginUtilities::file_exists(dir))
>>>> + {
>>>> + if (!g_mkdir(dir.c_str(), 755))
>>>> + {
>>>> + return errno;
>>>> + }
>>>> + }
>>>> + return 0;
>>>> +}
>>>> +
>>> ...
>>> > + int parentErr =
>>> IcedTeaPluginUtilities::createLogDirectory(r1);
>>> > + if (!parentErr){
>>> > + PLUGIN_ERROR("FATAL: Failed to create IcedTea-Web
>>> config directory %s: %s\n",
>>> r1.c_str(), strerror(parentErr));
>>> > + return NULL;
>>> }
>>>
>>> When you are her, you should also verify (if it exists then) whether
>>> it is directory or file. If
>>> File, return failure.
>>>
>>> I would discourage you from returning errno. I would say Print
>>> error messages here, and return
>>> true/false.
>>>
>>> true/false is the only indicator you need if you need to decide
>>> wheter continue or not.
>>>
>>> And I would suggest continue at all cost, but print out a warning
>>> that it probably will nto work.
>>>
>>> So I would go with:
>>>
>>> bool IcedTeaPluginUtilities::createLogDirectory(std::string dir)
>>> {
>>> if (!file_exists(dir) )
>>> {
>>> if (!g_mkdir(dir.c_str(), 755))
>>> int x=errno
>>> echo "warning, creation of $dir failed. Itw need this
>>> direcotry to work. You can
>>> expect failre later. reason: "error_toString(x)
>>> //always save errorn
>>> return false;
>>> }
>>> } else {
>>> if (!is_dir(dir)){
>>> echo "warning, cannot create $dir becasue there is
>>> already an file"
>>> return false
>>> }
>>> }
>>> return true;
>>> //feel free to add some debug only outputs here like exists,
>>> continuing, is dir, continuing...
>>> }
>>> int parentErr = IcedTeaPluginUtilities::createLogDirectory(r1);
>>> // warnings have been printed
>>> // no need to die, trying to continue
>>>
>>>
>>>
>>>
>>> Also.. :-/ .. your patch kills ITW at my machine
>>>
>>> [unknown user][ITW-C-PLUGIN][MESSAGE_DEBUG][Mon Jul 28 16:11:03 CEST
>>> 2014][/home/jvanek/hg/icedtea-web/plugin/icedteanp/IcedTeaParseProperties.cc:141]
>>> ITNPP Thread#
>>> 139757752895360, gthread 0x7f1bd2614120: FATAL: Failed to create
>>> IcedTea-Web config directory
>>> /home/jvanek/.config/icedtea-web: Success
>>>
>>> and firefox dies. Please run your code on soem usecases before
>>> posting.
>>>
>>> Well the /home/jvanek/.config/icedtea-web do exist at my pc - so
>>> somethig is wrong :)
>>
>> :S I could swear it worked for me, not sure what happened there.
>> Maybe I made a change and failed to
>> test that one before sending :/
>>
>>>
>>>
>>> My reason to try continuing is simple - There may be cases, when
>>> .confing/itw may be some special
>>> device - well nearly impossible, but still possible.
>>>
>>>
>>> Another note - sinc you created new method - please unittest it in
>>> cpp-unit-tests.
>>>
>>>
>>> And positive note at the end. I run covescan on your patch and not
>>> sure what to read -
>>> http://cov01.lab.eng.brq.redhat.com/covscanhub/task/13258/ :))
>>> J.
>>>
>>>
>>>
>>
>> New patch has tests added and some style cleanup done, and works
>> again (hopefully - seems to work
>> fine for me and unit tests are a little reassuring).
>>
>> Thanks,
>>
>
> Is this output of test expected? (yes, the code is doing it :) , but
> should not be :) )
> Passed: is_directory
> WARNING: Needed to create directory /tmp/fileSGg0Vp but there is
> already a file of the same name at this location.
> WARNING: Failed to create new directory /tmp/filecvV1sH/test. Reason:
> Permission denied
> Passed: create_log_dir
>
>
> I mean the warnings. I thing they are disturbing the output and should
> not be here.
>
> I think there are exampels in ccp tests, how to redirect the output.
> May you try them?
>
> Except this I'm moreover happy with patch.
>
> One nit
>
> you called it "create_log_dir" I would go with generic "create_dir"
> If the redirect of output and renaming will be smooth, ok for head.
>
>
> For 1.5 - I'm for a bit less invasive patch. One of the earlier
> versions was more suitable. I would Discourage you from any behaviour
> changes (like new error/warning messages). Please reconsider benefits
> and post 1.5 patch separately. (unless it is completely same as this
> one)
>
> tyvm!
>
> J.
>
Okay, I'll post again for the 1.5 patch. In the meantime here's the
hopefully final patch for HEAD for approval. It's the same as last time
but basically with s/create_log_dir/create_dir/g and the warning output
squelched during the tests.
Thanks,
--
Andrew A
-------------- next part --------------
A non-text attachment was scrubbed...
Name: rh1121549-fixes-8.patch
Type: text/x-patch
Size: 9004 bytes
Desc: not available
URL: <http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20140730/e7287896/rh1121549-fixes-8-0001.patch>
More information about the distro-pkg-dev
mailing list