Coverage for sources/frigid/__/nomina.py: 100%
21 statements
« prev ^ index » next coverage.py v7.9.1, created at 2025-06-14 22:24 +0000
« prev ^ index » next coverage.py v7.9.1, created at 2025-06-14 22:24 +0000
1# vim: set filetype=python fileencoding=utf-8:
2# -*- coding: utf-8 -*-
4#============================================================================#
5# #
6# Licensed under the Apache License, Version 2.0 (the "License"); #
7# you may not use this file except in compliance with the License. #
8# You may obtain a copy of the License at #
9# #
10# http://www.apache.org/licenses/LICENSE-2.0 #
11# #
12# Unless required by applicable law or agreed to in writing, software #
13# distributed under the License is distributed on an "AS IS" BASIS, #
14# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
15# See the License for the specific language governing permissions and #
16# limitations under the License. #
17# #
18#============================================================================#
21''' Common names and type aliases. '''
23# ruff: noqa: F401
26from classcore.standard.nomina import (
27 AttributesNamer,
28 BehaviorExclusionVerifiersOmni,
29 DecorationPreparers as ClassDecorationPreparers,
30 DynadocConfiguration,
31 concealment_label,
32 immutability_label,
33)
35from . import imports as __
38H = __.typx.TypeVar( 'H', bound = __.cabc.Hashable ) # Hash Key
39T = __.typx.TypeVar( 'T', bound = type ) # Class
40U = __.typx.TypeVar( 'U' ) # Class
41V = __.typx.TypeVar( 'V' ) # Value
44ComparisonResult: __.typx.TypeAlias = bool | __.types.NotImplementedType
45NominativeArguments: __.typx.TypeAlias = __.cabc.Mapping[ str, __.typx.Any ]
46PositionalArguments: __.typx.TypeAlias = __.cabc.Sequence[ __.typx.Any ]
48# TODO: Import ClassDecorator aliases from 'classcore' once documentation
49# fragments have been removed from them.
50ClassDecorator: __.typx.TypeAlias = (
51 __.cabc.Callable[ [ type[ U ] ], type[ U ] ] )
52ClassDecorators: __.typx.TypeAlias = (
53 __.cabc.Sequence[ ClassDecorator[ U ] ] )
54ClassDecoratorFactory: __.typx.TypeAlias = (
55 __.cabc.Callable[ ..., ClassDecorator[ U ] ] )
57DictionaryNominativeArgument: __.typx.TypeAlias = __.typx.Annotated[
58 V,
59 __.ddoc.Doc(
60 'Zero or more keyword arguments from which to initialize '
61 'dictionary data.' ),
62]
63DictionaryPositionalArgument: __.typx.TypeAlias = __.typx.Annotated[
64 __.cabc.Mapping[ H, V ] | __.cabc.Iterable[ tuple[ H, V ] ],
65 __.ddoc.Doc(
66 'Zero or more iterables from which to initialize dictionary data. '
67 'Each iterable must be dictionary or sequence of key-value pairs. '
68 'Duplicate keys will result in an error.' ),
69]
70DictionaryValidator: __.typx.TypeAlias = __.typx.Annotated[
71 __.cabc.Callable[ [ H, V ], bool ],
72 __.ddoc.Doc(
73 'Callable which validates entries before addition to dictionary.' ),
74]
75ModuleReclassifier: __.typx.TypeAlias = __.cabc.Callable[
76 [ __.cabc.Mapping[ str, __.typx.Any ] ], None ]
79package_name = __name__.split( '.', maxsplit = 1 )[ 0 ]
82def calculate_attrname( level: str, core: str ) -> str:
83 return f"_{package_name}_{level}_{core}_"
86def is_public_identifier( name: str ) -> bool:
87 ''' Is Python identifier public? '''
88 return not name.startswith( '_' )