1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
|
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
/*
* Based on ScottFree interpreter version 1.14 developed by Swansea
* University Computer Society without disassembly of any other game
* drivers, only of game databases as permitted by EEC law (for purposes
* of compatibility).
*
* Licensed under GPLv2
*
* https://github.com/angstsmurf/spatterlight/tree/master/terps/scott
*/
#include "common/util.h"
#include "glk/scott/layout_text.h"
namespace Glk {
namespace Scott {
int findBreak(const char *buf, int pos, int columns) {
int diff = 0;
while (diff < columns && !Common::isSpace((unsigned char)buf[pos])) {
pos--;
diff++;
}
if (diff >= columns || diff < 1) /* Found no space */ {
return -1;
}
return diff;
}
/* Breaks a null-terminated string up by inserting newlines, moving words
down to the next line when reaching the end of the line */
char *lineBreakText(char *source, int columns, int *rows, int *length) {
columns -= 1;
char *result = nullptr;
char buf[768];
int col = 0;
int row = 0;
int sourcepos = 0;
int destpos = 0;
int diff = 0;
*rows = 0;
while (source[sourcepos] != '\0') {
while (col < columns && source[sourcepos] != '\0') {
if (source[sourcepos] == 10 || source[sourcepos] == 13) {
/* Found a line break. */
/* Any spaces before a line break may cause trouble, */
/* so we delete them */
while (destpos && buf[destpos - 1] == ' ') {
destpos--;
}
col = 0;
row++;
} else {
col++;
}
buf[destpos++] = source[sourcepos++];
if (source[sourcepos] == 10 || source[sourcepos] == 13)
col--;
}
/* We have reached the end of a line */
row++;
col = 0;
if (source[sourcepos] == '\0') {
break;
}
diff = findBreak(source, sourcepos, columns);
if (diff > -1) { /* We found a suitable break */
sourcepos = sourcepos - diff;
destpos = destpos - diff;
buf[destpos++] = '\n';
if (Common::isSpace((unsigned char)source[sourcepos])) {
sourcepos++;
}
}
}
*rows = row;
*length = 0;
result = new char[destpos + 1];
if (result == nullptr)
return nullptr;
memcpy(result, buf, destpos);
result[destpos] = '\0';
*length = destpos;
return result;
}
} // End of namespace Scott
} // End of namespace Glk
|