forked from ibis-project/ibis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
gen_redirects.py
193 lines (183 loc) · 10 KB
/
gen_redirects.py
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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
from __future__ import annotations
import pathlib
# Versions for templated redirects
VERSIONS = ["latest", "dev", "4.1.0", "4.0.0", "3.2.0", "3.1.0", "3.0.2"]
# Templated redirects
TEMPLATED_REDIRECTS = {
"/backends/{version}/BigQuery/": "/backends/bigquery/",
"/backends/{version}/Clickhouse/": "/backends/clickhouse/",
"/backends/{version}/Dask/": "/backends/dask/",
"/backends/{version}/Datafusion/": "/backends/datafusion/",
"/backends/{version}/Druid/": "/backends/druid/",
"/backends/{version}/DuckDB/": "/backends/duckdb/",
"/backends/{version}/Impala/": "/backends/impala/",
"/backends/{version}/MSSQL/": "/backends/mssql/",
"/backends/{version}/MySQL/": "/backends/mysql/",
"/backends/{version}/Oracle/": "/backends/oracle/",
"/backends/{version}/Pandas/": "/backends/pandas/",
"/backends/{version}/Polars/": "/backends/polars/",
"/backends/{version}/PostgreSQL/": "/backends/postgresql/",
"/backends/{version}/PySpark/": "/backends/pyspark/",
"/backends/{version}/SQLite/": "/backends/sqlite/",
"/backends/{version}/Snowflake/": "/backends/snowflake/",
"/backends/{version}/Trino/": "/backends/trino/",
"/docs/{version}/": "/",
"/docs/{version}/api/": "/reference/",
"/docs/{version}/backends/": "/backends/",
"/docs/{version}/backends/BigQuery/": "/backends/bigquery/",
"/docs/{version}/backends/Clickhouse/": "/backends/clickhouse/",
"/docs/{version}/backends/Dask/": "/backends/dask/",
"/docs/{version}/backends/Datafusion/": "/backends/datafusion/",
"/docs/{version}/backends/Druid/": "/backends/druid/",
"/docs/{version}/backends/DuckDB/": "/backends/duckdb/",
"/docs/{version}/backends/Impala/": "/backends/impala/",
"/docs/{version}/backends/MSSQL/": "/backends/mssql/",
"/docs/{version}/backends/MySQL/": "/backends/mysql/",
"/docs/{version}/backends/Oracle/": "/backends/oracle/",
"/docs/{version}/backends/Pandas/": "/backends/pandas/",
"/docs/{version}/backends/Polars/": "/backends/polars/",
"/docs/{version}/backends/PostgreSQL/": "/backends/postgresql/",
"/docs/{version}/backends/PySpark/": "/backends/pyspark/",
"/docs/{version}/backends/SQLite/": "/backends/sqlite/",
"/docs/{version}/backends/Snowflake/": "/backends/snowflake/",
"/docs/{version}/backends/Trino/": "/backends/trino/",
"/docs/{version}/docs/": "/docs/",
"/docs/{version}/how_to/": "/how-to/",
"/docs/{version}/install/": "/install/",
}
# Untemplated redirects
REDIRECTS = {
"/api/": "/reference/",
"/api/backends/": "/reference/backends/",
"/api/backends/base/": "/reference/backends/base/",
"/api/backends/pandas/": "/reference/backends/pandas/",
"/api/backends/sql/": "/reference/backends/sql/",
"/api/backends/sqlalchemy/": "/reference/backends/sqlalchemy/",
"/api/config/": "/reference/config/",
"/api/datatypes/": "/reference/datatypes/",
"/api/expressions/": "/reference/expressions/",
"/api/expressions/collections/": "/reference/expressions/collections/",
"/api/expressions/generic/": "/reference/expressions/generic/",
"/api/expressions/geospatial/": "/reference/expressions/geospatial/",
"/api/expressions/numeric/": "/reference/expressions/numeric/",
"/api/expressions/strings/": "/reference/expressions/strings/",
"/api/expressions/tables/": "/reference/expressions/tables/",
"/api/expressions/timestamps/": "/reference/expressions/timestamps/",
"/api/expressions/top_level/": "/reference/expressions/top_level/",
"/api/schemas/": "/reference/schemas/",
"/api/selectors/": "/reference/selectors/",
"/backends/": "/support_matrix",
"/backends/BigQuery/": "/backends/bigquery/",
"/backends/Clickhouse/": "/backends/clickhouse/",
"/backends/Dask/": "/backends/dask/",
"/backends/Datafusion/": "/backends/datafusion/",
"/backends/Druid/": "/backends/druid/",
"/backends/DuckDB/": "/backends/duckdb/",
"/backends/Impala/": "/backends/impala/",
"/backends/MSSQL/": "/backends/mssql/",
"/backends/MySQL/": "/backends/mysql/",
"/backends/Oracle/": "/backends/oracle/",
"/backends/Pandas/": "/backends/pandas/",
"/backends/Polars/": "/backends/polars/",
"/backends/PostgreSQL/": "/backends/postgresql/",
"/backends/PySpark/": "/backends/pyspark/",
"/backends/SQLite/": "/backends/sqlite/",
"/backends/Snowflake/": "/backends/snowflake/",
"/backends/Trino/": "/backends/trino/",
"/backends/_support_matrix/": "/support_matrix",
"/backends/support_matrix": "/support_matrix",
"/blog": "/posts",
"/blog/Ibis-version-3.0.0-release/": "/posts/Ibis-version-3.0.0-release/",
"/blog/Ibis-version-3.1.0-release/": "/posts/Ibis-version-3.1.0-release/",
"/blog/ffill-and-bfill-using-ibis/": "/posts/ffill-and-bfill-using-ibis",
"/blog/ibis-examples/": "/posts/ibis-examples/",
"/blog/ibis-to-file/": "/posts/ibis-to-file/",
"/blog/ibis-version-4.0.0-release/": "/posts/ibis-version-4.0.0-release/",
"/blog/ibis_substrait_to_duckdb/": "/posts/ibis_substrait_to_duckdb/",
"/blog/rendered/campaign-finance/": "/posts/campaign-finance/",
"/blog/rendered/campaign-finance/campaign-finance.ipynb": "/posts/campaign-finance/",
"/blog/rendered/ci-analysis/": "/posts/ci-analysis/",
"/blog/rendered/ci-analysis/ci-analysis.ipynb": "/posts/ci-analysis/",
"/blog/rendered/ibis-version-6.0.0-release/": "/posts/ibis-version-6.0.0-release/",
"/blog/rendered/ibis-version-6.0.0-release/ibis-version-6.0.0-release.ipynb": "/posts/ibis-version-6.0.0-release/",
"/blog/rendered/ibis-version-6.1.0-release/": "/posts/ibis-version-6.1.0-release/",
"/blog/rendered/ibis-version-6.1.0-release/ibis-version-6.1.0-release.ipynb": "/posts/ibis-version-6.1.0-release/",
"/blog/rendered/torch/": "/posts/torch/",
"/blog/rendered/torch/torch.ipynb": "/posts/torch/",
"/blog/selectors/": "/posts/selectors/",
"/community": "/contribute/01_environment",
"/community/contribute/": "/contribute/01_environment",
"/community/contribute/01_environment/": "/contribute/01_environment",
"/community/contribute/02_workflow/": "/contribute/02_workflow/",
"/community/contribute/03_style/": "/contribute/03_style/",
"/community/contribute/05_maintainers_guide/": "/contribute/05_maintainers_guide/",
"/concept/backends/": "/concepts/backend",
"/concept/design/": "/concepts/internals",
"/concept/why_ibis/": "/why",
"/docs/": "/",
"/docs/dev/backends/support_matrix/": "/support_matrix",
"/docs/dev/contribute/01_environment/": "/contribute/01_environment",
"/docs/dev/release_notes/": "/release_notes",
"/getting_started/": "/tutorial/getting_started/",
"/how_to/chain-expressions/": "/how-to/analytics/chain_expressions/",
"/how_to/chain_expressions/": "/how-to/analytics/chain_expressions/",
"/how_to/configuration/": "/how-to/configure/basics",
"/how_to/duckdb_register/": "/backends/duckdb#ibis.backends.duckdb.Backend.register",
"/how_to/extending/elementwise/": "/how-to/extending/elementwise",
"/how_to/extending/elementwise/elementwise.ipynb": "/how-to/extending/elementwise",
"/how_to/extending/reduction/": "/how-to/extending/reduction",
"/how_to/extending/reduction/reduction.ipynb": "/how-to/extending/reduction",
"/how_to/ffill_bfill_w_window/": "/posts/ffill-and-bfill-using-ibis",
"/how_to/self_joins/": "/tutorials/ibis-for-sql-users#self-joins",
"/how_to/sessionize": "/how-to/timeseries/sessionize",
"/how_to/streamlit/": "/how-to/visualization/streamlit",
"/how_to/topk/": "/tutorials/ibis-for-sql-users#top-k-operations",
"/ibis-for-dplyr-users/": "/tutorial/ibis-for-dplyr-users/",
"/ibis-for-pandas-users/": "/tutorial/ibis-for-pandas-users/",
"/ibis-for-sql-programmers/": "/tutorial/ibis-for-sql-users/",
"/reference/backends/pandas/": "/backends/pandas/",
"/reference/expressions/": "/reference/",
"/reference/expressions/collections/": "/reference/expression-collections",
"/reference/expressions/generic/": "/reference/expression-generic",
"/reference/expressions/geospatial/": "/reference/expression-geospatial",
"/reference/expressions/numeric/": "/reference/expression-numeric",
"/reference/expressions/strings/": "/reference/expression-strings",
"/reference/expressions/tables/": "/reference/expressions-tables",
"/reference/expressions/timestamps/": "/reference/expression-temporal",
"/reference/expressions/top_level/": "/reference/top_level",
"/tutorial/": "/tutorials/getting_started/",
"/tutorial/getting_started/": "/tutorials/getting_started",
"/tutorial/ibis-for-dplyr-users/": "/tutorials/ibis-for-dplyr-users/",
"/tutorial/ibis-for-dplyr-users/ibis-for-dplyr-users.ipynb": "/tutorials/ibis-for-dplyr-users/",
"/tutorial/ibis-for-pandas-users/": "/tutorials/ibis-for-pandas-users/",
"/tutorial/ibis-for-pandas-users/ibis-for-pandas-users.ipynb": "/tutorials/ibis-for-pandas-users/",
"/tutorial/ibis-for-sql-users/": "/tutorials/ibis-for-sql-users/",
"/tutorial/ibis-for-sql-users/ibis-for-sql-users.ipynb": "/tutorials/ibis-for-sql-users/",
"/user_guide/configuration/": "/how-to/configure/basics",
"/user_guide/design/": "/concepts/internals",
"/user_guide/extending/": "/how-to/extending/elementwise",
"/user_guide/self_joins/": "/tutorials/ibis-for-sql-users#self-joins",
"/versioning": "/concepts/versioning",
"/why_ibis/": "/why",
# TODO: "/how_to/memtable-join/": "/how_to/memtable_join/",
# TODO: "/how_to/memtable_join/"
# TODO: "/reference/backends/base/"
# TODO: "/reference/backends/sql/"
# TODO: "/reference/backends/sqlalchemy/"
}
# Fill in templates
REDIRECTS.update(
{
old.format(version=version): new
for version in VERSIONS
for old, new in TEMPLATED_REDIRECTS.items()
}
)
def main():
# Write all redirect files
output_dir = pathlib.Path(__file__).parent.joinpath("docs", "_output")
output_dir.mkdir(exist_ok=True, parents=True)
lines = "\n".join(f"{old} {new}" for old, new in REDIRECTS.items())
output_dir.joinpath("_redirects").write_text(f"{lines}\n")
if __name__ == "__main__":
main()