X-Git-Url: http://git.roojs.org/?a=blobdiff_plain;f=JSDOC%2FTextStream.vala;h=f5bb7258fce7e3965ceb9fc1f595af5dd86f1873;hb=4874ad3e1d08502e88986231f3de271795ca2302;hp=153495f9142139f8a3649355508e41b6838d09a9;hpb=e9d0b3f2ae8eb12c36bdce57184bef25143ff1ff;p=gnome.introspection-doc-generator diff --git a/JSDOC/TextStream.vala b/JSDOC/TextStream.vala index 153495f..f5bb725 100644 --- a/JSDOC/TextStream.vala +++ b/JSDOC/TextStream.vala @@ -20,53 +20,58 @@ namespace JSDOC { string text; int cursor; + int length; public TextStream (string text = "") { this.text = text; + this.length = text.length; // text.char_count(); this.cursor = 0; } public char look(int n = 0) { - if (this.cursor+n < 0 || this.cursor+n >= this.text.length) { + if (this.cursor+n < 0 || this.cursor+n >= this.length) { return '\0'; } - return this.text[this.cursor+n]; - }, + return this.text[this.cursor+n]; // this.text.get_char(this.cursor+n); + } public bool lookEOF(int n = 0) { - if (this.cursor+n < 0 || this.cursor+n >= this.text.length) { + if (this.cursor+n < 0 || this.cursor+n >= this.length) { return true; } - return false - }, + return false; + } - - public char next(int n = 1, out bool eof) + /** + * @param n - number of characters to return.. + */ + public string next(int n = 1) { - eof = false; + if (n < 1) { //?? eof??? - return '\0'; + return "\0"; } - char pulled; - for (var i = 0; i < n; i++) { - if (this.cursor+i < this.text.length) { - pulled += this.text.get_char(this.cursor+i); + string pulled = ""; + var i = 0; + while (i < n) { + if (this.cursor+i < this.length) { + var add = this.text[this.cursor+i]; //this.text.get_char(this.cursor+i).to_string(); + pulled += add.to_string(); + i += 1;// add.length; } else { - eof =true; - return '\0'; - + return ""; } } - this.cursor += n; + this.cursor += pulled.length; return pulled; }