我會用pkgIndex文件源中的所有組成文件你的包。這將加載所有東西。然後在解釋器加載完所有內容後宣佈合奏。
package ifneeded Mypackage 1.2.3 \
"source \[file join [list $dir] pkg-part1.tcl\] ; \
source \[file join [list $dir] pkg-part2.tcl\] ; \
namespace ensemble create {...} ; \
package provide Mypackage 1.2.3"
不要在每個子組件中「提供」。一旦所有東西都被成功加載到解釋器中,最好提供這個包,所以我會在文件的末尾做這件事,或者在這種情況下,最後加載全套。如果您真的想將每個部分視爲一個子包,那麼沒有理由不將它們聲明爲子包,並且需要每個子包的主包。例如:
<main package>
package require Package::part1
package require Package::part2
package provide Package 1.0
<subpackage files>
namespace eval Package {
... stuff ...
}
... more stuff ...
package provide Package::partN 1.0
<pkgIndex.tcl>
package ifneeded Package::part1 1.0 [list source [file join $dir part1.tcl]]
package ifneeded Package::part2 1.0 [list source [file join $dir part2.tcl]]
package ifneeded Package 1.0 [list source [file join $dir package.tcl]]
這種模式可能是有用的,如果子組件可能是對自己有幫助的,或者它可能是很方便的只有某些部分加載到插補。 tcllib SASL軟件包可以避免在默認情況下加載某些機制(例如NTLM)。
非常感謝。你的解決方案非常完美!只是最後一件事。我仍然試圖創建一個命名空間集合。我將'包放在需要的地方Package :: part1 1.0 [list source [file join $ dir part1.tcl]] package ifneeded Package :: part2 1.0 [list source [file join $ dir part2.tcl]] package ifneeded Package 1.0 [list source [file join $ dir package.tcl]; \ namespace eval {namespace ensamble create}; \ package provides 0.1]'但它不起作用(我的意思是整體不起作用) 。它僅將第一個包中的proc識別爲子命令。 –
2012-02-21 11:44:39