Skip to content

Commit 93f83b6

Browse files
committed
Improve README
1 parent 0ff0c79 commit 93f83b6

File tree

1 file changed

+15
-9
lines changed

1 file changed

+15
-9
lines changed

README.md

Lines changed: 15 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -23,13 +23,6 @@ The stubs should be automatically picked up by your editor or typechecker.
2323

2424
## Caveats
2525

26-
### Performance
27-
The stubs contain a separate overload of `googleapiclient.discovery.build` for each service and version (see `discovery.pyi`).
28-
This can lead to slow type inference for this function. Mypy will generally be pretty fast after the first run,
29-
but you might experience slow autocomplete in your editor. If you're experiencing this problem you can bypass type inference with explicit annotations,
30-
e.g. `sheets_service: SheetsResource = build("sheets", "v4")` instead of `sheets_service = build("sheets", "v4")`.
31-
See the next section for some caveats to this approach.
32-
3326
### Explicit annotations
3427
The `google-api-python-client-stubs` is quite dynamic.
3528
All resources are just instances of a single class with dynamically attached methods
@@ -42,11 +35,24 @@ annotate a variable, argument or return type in your code with one of these type
4235
This ensures that Python doesn't attempt to evaluate the types at runtime.
4336
Note that the import is only supported in Python 3.7 and above.
4437
2. Only import the types inside an `if typing.TYPE_CHECKING` block. This ensures that the imports are only evaluated during
45-
type checking. Note that any type not available at runtime is located under the `googleapiclient._apis` package.
46-
For example, `SheetsResource` should be imported from `googleapiclient._apis.sheets.v4`. Note that nested resources have a nested class structure, e.g. the return type of `sheets_service.spreadsheets().values()` is `SheetsResource.SpreadsheetsResource.ValuesResource`.
38+
type checking, not at runtime.
39+
40+
Any type not available at runtime is located under the `googleapiclient._apis` package, with a subpackage for the API and a subpackage for the API version.
41+
For example, the return type of `build("sheets", "v4")`, `SheetsResource`, should be imported from `googleapiclient._apis.sheets.v4`. Nested resources have a nested class structure, e.g. the return type of `build("sheets", "v4").spreadsheets().values()` is `SheetsResource.SpreadsheetsResource.ValuesResource`.
4742
If autocompleting import paths doesn't work you can find the correct path by using Mypy's [reveal_type](https://mypy.readthedocs.io/en/stable/common_issues.html#reveal-type)
4843
on the thing you want to explicitly annotate. For `TypedDict`s this will also give you useful info about the structure of the dictionary.
4944

45+
If you use Pyright/Pylance, you'll get a [reportMissingModuleSource](https://github.com/microsoft/pyright/blob/main/docs/configuration.md#reportMissingModuleSource) error at the import site, which indicates that the stub file doesn't have a corresponding source file. As long as the import only occurs during typechecking, this can be safely ignored. Autocomplete and typechecking will still work.
46+
47+
Note that since the types don't exist at runtime, they're not compatible with libraries that evaluate annotations at runtime. For example, you can't use them to annotate a field in a Pydantic model.
48+
49+
### Performance
50+
The stubs contain a separate overload of `googleapiclient.discovery.build` for each service and version (see `discovery.pyi`).
51+
This can lead to slow type inference for this function. Mypy will generally be pretty fast after the first run,
52+
but you might experience slow autocomplete in your editor. If you're experiencing this problem you can bypass type inference with explicit annotations,
53+
e.g. `sheets_service: SheetsResource = build("sheets", "v4")` instead of `sheets_service = build("sheets", "v4")`.
54+
Note the caveats to this approach in the previous section.
55+
5056
### Recursive types
5157
The stubs previously didn't include recursive type definitions due to a lack of type checker support, but this is now included. Note that if you're using Mypy, v0.990 or higher is required for this to work.
5258

0 commit comments

Comments
 (0)