B –öϨKàéŠã@sˆdZddlmZddlmZmZmZmZmZm Z Gdd„dƒZ Gdd„de ƒZ e dkr„dd l mZed d d d ddlmZee ƒdS)zBDefine SearchDialogBase used by Search, Replace, and Grep dialogs.é)ÚToplevel)ÚFrameÚEntryÚLabelÚButtonÚ CheckbuttonÚ Radiobuttonc@s|eZdZdZdZdZdZdd„Zddd „Zdd d „Z d d „Z dd„Z dd„Z ddd„Z dd„Zdd„Zd dd„Zdd„ZdS)!ÚSearchDialogBaseayCreate most of a 3 or 4 row, 3 column search dialog. The left and wide middle column contain: 1 or 2 labeled text entry lines (make_entry, create_entries); a row of standard Checkbuttons (make_frame, create_option_buttons), each of which corresponds to a search engine Variable; a row of dialog-specific Check/Radiobuttons (create_other_buttons). The narrow right column contains command buttons (make_button, create_command_buttons). These are bound to functions that execute the command. Except for command buttons, this base class is not limited to items common to all three subclasses. Rather, it is the Find dialog minus the "Find Next" command, its execution function, and the default_command attribute needed in create_widgets. The other dialogs override attributes and methods, the latter to replace and add widgets. z Search DialogZSearchécCs||_|j|_||_d|_dS)a'Initialize root, engine, and top attributes. top (level widget): set in create_widgets() called from open(). text (Text searched): set in open(), only used in subclasses(). ent (ry): created in make_entry() called from create_entry(). row (of grid): 0 in create_widgets(), +1 in make_entry/frame(). default_command: set in subclasses, used in create_widgets(). title (of dialog): class attribute, override in subclasses. icon (of dialog): ditto, use unclear if cannot minimize dialog. N)ÚrootZbellÚengineÚtop)Úselfr r ©rú7/opt/alt/python37/lib64/python3.7/idlelib/searchbase.pyÚ__init__ s zSearchDialogBase.__init__NcCsŒ||_|js| ¡n|j ¡|j ¡|j | ¡¡|rZ|j dd¡|j  d|¡|j  ¡|j  dd¡|j  d¡|j  ¡dS)z6Make dialog visible on top of others and ready to use.rÚendN)Útextr Úcreate_widgetsZ deiconifyZtkraiseÚ transientZwinfo_toplevelÚentÚdeleteÚinsertZ focus_setZselection_rangeZicursorZgrab_set)rrZ searchphraserrrÚopen1s     zSearchDialogBase.opencCs*|jr&|j ¡|j d¡|j ¡dS)zPut dialog away for later use.ÚN)r Z grab_releaserZwithdraw)rZeventrrrÚcloseBs  zSearchDialogBase.closecCs¢t|jƒ}| d|j¡| d|j¡| d|j¡| |j¡| |j ¡||_ d|_ |j j dddd|j j ddddd |  ¡| ¡| ¡| ¡d S) z¹Create basic 3 row x 3 col search (find) dialog. Other dialogs override subsidiary create_x methods as needed. Replace and Find-in-Files add another entry row. zzZWM_DELETE_WINDOWré)ÚpadÚweightr éd)rZminsizerN)rr ZbindÚdefault_commandrZprotocolZwm_titleÚtitleZ wm_iconnameÚiconr ÚrowZgrid_columnconfigureÚcreate_entriesÚcreate_option_buttonsÚcreate_other_buttonsÚcreate_command_buttons)rr rrrrIs   zSearchDialogBase.create_widgetscCsVt|j|d}|j|jdddt|j|dd}|j|jddd|jd|_||fS)zŒReturn (entry, label), . entry - gridded labeled Entry for text entry. label - Label widget, returned for testing. )rrÚnw)r#ÚcolumnÚsticky)Z textvariableZexportselectionr Únwe)rr Úgridr#r)rZ label_textÚvarÚlabelÚentryrrrÚ make_entry`s  zSearchDialogBase.make_entrycCs| d|jj¡d|_dS)z/Create one or more entry lines with make_entry.zFind:rN)r0r Zpatvarr)rrrrr$mszSearchDialogBase.create_entriescCs\|r&t|j|d}|j|jdddnd}t|jƒ}|j|jdddd|jd|_||fS) z—Return (frame, label). frame - gridded labeled Frame for option or other buttons. label - Label widget, returned for testing. )rrr()r#r)r*rr r+)r#r)Z columnspanr*)rr r,r#r)rZ labeltextr.ÚframerrrÚ make_frameqs  zSearchDialogBase.make_framecCs|| d¡d}|j}|jdf|jdf|jdfg}|jrF| |jdf¡x,|D]$\}}t|||d}|j dd d qLW||fS) aReturn (filled frame, options) for testing. Options is a list of searchengine booleanvar, label pairs. A gridded frame from make_frame is filled with a Checkbutton for each pair, bound to the var, with the corresponding label. ZOptionsrzRegular expressionz Match casez Whole wordz Wrap around)ÚvariablerÚleftÚboth)ÚsideÚfill) r2r ZrevarZcasevarZwordvarÚneedwrapbuttonÚappendZwrapvarrÚpack)rr1r Zoptionsr-r.Úbtnrrrr%s z&SearchDialogBase.create_option_buttonscCsV| d¡d}|jj}ddg}x.|D]&\}}t||||d}|jdddq$W||fS) z£Return (frame, others) for testing. Others is a list of value, label pairs. A gridded frame from make_frame is filled with radio buttons. Z Directionr)r ZUp)rZDown)r3Úvaluerr4r5)r6r7)r2r Zbackvarrr:)rr1r-ZothersÚvalr.r;rrrr&”sz%SearchDialogBase.create_other_buttonsrcCsPt|j|||rdpdd}|j ¡\}}|jd|ddd|jj|dd|S) z/Return command button gridded in command frame.ZactiveZnormal)rÚcommandÚdefaultr rZew)Úpadyr#r)r*)Zrowspan)rÚ buttonframeZ grid_sizer,)rr.r>ZisdefÚbZcolsZrowsrrrÚ make_button¢szSearchDialogBase.make_buttoncCs@t|jƒ}|_|jddddddd| d|j¡}| ¡dS)z9Place buttons in vertical command frame gridded on right.rr)r#r)Zpadxr@ZipadxZipadyZCloseN)rr rAr,rCrÚlower)rÚfrBrrrr'¬sz'SearchDialogBase.create_command_buttons)N)N)N)r)Ú__name__Ú __module__Ú __qualname__Ú__doc__r!r"r8rrrrr0r$r2r%r&rCr'rrrrr s     r c@s eZdZdZdd„Zdd„ZdS)Ú _searchbasez3Create auto-opening dialog with no text connection.cCs|ddl}ddlm}||_| |¡|_| ¡t| ¡ƒt t t |  d| ¡¡ƒƒ\}}}}|j  d|d|df¡dS)Nr)Ú searchenginez[x+]z+%d+%dé(é¯)ÚreZidlelibrKr Úgetr rÚprintZgeometryÚlistÚmapÚintÚsplitr )rÚparentrNrKÚwidthZheightÚxÚyrrrr¸s   "z_searchbase.__init__cCsdS)Nr)rZdummyrrrr Ãóz_searchbase.default_commandN)rFrGrHrIrr rrrrrJµs rJÚ__main__)Úmainz!idlelib.idle_test.test_searchbaserF)Ú verbosityÚexit)ÚrunN)rIZtkinterrZ tkinter.ttkrrrrrrr rJrFZunittestr[Zidlelib.idle_test.htestr^rrrrÚs  /