@@ -1642,22 +1642,11 @@ def _normalize_dir(self, value):
1642
1642
value = os .path .abspath (value )
1643
1643
return value
1644
1644
1645
- # Because the validation of preferred_dir depends on root_dir and validation
1646
- # occurs when the trait is loaded, there are times when we should defer the
1647
- # validation of preferred_dir (e.g., when preferred_dir is defined via CLI
1648
- # and root_dir is defined via a config file).
1649
- _defer_preferred_dir_validation = False
1650
-
1651
1645
@validate ("root_dir" )
1652
1646
def _root_dir_validate (self , proposal ):
1653
1647
value = self ._normalize_dir (proposal ["value" ])
1654
1648
if not os .path .isdir (value ):
1655
1649
raise TraitError (trans .gettext ("No such directory: '%r'" ) % value )
1656
-
1657
- if self ._defer_preferred_dir_validation :
1658
- # If we're here, then preferred_dir is configured on the CLI and
1659
- # root_dir is configured in a file
1660
- self ._preferred_dir_validation (self .preferred_dir , value )
1661
1650
return value
1662
1651
1663
1652
preferred_dir = Unicode (
@@ -1674,39 +1663,8 @@ def _preferred_dir_validate(self, proposal):
1674
1663
value = self ._normalize_dir (proposal ["value" ])
1675
1664
if not os .path .isdir (value ):
1676
1665
raise TraitError (trans .gettext ("No such preferred dir: '%r'" ) % value )
1677
-
1678
- # Before we validate against root_dir, check if this trait is defined on the CLI
1679
- # and root_dir is not. If that's the case, we'll defer it's further validation
1680
- # until root_dir is validated or the server is starting (the latter occurs when
1681
- # the default root_dir (cwd) is used).
1682
- cli_config = self .cli_config .get ("ServerApp" , {})
1683
- if "preferred_dir" in cli_config and "root_dir" not in cli_config :
1684
- self ._defer_preferred_dir_validation = True
1685
-
1686
- if not self ._defer_preferred_dir_validation : # Validate now
1687
- self ._preferred_dir_validation (value , self .root_dir )
1688
1666
return value
1689
1667
1690
- def _preferred_dir_validation (self , preferred_dir : str , root_dir : str ) -> None :
1691
- """Validate preferred dir relative to root_dir - preferred_dir must be equal or a subdir of root_dir"""
1692
- if not preferred_dir .startswith (root_dir ):
1693
- raise TraitError (
1694
- trans .gettext (
1695
- "preferred_dir must be equal or a subdir of root_dir. preferred_dir: '%r' root_dir: '%r'"
1696
- )
1697
- % (preferred_dir , root_dir )
1698
- )
1699
- self ._defer_preferred_dir_validation = False
1700
-
1701
- @observe ("root_dir" )
1702
- def _root_dir_changed (self , change ):
1703
- self ._root_dir_set = True
1704
- if not self .preferred_dir .startswith (change ["new" ]):
1705
- self .log .warning (
1706
- trans .gettext ("Value of preferred_dir updated to use value of root_dir" )
1707
- )
1708
- self .preferred_dir = change ["new" ]
1709
-
1710
1668
@observe ("server_extensions" )
1711
1669
def _update_server_extensions (self , change ):
1712
1670
self .log .warning (_i18n ("server_extensions is deprecated, use jpserver_extensions" ))
@@ -1888,6 +1846,9 @@ def init_configurables(self):
1888
1846
parent = self ,
1889
1847
log = self .log ,
1890
1848
)
1849
+ # Trigger a default/validation here explicitly while we still support the
1850
+ # deprecated trait on ServerApp (FIXME remove when deprecation finalized)
1851
+ self .contents_manager .preferred_dir
1891
1852
self .session_manager = self .session_manager_class (
1892
1853
parent = self ,
1893
1854
log = self .log ,
@@ -2087,7 +2048,7 @@ def init_resources(self):
2087
2048
)
2088
2049
return
2089
2050
2090
- old_soft , old_hard = resource .getrlimit (resource .RLIMIT_NOFILE )
2051
+ old_soft , old_hard = resource .getrlimit (resource .RLIMIT_NOFILE ) # noqa
2091
2052
soft = self .min_open_files_limit
2092
2053
hard = old_hard
2093
2054
if old_soft < soft :
@@ -2098,7 +2059,7 @@ def init_resources(self):
2098
2059
old_soft , soft , old_hard , hard
2099
2060
)
2100
2061
)
2101
- resource .setrlimit (resource .RLIMIT_NOFILE , (soft , hard ))
2062
+ resource .setrlimit (resource .RLIMIT_NOFILE , (soft , hard )) # noqa
2102
2063
2103
2064
def _get_urlparts (self , path = None , include_token = False ):
2104
2065
"""Constructs a urllib named tuple, ParseResult,
@@ -2506,10 +2467,6 @@ def initialize(
2506
2467
# Parse command line, load ServerApp config files,
2507
2468
# and update ServerApp config.
2508
2469
super ().initialize (argv = argv )
2509
- if self ._defer_preferred_dir_validation :
2510
- # If we're here, then preferred_dir is configured on the CLI and
2511
- # root_dir has the default value (cwd)
2512
- self ._preferred_dir_validation (self .preferred_dir , self .root_dir )
2513
2470
if self ._dispatching :
2514
2471
return
2515
2472
# initialize io loop as early as possible,
0 commit comments