importing variables in compiled package

3 vues (au cours des 30 derniers jours)
Richard
Richard le 13 Juin 2011
Hi all,
I have some matlab code from which I've extracted the important variables to a separate file that I called config.m...
%comment comment comment a = 1; %comment comment comment b = 2; ...
When I start up my code, this file is "sourced" by running config.m to load the parameters.
This has worked well for me while test/debugging. Now I want to compile the code, but keep the same configuration so I can tweak all the parameters for each run. One way around this I have found is to load my config file line by line, and use the eval function to get the variables into scope. Is this breaking any sort of license agreement if I distribute it? If so, are there any more valid ways to accomplish the same thing?

Réponses (3)

Walter Roberson
Walter Roberson le 14 Juin 2011
You are correct that it would be a license violation, as your executable would be providing the same functionality as the MATLAB command line by way of the user providing a config.m file that happened to include an input / eval loop.
You are responsible for ensuring that your program is secure against these kinds of hacks.
This does not rule out the use of eval (though it would not be recommended as there are clear alternatives such as dynamic structure fields), but it does mean that you have to scan the input for validity instead of blindly eval()'ing it. And if you are going to scan it for validity, you might as well use a data file.
  5 commentaires
Richard
Richard le 14 Juin 2011
After some minimal thinking, I realize I could do the same as I was doing but filter out any lines that call functions. So I could throw out any lines that contain [, ], (, or ) and then there is no exposure to internal functions.
Walter Roberson
Walter Roberson le 14 Juin 2011
Note that some functions do not require arguments -- for example, "now" and "eps" .
I suspect you could reduce it down to checking whether the lines are of the form
name = numericvalue
and validate the name via ismember() against the set of names you specifically want to allow to be set.

Connectez-vous pour commenter.


Fangjun Jiang
Fangjun Jiang le 13 Juin 2011
I think you are doing perfectly fine regarding license or good practice. You can put your parameters in a M-script or a M-function. Just make sure you deal with the base workspace or function workspace properly.

Chirag Gupta
Chirag Gupta le 13 Juin 2011
Why don't you save the variables in a MAT file and just include the file when compiling it! Better way would be for your compiled application to have an interface that allows you to specify a MAT file( using uigetfile ). Then you could save multiple config params in separate MAT files and just choose the desired one at runtime
  3 commentaires
Chirag Gupta
Chirag Gupta le 14 Juin 2011
Agreed, but then the correct way (in my opinion) should be to save it as a text file and use MATLAB file i/o to read the values. Saving it as a MATLAB file (M) doesn't seem like the right approach!
Richard
Richard le 14 Juin 2011
What sort of matlab i/o do you recommend? I'd like to keep the format of config.m similar to what I have above.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Debugging and Analysis dans Help Center et File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by