aboutsummaryrefslogtreecommitdiff
path: root/advtrains/api_doc.txt
Commit message (Collapse)AuthorAge
* Use a standard wagon inventory formspecBlockhead2020-03-18
| | | | | | | | | | | | | | This new formspec also allows access to the wagon properties. Once whitelisted in the wagon properties, other players can access its inventory. Note on 'useless use' of OO: I tried passing just the wagon ID and avoiding using the `self` object in order to bypass the need to look up the lua entitie out of the list, but it ended up retrieving nil data. The best way to solve this overhead might be to wait for some kind of better way upstream in minetest's lua API to get entities, or to keep a central record of entities. Either way, the solution is outside the scope of this commit.
* Move LZB system to core and unify approach callback mechanismorwell962019-04-16
|
* Fix stop rails sometimes not sending stop commandorwell962019-02-16
|
* Change get_inventory_formspec API - add invname parameterorwell962018-12-10
|
* Added on_train_approach callback, non-permanent external LZB brakepoints and ↵orwell962018-11-29
| | | | | | basis for "stop rails" Stop rails ATM use the aforementioned things to add a pointwise "2" speed restriction. Seems to work.
* Correct some documentationorwell962018-06-14
|
* Implement a reverse path lookup for trains instead of an occupations window ↵orwell962018-06-14
| | | | system
* Move driving_ctrl_access property to seat grouporwell962018-01-09
| | | | | there's now a more strict check for the train_operator privilege Also added custom reasons on getting on a train.
* Implement sound api and some soundsorwell962017-12-06
| | | | | | | - Level crossing bell - Horns - Subway train driving and door sounds ...to be continued...
* Change name of update_animation functionorwell962017-11-29
| | | | I will use this for sounds, and so it needs to be changed to a more general name
* Add modifiable wagon extentsorwell962017-11-23
| | | | This will be required for advcarts
* do not register wagons in the advtrains namespace automaticallyorwell962017-11-22
| | | | One step towards advcarts compatibility
* Remove zip release files, move mod to root, exclude assets from Makefile (#92)rubenwardy2017-09-20
|
* Restructure mod directoryorwell962017-01-04
|
* Add Automatic Train Control systemorwell962017-01-04
|
* add API documentationorwell962017-01-03
); } void EnrichedString::addAtEnd(const std::wstring &s, const SColor &initial_color) { SColor color(initial_color); size_t i = 0; while (i < s.length()) { if (s[i] != L'\x1b') { m_string += s[i]; m_colors.push_back(color); ++i; continue; } ++i; size_t start_index = i; size_t length; if (i == s.length()) { break; } if (s[i] == L'(') { ++i; ++start_index; while (i < s.length() && s[i] != L')') { if (s[i] == L'\\') { ++i; } ++i; } length = i - start_index; ++i; } else { ++i; length = 1; } std::wstring escape_sequence(s, start_index, length); std::vector<std::wstring> parts = split(escape_sequence, L'@'); if (parts[0] == L"c") { if (parts.size() < 2) { continue; } parseColorString(wide_to_utf8(parts[1]), color, true); } else if (parts[0] == L"b") { if (parts.size() < 2) { continue; } parseColorString(wide_to_utf8(parts[1]), m_background, true); m_has_background = true; } continue; } } void EnrichedString::addChar(const EnrichedString &source, size_t i) { m_string += source.m_string[i]; m_colors.push_back(source.m_colors[i]); } void EnrichedString::addCharNoColor(wchar_t c) { m_string += c; if (m_colors.empty()) { m_colors.push_back(SColor(255, 255, 255, 255)); } else { m_colors.push_back(m_colors[m_colors.size() - 1]); } } EnrichedString EnrichedString::operator+(const EnrichedString &other) const { std::vector<SColor> result; result.insert(result.end(), m_colors.begin(), m_colors.end()); result.insert(result.end(), other.m_colors.begin(), other.m_colors.end()); return EnrichedString(m_string + other.m_string, result); } void EnrichedString::operator+=(const EnrichedString &other) { m_string += other.m_string; m_colors.insert(m_colors.end(), other.m_colors.begin(), other.m_colors.end()); } EnrichedString EnrichedString::substr(size_t pos, size_t len) const { if (pos == m_string.length()) { return EnrichedString(); } if (len == std::string::npos || pos + len > m_string.length()) { return EnrichedString( m_string.substr(pos, std::string::npos), std::vector<SColor>(m_colors.begin() + pos, m_colors.end()) ); } else { return EnrichedString( m_string.substr(pos, len), std::vector<SColor>(m_colors.begin() + pos, m_colors.begin() + pos + len) ); } } const wchar_t *EnrichedString::c_str() const { return m_string.c_str(); } const std::vector<SColor> &EnrichedString::getColors() const { return m_colors; } const std::wstring &EnrichedString::getString() const { return m_string; }