The GTFS Specification is not set in stone. Instead, it is an open specification developed and maintained by the community of transit agencies, developers, and other stakeholders who use GTFS. It is expected that this community of producers and consumers of GTFS data will have proposals for extending the spec to enable new capabilities. To help manage that process, the following procedures and guidelines have been established.
The official specification, reference and documentation are written in English. If a translation to a different language differs from the English original, the latter takes precedence. All communication is performed in English.
- Create a git branch with update of all relevant parts of protocol definition, specification and documentation files (except for translations).
- Create pull request on https://github.com/google/transit. Pull request must contain an extended description of the patch. The creator of the pull request becomes the advocate.
- Once pull request is registered, it must be announced by its advocate in the GTFS Changes mailing list, including a link to the pull request. Once announced, the pull request is considered a proposal. The pull request should also be edited to contain a link to the Google Groups announcement so they can easily be cross-referenced.
- Since the advocate is a contributor, they must sign the Contributor License Agreement before pull request can be accepted.
- The discussion of the proposal follows. Pull request comments should be used as the sole discussion forum.
- The discussion lasts for as long as the advocate feels necessary, but must be at least 7 calendar days.
- The advocate is responsible for timely update of the proposal (i.e. pull request) based on the comments for which they agree to.
- At any point in time the advocate can claim proposal abandoned.
- The advocate can call for a vote on a version of the proposal at any point in time following the initial 7-day interval required for discussion.
- Before calling for a vote, at least one GTFS producer and one GTFS consumer should implement the proposed change. It is expected that the GTFS producer(s) include the change in a public-facing GTFS feed and provide a link to that data within the pull request comments, and that the GTFS consumer(s) provides a link in the pull request comments to an application that is utilizing the change in a non-trivial manner (i.e, it is supporting new or improved functionality).
- Vote lasts the minimum period sufficient to cover 14 full calendar days. Vote ends at 23:59:59 UTC.
- The advocate should announce the specific end time at the start of the vote.
- During voting period only editorial changes to the proposal are allowed (typos, wording may change as long as it does not change the meaning).
- Anyone is allowed to vote yes/no in a form of comment to the pull request, and votes can be changed until the end of the voting period. If a voter changes her vote, it is recommended to do it by updating the original vote comment by striking through the vote and writing the new vote.
- Votes before the start of the voting period are not considered.
- Opening and closing of votes must be announced on the GTFS Changes mailing list.
- The proposal is accepted if there is a unanimous consensus yes with at least 3 votes.
- The proposer's vote does not count towards the 3 vote total. For example, if Proposer X creates a pull request and votes yes, and User Y and Z vote yes, this is counted as 2 total yes votes.
- Votes against shall be motivated, and ideally provide actionable feedback.
- If the vote has failed, then the advocate may choose to continue work on the proposal, or to abandon the proposal. Either decision of the advocate must be announced in the GTFS Changes mailing list.
- If the advocate continues the work on proposal then a new vote can be called for at any point in time.
- Any pull request remaining inactive for 30 calendar days will be closed. When a pull request is closed, the corresponding proposal is considered abandoned. The advocate may reopen the pull request at any time if they wish to continue or maintain the conversation.
- If the proposal is accepted:
- Google is committed to merging the voted upon version of the pull request (provided that the contributors have signed the CLA), and performing the pull request within 5 business days.
- Translations must not be included into the original pull request. Google is responsible for eventually updating relevant translations into supported languages, but pure translation pull requests from the community are welcome and will be accepted as soon as all editorial comments are addressed.
- The final result of the pull request (accepted or abandoned) should be announced on the same Google Groups thread where the pull request was originally announced.
In order to preserve the original vision of GTFS, a number of guiding principles have been established to take into consideration when extending the spec:
We chose CSV as the basis for the specification because it's easy to view and edit using spreadsheet programs and text editors, which is helpful for smaller agencies. It's also straightforward to generate from most programming languages and databases, which is good for publishers of larger feeds.
Feed readers should be able to extract the information they're looking for with as little work as possible. Changes and additions to the feed should be as broadly useful as possible, to minimize the number of code paths that readers of the feed need to implement. (However, making creation easier should be given precedence, since there will ultimately be more feed publishers than feed readers.)
GTFS is primarily concerned with passenger information. That is, the spec should include information that can help power tools for riders, first and foremost. There is potentially a large amount of operations-oriented information that transit agencies might want to transmit internally between systems. GTFS is not intended for that purpose and there are potentially other operations-oriented data-standards that may be more appropriate.
When adding features to the specification, we want to avoid making changes that will make existing feeds invalid. We don't want to create more work for existing feed publishers until they want to add capabilities to their feeds. Also, whenever possible, we want existing parsers to be able to continue to read the older parts of newer feeds.
Every new feature adds complexity to the creation and reading of feeds. Therefore, we want to take care to only add features that we know to be useful. Ideally, any proposal will have been tested by generating data for a real transit system that uses the new feature and writing software to read and display it. Note that the GTFS readily allows for extensions to the format through the addition of extra columns and files that are ignored by the official parsers & validators, so proposals can be easily prototyped and tested on existing feeds.
- Best practices: add Dataset Publishing guidelines and Practice Recommendations for all files. See discussion.
- Add networks.txt & route_networks.txt. See discussion
- Add fare_media_type=1. See discussion.
- Forbid subfolders in GTFS files. See discussion.
- Added variable fares by time or day. See discussion.
- Clarify implied timezone in stop_times.txt. See discussion.
- Specify stop times shape_dist_traveled must not exceed the trip shape's maximum distance. See discussion.
- Best practices: add recommended presence. See discussion.
- Added fare media. See discussion.
- Added trip-to-trip transfers with in-seat option. See discussion.
- GTFS-Fares v2 base implementation. See discussion.
- Added Primary and Foreign ID fields. See discussion.
- Added Trip-to-trip and route-to-route transfers. See discussion.
- Allowed fare gates (pathway_mode=6) to be bidirectional. See discussion.
- Updated
stop_name
best practices. See discussion.
- Updated GTFS Schedule to RFC 2119. See discussion.
- Clarified description of
stop_times.stop_id
. See discussion. - Defined positive and non-zero field signs. See discussion.
- Changed field type of
frequencies.headway_secs
from non-negative to positive integer. See discussion.
- Defined
pathways.txt
,levels.txt
andattributions.txt
as translatable tables. Added recommendations for translating multilingualsignposted_as
values. See discussion.
- Added
continuous_pickup
andcontinuous_drop_off
toroutes.txt
andstop_times.txt
. Changedshape_id
from "Optional" to "Conditionally required". See discussion.
- Defined text-to-speech field and added
tts_stop_name
tostops.txt
. See discussion.
- Added trolleybus and monorail
route_types
. See discussion.
- Added
translations.txt
. See discussion.
- Updated definitions for cable tram and aerial lift in
route_type
. See discussion.
- Added
attributions.txt
. See discussion.
- Specified that
stop_lat
andstop_lon
be positioned where passengers wait to board the vehicle. See discussion.
- Added arrival and departure time best practices. See discussion.
- Added headsign best practices. See discussion.
- Added
stop_id
best practices. See discussion.
- Clarified relationship of shape points and stops. See discussion.
- Added
platform_code
field instops.txt
. See discussion.
- Added
pathways.txt
andlevels.txt
. See discussion.
- Editorial and formatting changes for clarity. See discussion.
- Factorized field types. See discussion.
- Added "Conditionally required" concept. See discussion.
- Unified the definitions of
agency_lang
andfeed_lang
. See discussion.
- Updated
CHANGES.md
and last revised date. See discussion.
- Added
feed_contact_email
andfeed_contact_url
fields in thefeed_info.txt
file. See discussion.
- Added
route_sort_order
toroutes.txt
. See discussion.
- Clarified that a proposer's vote does not count towards total. See discussion.
- Specified that at before calling a vote, at least one GTFS producer and one GTFS consumer should implement the proposed change. See discussion.
- Clarified relationship of
block_id
andservice_id
. See discussion. - Clarified that frequency-based service begins at vehicle departure. See discussion.
- Clarified descriptions of
stop_id
andstop_code
. See discussion.
- Added
route_sort_order
field in theroutes.txt
file. See discussion.
- Added station entrance as a
stops.location_type
. See discussion.
- Updated documentation to add
agency_id
underfare_attributes.txt
. See discussion.
- Transition of GTFS documentation to Github at https://github.com/google/transit
- Added
agency_email
toagency.txt
proposal to spec: discussion
- Added stop_times.txt 'timepoint' proposal to spec: discussion
- Added trips.txt 'bikes_allowed' proposal to spec: discussion
Added trips.txt 'wheelchair_accessible' proposal to spec: discussion
- Added 'wheelchair_boarding' proposal to spec: discussion
- Added 'stop_timezone' proposal to spec: discussion
- Migrated documentation from old code.google.com to their new location at developers.google.com.
- Added 'feed_info' proposal to spec: discussion
- Added 'agency_fare_url' proposal to spec: discussion
- Added 'exact_times' proposal to spec: discussion
- A new section on making a transit feed publicly available. This wasn't previously discussed on the group, because it wasn't strictly a change to how the data is interpreted or written. However, some of the folks at Google thought that it would be informative to include discussion of non-Google uses of GTFS, since there are an increasing number of applications that can make use of GTFS-formatted data.
- CSV format clarifications: discussion.
- Additional guidance on how to pick contrasting colors in the descriptions of the route_color and route_text_color fields.
- trip_short_name, as proposed and tested in these threads: a and b.
- A fix for a minor error in the sample data included at the end of the document (giving stop S7 the parent_station S8).
- Added "agency_lang" information to the sample data at the end of the document, as suggested by Marcy during the comment period: discussion.
- Updated the link to OCTA's GTFS feed in the sidebar
- See original summary.
- Removed most of the Google-specific feed submission instructions, since there are many other applications that consume GTFS data at this point.
- Fixed a broken link in the sidebar to Orange County OCTA's public feed.
- Restored the stop_url field, which was accidentally omitted in the August 6 version
- Added agency_phone to sample data
- Added a mention of the data use agreement when submitting a feed to Google
- Added transfers.txt file, allowing the feed publishers to provide hints on preferred transfer behavior (original proposal)
- Added location_type and parent_station fields to stops.txt, allowing stop points to be grouped into stations (original proposal)
- Added agency_phone field for providing voice telephone number for an agency (original proposal)
- Added "Testing Your Feeds" section mentioning open-source testing tools
- Added clarifications about CSV format, agency_timezone, agency_lang, route_color, route_text_color, arrival_time, departure_time, calendar.txt vs. calendar_dates.txt, fare tables, and frequencies.txt
- Added link to feed history document, and corrected some public feed links
- Updated example images to depict the current Google Maps UI
- Updated/fixed sample data in document
- Added the stop_code field in stops.txt to allow for the specification of rider-facing stop codes (original proposal)
- Clarified the descriptions of route_short_name and route_long_name in routes.txt
- Clarified the descriptions of arrival_time and departure_time in stop_times.txt
- Fixed typos in the Sample Data section
- Clarified block_id description
- Changed language to de-emphasize Google Transit (since non-Google applications are using GTFS, and transit routing is now an integrated feature of Google Maps), and to fix assorted typos
- Updated example screenshots to reflect the presentation of GTFS fields in the current Google Maps UI
- Updated the Google contact email address for transit data providers
- Updated formatting
- Changed stop_sequence and shape_pt_sequence to allow for any increasing non-negative integers
- Clarified descriptions and fixed typos
- Updated page style, made HTML cleaner and more accessible
- Added links to public feed examples and other useful sites
- Removed examples from individual field descriptions
- Added section on submitting a feed.
- Added the Example Demo Transit Agency feed.
- Added note that calendar.txt can be omitted if all the service dates are defined in calendar_dates.txt.
- Made the agency_id field optional in feeds containing only one agency. This allows existing feeds without agency_id to remain valid.
- Added fuller specification of agency_url, stop_url, and route_url, and additional example values for those fields.
- Added 6 (Gondola) and 7 (Funicular) as valid route_type values.
- Minor edit to move the stop_url field from stop_times.txt, where it was incorrectly specified in the Feb. 28 update, to stops.txt, where it belongs.
- Minor edit to clarify the description of the route_long_name field.
- Addition of frequencies.txt for headway-based schedule support.
- Multiple agencies now allowed in the the same feed. Also added new agency_id field in both agencies.txt and routes.txt that lets you specify which route is operated by which agency.
- Addition of per-route and per-stop URLs.
- Addition of direction_id field in trips.txt.
- Support for mid-trip headsign changes with addition of stop_headsign field in stop_times.txt.
- Support for route colors with addition of optional route_color and route_text_color in routes.txt.
- Removed the ability to specify stops using street addresses. The previous version of the spec allowed you to give the location of a transit stop using a street address in the stop_street, stop_city, stop_region, stop_postcode, and stop_country fields. Now stop locations must be given using stop_lat for latitude and stop_lon for longitude, which are more useful for most applications.
- Addition of cable car vehicle type for route_type field in routes.txt.
- See the original Headway blog post summary of the changes.
- Added support for trip shape information via shapes.txt
- Clarified the definition of stop_sequence
- Marked pickup_type and drop_off_type optional
- Added support for fare information
- Removed dates from individual file names
- Changed the route_type value definitions
- Allowed for multiple feed files to be posted at the same time, as long as their service periods didn't overlap
- Fixed block_id in trips.txt so that it was correctly marked Optional
- Noted that column headers must be included
- Minor edit to fix a couple errors in the examples.
- Initial version.