[rfc][icedtea-web] C++-side small fixes (RH 1121549)
Andrew Azores
aazores at redhat.com
Mon Jul 28 21:53:30 UTC 2014
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,
--
Andrew A
-------------- next part --------------
A non-text attachment was scrubbed...
Name: rh1121549-fixes-7.patch
Type: text/x-patch
Size: 8730 bytes
Desc: not available
URL: <http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20140728/cc43762a/rh1121549-fixes-7.patch>
More information about the distro-pkg-dev
mailing list