OpenTTD AI API 20250108-master-g4db0af99a7
Lists all changes / additions to the API.

Only new / renamed / deleted api functions will be listed here.

A list of bug fixes can be found in the normal changelog. Note that removed API functions may still be available if you return an older API version in GetAPIVersion() in info.nut.

15.0

This version is not yet released. The following changes are not set in stone yet.

API additions:

14.0

API additions:

API removals:

  • AIError::ERR_PRECONDITION_TOO_MANY_PARAMETERS, that error is never returned anymore.
  • AIInfo::CONFIG_RANDOM, no longer used.
  • AIInfo::AddSettings random_deviation is no longer used.

Other changes:

  • AIGroupList accepts an optional filter function
  • AIIndustryList accepts an optional filter function
  • AISignList accepts an optional filter function
  • AISubsidyList accepts an optional filter function
  • AITownList accepts an optional filter function
  • AIVehicleList accepts an optional filter function
  • AIInfo::AddSettings easy_value / medium_value / hard_value are replaced with default_value

13.0

API additions:

Other changes:

12.0

API additions:

1.11.0

API additions:

Other changes:

1.10.0

API additions:

Other changes:

1.9.0

API additions:

Other changes:

1.8.0

No changes

API additions:

1.7.0 - 1.7.2

No changes

1.6.1 - 1.6.0

No changes

1.5.3 - 1.5.1

No changes

1.5.0

API additions:

1.4.4 - 1.4.1 No changes

1.4.0

API additions:

Other changes:

  • AIStation::GetCargoRating does return -1 for cargo-station combinations that do not have a rating yet instead of returning 69.

1.3.3 - 1.3.2

No changes

1.3.1

API additions:

1.3.0

API additions:

1.2.3 - 1.2.1

No changes

1.2.0

API additions:

API renames:

  • AITown::GetLastMonthTransported to AITown::GetLastMonthSupplied to better reflect what it does.
  • AIInfo has all its configure settings renamed from AICONFIG to just CONFIG like CONFIG_RANDOM.
  • AIEvent has all its types renamed from AI_ET_ prefix to just ET_ prefix, like ET_SUBSIDY_OFFER.
  • AIOrder has all its types renamed from AIOF_ prefix to just OF_ prefix.

API removals:

Other changes:

1.1.5

No changes

1.1.4

API additions:

1.1.3 - 1.1.1

No changes

1.1.0

API additions:

API removals:

  • HasNext for all lists.
  • AIAbstractList, use AIList instead.
  • AIList::ChangeItem, use AIList::SetValue instead.
  • AIRail::ERR_NONUNIFORM_STATIONS_DISABLED, that error is never returned anymore.

Other changes:

1.0.5 - 1.0.4

No changes

1.0.3

API additions:

1.0.2

Other changes:

  • AIBridge::GetPrice now returns the price of the bridge without the cost for the rail or road.

1.0.1

API additions:

1.0.0

API additions:

API removals:

Other changes:

  • The GetName / SetName / GetLocation functions were moved from AIStation and AIWaypoint to AIBaseStation, but you can still use AIStation.GetName as before
  • The GetConstructionDate function was moved from AIStation to AIBaseStation, but can still be used as AIStation.GetConstructionDate
  • WaypointID was replaced by StationID. All WaypointIDs from previous savegames are invalid. Use STATION_INVALID instead of WAYPOINT_INVALID
  • AIWaypointList constructor now needs a WaypointType similar to AIStationList, it can also handle buoys.
  • AIVehicleList_Station now also works for waypoints
  • Stations can be build over rail without signals that is in the right direction for the to-be built station. It will also convert the rail if the station's rail type supports the old type.
  • GetAPIVersion() was added as function to info.nut. If it does not exist API version 0.7 is assumed. This function should return the major and minor number of the stable version of the API the AI is written against. For 0.7.2 that would be 0.7, for 1.1.3 it would be 1.1, etc.
  • The subsidy logic has changed. Subsidy is now awarded when cargo originating from subsidy source is delivered to station that has subsidy destination it its catchment area. One industry tile or one town house is enough as long as station accepts the cargo. Awarded subsidies are no longer bound to stations used for first delivery, any station can be used for loading and unloading as long as cargo is transferred from source to destination.
  • Make AIEngine:CanRefitCargo() not report refittability to mail by default for aircraft. It is not necessarily true. This means that even if the aircraft can carry mail (as secondary cargo) it does not return true if the aircraft cannot carry it as its only cargo.
  • Improve behaviour of AIEngine::GetCargoType(), AIEventEnginePreview::GetCargoType() and AIEngine::CanRefitCargo() for articulated vehicles. For CanRefitCargo true is returned if at least one part can be refitted. For GetCargoType the first most used cargo type is returned.
  • AIIndustryType::GetConstructionCost() now returns -1 if the industry is neither buildable nor prospectable.
  • AIEngine::IsValidEngine will now return true if you have at least one vehicle of that type in your company, regardless if it's still buildable or not. AIEngine::IsBuildable returns only true when you can actually build an engine.
  • AITile::GetCargoProduction will now return the number of producers, including houses instead the number of producing tiles. This means that also industries that do not have a tile within the radius, but where the search bounding box and the industry's bounding box intersect, are counted. Previously these industries (and their cargoes), although they produced cargo for a station at the given location, were not returned.
  • AIRail::BuildRail will now fail completely if there is an obstacle between the begin and end, instead of building up to the obstacle and returning that everything went okay.
  • Orders for buoys are now waypoint orders, i.e. instead of using the station orders for buoys one has to use waypoint orders.
  • Autoreplaces can now also be set for the default group via AIGroup.

0.7.5 - 0.7.4

No changes

0.7.3

API additions:

Other changes:

  • AIs are now killed when they execute a DoCommand or Sleep at a time they are not allowed to do so.
  • When the API requests a string as parameter you can give every squirrel type and it will be converted to a string
  • AIs can create subclasses of API classes and use API constants as part of their own constants

0.7.2

API additions:

Other changes:

  • DoCommands and sleeps in call, acall, pcall and valuators are disallowed

0.7.1

API additions:

Other changes:

  • GetURL() was added as optional function to info.nut
  • UseAsRandomAI() was added as optional function to info.nut
  • A limit was introduced on the time the AI spends in the constructor and Load function

0.7.0

  • First stable release with the NoAI framework.