diff options
| -rw-r--r-- | include/PropSet.h | 6 | ||||
| -rw-r--r-- | src/PropSet.cxx | 39 | 
2 files changed, 28 insertions, 17 deletions
| diff --git a/include/PropSet.h b/include/PropSet.h index 2326ba5c4..4e30c37c5 100644 --- a/include/PropSet.h +++ b/include/PropSet.h @@ -108,11 +108,11 @@ private:  	char **vals;  	int size;  	int used; +	void EnsureCanAddEntry();  public:  	PropSet *superPS;  	PropSet();  	~PropSet(); -	void EnsureCanAddEntry();  	void Set(const char *key, const char *val);  	void Set(char *keyval);  	SString Get(const char *key); @@ -120,8 +120,8 @@ public:  	SString GetWild(const char *keybase, const char *filename);  	SString GetNewExpand(const char *keybase, const char *filename);  	void Clear(); -	void ReadFromMemory(const char *data, int len); -	void Read(const char *filename); +	void ReadFromMemory(const char *data, int len, const char *directoryForImports=0); +	void Read(const char *filename, const char *directoryForImports);  };  // This is a fixed length list of strings suitable for display  in combo boxes diff --git a/src/PropSet.cxx b/src/PropSet.cxx index b582327b7..2558201a6 100644 --- a/src/PropSet.cxx +++ b/src/PropSet.cxx @@ -97,6 +97,8 @@ void PropSet::Set(const char *key, const char *val) {  }  void PropSet::Set(char *keyval) { +    while (isspace(*keyval)) +        keyval++;  	char *eqat = strchr(keyval, '=');  	if (eqat) {  		*eqat = '\0'; @@ -244,29 +246,38 @@ void PropSet::Clear() {  	used = 0;  } -void PropSet::ReadFromMemory(const char *data, int len) { -	if (len > 0) { -		const char *pd = data; -		char linebuf[60000]; -		while (GetFullLine(pd, len, linebuf, sizeof(linebuf))) { -			if (isalpha(linebuf[0])) -				Set(linebuf); -		} -		// If there is a final line: -		if (isalpha(linebuf[0])) +void PropSet::ReadFromMemory(const char *data, int len, const char *directoryForImports) { +	const char *pd = data; +	char linebuf[60000]; +	bool ifIsTrue = true; +	while (len > 0) { +		GetFullLine(pd, len, linebuf, sizeof(linebuf)); +		if (isalpha(linebuf[0]))    // If clause ends with first non-indented line +			ifIsTrue = true; +		if (isprefix(linebuf, "if ")) { +			const char *expr = linebuf + strlen("if") + 1; +			ifIsTrue = GetInt(expr); +		} else if (isprefix(linebuf, "import ") && directoryForImports) { +			char importPath[MAX_PATH]; +			strcpy(importPath, directoryForImports); +			strcat(importPath, linebuf + strlen("import") + 1); +			strcat(importPath, ".properties"); +            Read(importPath,directoryForImports); +		} else if (isalpha(linebuf[0])) { +			Set(linebuf); +		} else if (isspace(linebuf[0]) && ifIsTrue) {  			Set(linebuf); +		}  	}  } -void PropSet::Read(const char *filename) { -	//printf("Opening properties <%s>\n", filename); -	Clear(); +void PropSet::Read(const char *filename, const char *directoryForImports) {  	char propsData[60000];  	FILE *rcfile = fopen(filename, "rb");  	if (rcfile) {  		int lenFile = fread(propsData, 1, sizeof(propsData), rcfile);  		fclose(rcfile); -		ReadFromMemory(propsData, lenFile); +		ReadFromMemory(propsData, lenFile, directoryForImports);  	} else {  		//printf("Could not open <%s>\n", filename);  	} | 
