[rfc][icedtea-web] replacing of hardcoded jre path by function
Adam Domurad
adomurad at redhat.com
Wed Mar 20 06:21:58 PDT 2013
On 03/20/2013 07:02 AM, Jiri Vanek wrote:
> Looks like we have deal...
> ok?
>
>
> J.
> On 03/19/2013 04:28 PM, Adam Domurad wrote:
>> On 03/19/2013 11:08 AM, Jiri Vanek wrote:
>>> On 03/12/2013 04:42 PM, Adam Domurad wrote:
>>>> [ .. snip .. ]
>>>> The commands vector will not need the c_str(), because it is a vector
>>>> of std::string (things are much nicer when everything uses
>>>> std::string, we should move towards that!)
>>>
>>> Hmmm.. I can not see the difference...:(
>>
>> See notes in-line
>>
>>>
>>>
>>> Itteration 2 attached. Thanx for patience!
>>> J.
>>
>> Thanks for the new iteration!
>>
>>> diff -r 1024198de51f plugin/icedteanp/IcedTeaNPPlugin.cc
>>> --- a/plugin/icedteanp/IcedTeaNPPlugin.cc Tue Mar 19 15:44:43 2013
>>> +0100
>>> +++ b/plugin/icedteanp/IcedTeaNPPlugin.cc Tue Mar 19 16:02:11 2013
>>> +0100
>>> @@ -43,6 +43,7 @@
>>> #include <stdio.h>
>>> #include <stdlib.h>
>>> #include <string.h>
>>> +#include <string>
>>> #include <sys/stat.h>
>>> #include <sys/types.h>
>>> #include <unistd.h>
>>> @@ -156,8 +157,14 @@
>>> // Data directory for plugin.
>>> static std::string data_directory;
>>>
>>> -// Fully-qualified appletviewer executable.
>>> -static const char* appletviewer_executable = ICEDTEA_WEB_JRE
>>> "/bin/java";
>>> +// Fully-qualified appletviewer default executable and rt.jar
>>> +static const char* appletviewer_default_executable = ICEDTEA_WEB_JRE
>>> "/bin/java";
>>> +static const char* appletviewer_default_rtjar = ICEDTEA_WEB_JRE
>>> "/lib/rt.jar";
>>> +// Fully-qualified appletviewer default executable and rt.jar
>>> +// resolved by methods in runtime. It is expected they will be the
>>> same during
>>> +//whole runtime
>>> +static std::string appletviewer_executable;
>>> +static std::string appletviewer_rtjar;
>>
>> You can get rid of these if you just have get_plugin_executable &
>> get_plugin_rt_jar return values,
>> and use the return value whenever you need it.
>>
>>>
>>> // Applet viewer input channel (needs to be static because it is used
>>> in plugin_in_pipe_callback)
>>> static GIOChannel* in_from_appletviewer = NULL;
>>> @@ -284,6 +291,16 @@
>>>
>>> #endif
>>>
>>> +static std::string get_plugin_executable(std::string& dest){
>>> + dest = std::string (appletviewer_default_executable);
>>> + return dest;
>>> +}
>>
>> Why do you take an argument here ? You should just return the value?
>>
>>> +
>>> +static std::string get_plugin_rt_jar(std::string& dest){
>>> + dest = std::string (appletviewer_default_rtjar);
>>> + return dest;
>>> +}
>>> +
>>
>> Same
>>
>>>
>>> /*
>>> * Find first member in GHashTable* depending on version of glib
>>> @@ -1517,13 +1534,14 @@
>>> static NPError
>>> plugin_test_appletviewer ()
>>> {
>>> - PLUGIN_DEBUG ("plugin_test_appletviewer: %s\n",
>>> appletviewer_executable);
>>> +
>>> + PLUGIN_DEBUG ("plugin_test_appletviewer: %s\n",
>>> get_plugin_executable(appletviewer_executable).c_str());
>>> NPError error = NPERR_NO_ERROR;
>>>
>>> gchar* command_line[3] = { NULL, NULL, NULL };
>>> gchar** environment;
>>>
>>> - command_line[0] = g_strdup (appletviewer_executable);
>>> + command_line[0] = g_strdup
>>> (get_plugin_executable(appletviewer_executable).c_str());
>>> command_line[1] = g_strdup("-version");
>>> command_line[2] = NULL;
>>>
>>> @@ -1570,7 +1588,7 @@
>>>
>>> // Construct command line parameters
>>>
>>> - command_line.push_back(appletviewer_executable);
>>> +
>>> command_line.push_back(get_plugin_executable(appletviewer_executable).c_str());
>>>
>>
>> As I mentioned earlier, the .c_str() is redundant here and causes an
>> unnecessary string copy (if
>> you're curious why, normally std::string can be passed around and
>> share string data, but it is not
>> able to do this simply given a char*).
>>
>>>
>>> //Add JVM args to command_line
>>> for (int i = 0; i < jvm_args->size(); i++)
>>> @@ -1581,7 +1599,7 @@
>>> command_line.push_back(PLUGIN_BOOTCLASSPATH);
>>> // set the classpath to avoid using the default (cwd).
>>> command_line.push_back("-classpath");
>>> - command_line.push_back(ICEDTEA_WEB_JRE "/lib/rt.jar");
>>> +
>>> command_line.push_back(get_plugin_rt_jar(appletviewer_rtjar).c_str());
>>
>> Same (drop c_str())
>>
>>>
>>> // Enable coverage agent if we are running instrumented plugin
>>> #ifdef COVERAGE_AGENT
>>> @@ -1652,10 +1670,10 @@
>>> gchar *output = NULL;
>>> std::vector<std::string*>* tokenOutput = NULL;
>>>
>>> - commands.push_back(appletviewer_executable);
>>> +
>>> commands.push_back(get_plugin_executable(appletviewer_executable).c_str());
>>>
>>
>> Same (drop c_str())
>>
>>
>>> commands.push_back(PLUGIN_BOOTCLASSPATH);
>>> commands.push_back("-classpath");
>>> - commands.push_back(ICEDTEA_WEB_JRE "/lib/rt.jar");
>>> + commands.push_back(get_plugin_rt_jar(appletviewer_rtjar).c_str());
>>
>> Same (drop c_str())
>>
>>> commands.push_back("net.sourceforge.jnlp.controlpanel.CommandLine");
>>> commands.push_back("get");
>>> commands.push_back("deployment.plugin.jvm.arguments");
>>> @@ -2175,11 +2193,11 @@
>>> }
>>>
>>> // Set appletviewer_executable.
>>> - PLUGIN_DEBUG("Executing java at %s\n", appletviewer_executable);
>>> + PLUGIN_DEBUG("Executing java at %s\n",
>>> get_plugin_executable(appletviewer_executable).c_str());
>>> np_error = plugin_test_appletviewer ();
>>> if (np_error != NPERR_NO_ERROR)
>>> {
>>> - fprintf(stderr, "Unable to find java executable %s\n",
>>> appletviewer_executable);
>>> + fprintf(stderr, "Unable to find java executable %s\n",
>>> get_plugin_executable(appletviewer_executable).c_str());
>>> return np_error;
>>> }
>>>
>>> @@ -2191,7 +2209,7 @@
>>>
>>> plugin_instance_mutex = g_mutex_new ();
>>>
>>> - PLUGIN_DEBUG ("NP_Initialize: using %s\n", appletviewer_executable);
>>> + PLUGIN_DEBUG ("NP_Initialize: using %s\n",
>>> get_plugin_executable(appletviewer_executable).c_str());
>>>
>>> plugin_req_proc = new PluginRequestProcessor();
>>> java_req_proc = new JavaMessageSender();
>>
>>
>> Looks ok otherwise.
>> Thanks,
>> -Adam
>
OK to push to HEAD.
-Adam
More information about the distro-pkg-dev
mailing list