File: make_areas.py

package info (click to toggle)
metpy 1.7.1%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 18,584 kB
  • sloc: python: 41,853; makefile: 111; javascript: 57
file content (107 lines) | stat: -rw-r--r-- 4,350 bytes parent folder | download | duplicates (2)
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
# Copyright (c) 2023 MetPy Developers.
# Distributed under the terms of the BSD 3-Clause License.
# SPDX-License-Identifier: BSD-3-Clause

from pathlib import Path
import textwrap

import sphinx.util

from metpy.plots import named_areas

states_provinces = ['ak', 'al', 'ar', 'ca', 'co', 'ct', 'dc', 'de', 'fl', 'ga', 'hi',
                    'ia', 'id', 'il', 'in', 'ks', 'ky', 'la', 'ma', 'md', 'me', 'mi',
                    'mn', 'mo', 'ms', 'mt', 'nc', 'nd', 'ne', 'nh', 'nj', 'nm', 'nv',
                    'ny', 'oh', 'ok', 'or', 'pa', 'ri', 'sc', 'sd', 'tn', 'tx', 'ut',
                    'va', 'vt', 'wi', 'wv', 'wy', 'az', 'wa', 'cn', 'cnlcc', 'ab', 'bc',
                    'mb', 'nb', 'nf', 'ns', 'nt', 'nu', 'on', 'pe', 'qb', 'sa', 'yt', 'us',
                    'uslcc', 'awips', 'whlf', 'chlf', 'centus', 'ehlf', 'mehlf', 'bosfa',
                    'miafa', 'chifa', 'dfwfa', 'slcfa', 'sfofa', 'west', 'cent', 'east',
                    'nwus', 'swus', 'ncus', 'scus', 'neus', 'seus']


def generate_area_file(app):
    """Generate an RST file with nicely formatted views of map areas."""
    sphinx.util.logging.getLogger('make_areas').info('Generating areas file...')

    output = Path(app.srcdir) / 'api' / 'areas.rst'
    with output.open('w') as table:
        header = f"""
            .. (comment): DO NOT EDIT this file.
            .. It is auto-generated by running : {__file__}
            .. Please adjust by making changes there.
            .. It is included in the repository only to aid detection of changes.
            .. _api-areas:

            MetPy Area List
            ===============


            """

        table.write(textwrap.dedent(header))

        for ind, area in enumerate(named_areas):
            extent = named_areas[area].bounds
            longname = named_areas[area].description

            area_header = area + '  -  ' + longname + '\n'
            table.write(area_header)
            table.write('-' * len(area_header) + '\n\n')

            if area in states_provinces:
                code = textwrap.dedent(f"""
                .. plot::
                   :context: reset

                    import matplotlib.pyplot as plt
                    import cartopy.crs as ccrs
                    import cartopy.feature as cfeature
                    from metpy.plots import named_areas

                    proj = named_areas['{area}'].projection

                    plt.figure(figsize=(8, 10))
                    ax = plt.subplot(111, projection=proj)
                    ax.set_extent({extent}, ccrs.PlateCarree())
                    ax.add_feature(cfeature.STATES.with_scale('10m'), edgecolor='grey',
                                linewidth=0.75)
                    ax.add_feature(cfeature.COASTLINE.with_scale('10m'), linewidth=1.1)
                    ax.add_feature(cfeature.BORDERS.with_scale('10m'), edgecolor='black')
                    ax.set_title(f'area={area}          name={named_areas[area].description}')


                """)

            else:
                code = textwrap.dedent(f"""
                .. plot::
                   :context: reset

                    import matplotlib.pyplot as plt
                    import cartopy.crs as ccrs
                    import cartopy.feature as cfeature
                    from metpy.plots import named_areas

                    proj = named_areas['{area}'].projection

                    plt.figure(figsize=(8, 10))
                    ax = plt.subplot(111, projection=proj)
                    ax.set_extent({extent}, ccrs.PlateCarree())
                    ax.add_feature(cfeature.COASTLINE.with_scale('10m'), linewidth=1.1)
                    ax.add_feature(cfeature.BORDERS.with_scale('10m'), edgecolor='black')
                    ax.set_title(f'area={area}          name={named_areas[area].description}')


                """)
            table.write(code)
            if not app.config.metpy_generate_all_areas and ind >= 1:
                break


def setup(app):
    """Set up the make_areas extension with a callback once builders are initialized."""
    app.connect('builder-inited', generate_area_file)

    # Add option to only build a couple areas since all take a while--ONLY FOR DEV
    app.add_config_value('metpy_generate_all_areas', default=True, rebuild='html', types=bool)