Sha256: 57224f785f59826fc46c76ff1d96a3e88233ebb3ae9474e42c804ba7ce16def1

Contents?: true

Size: 1.5 KB

Versions: 6

Compression:

Stored size: 1.5 KB

Contents

#include "Parser.h"
#include <cstring>

namespace SWF {

Parser::Parser(const char begin, const char end, const char parameter) {
	expectedDelimiter = begin;
	otherDelimiter = end;
	parameterDelimiter = parameter;
}

Parser::~Parser() {
}

void Parser::swapDelimiters() {
	char tmp = otherDelimiter;
	otherDelimiter = expectedDelimiter;
	expectedDelimiter = tmp;
}

bool Parser::isWhitespace(const char c) {
	return (c == 0 || c == '\n' || c == '\r' || c == '\t' || c == ' '); 	
}

void Parser::doParse(const char* str) {
	string tmp;
		
	insideParams = false;
	params.clear();

	for (size_t i = 0; i < strlen(str); i++) {
		if(str[i] == expectedDelimiter) {
			handleDelimiter(tmp);	
		} else if(str[i] == otherDelimiter) {
			cerr << "WARNING: Unexpected delimiter while parsing" << endl;
		} else {
			if(tmp.length() > 0 && (str[i] == parameterDelimiter || isWhitespace(str[i]))) {
				trimString(tmp);
				params.push_back(tmp);
				tmp.clear();
			} else {
				tmp += str[i];
			}
		}
	}
		
	if (tmp.length() > 0) {
		//cerr << "WARNING: Reached end of line while parsing" << endl;
		handleDelimiter(tmp);
	}
}

void Parser::handleDelimiter(string& tmp) {
	trimString(tmp);
		
	if(insideParams) {
		if(tmp.length() > 0) {
			params.push_back(tmp);
		}
		handleData(outside, params);
		params.clear();
	} else {
		outside = tmp;
	}
	
	insideParams = !insideParams;
	tmp.clear();
	swapDelimiters();
}

void Parser::trimString(string& s) {
	s.erase(0, s.find_first_not_of(" \t\r\n"));
	s.erase(s.find_last_not_of(" \t\r\n") + 1);
}

}

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
swfmill-0.0.6 ext/swfmill/src/swft/Parser.cpp
swfmill-0.0.5 ext/swfmill/src/swft/Parser.cpp
swfmill-0.0.4 ext/swfmill/src/swft/Parser.cpp
swfmill-0.0.3 ext/swfmill/src/swft/Parser.cpp
swfmill-0.0.2 ext/swfmill/src/swft/Parser.cpp
swfmill-0.0.1 ext/swfmill/src/swft/Parser.cpp