SILENT KILLERPanel

Current Path: > > opt > alt > python37 > lib64 > > python3.7 > idlelib


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/alt/python37/lib64//python3.7/idlelib

NameTypeSizeLast ModifiedActions
Icons Directory - -
__pycache__ Directory - -
idle_test Directory - -
CREDITS.txt File 1866 bytes June 05 2023 20:45:13.
ChangeLog File 56360 bytes June 05 2023 20:45:13.
HISTORY.txt File 10312 bytes June 05 2023 20:45:13.
NEWS.txt File 48791 bytes June 05 2023 20:45:13.
NEWS2x.txt File 27172 bytes June 05 2023 20:45:13.
README.txt File 9599 bytes June 05 2023 20:45:13.
TODO.txt File 8478 bytes June 05 2023 20:45:13.
__init__.py File 396 bytes April 17 2024 17:36:04.
__main__.py File 159 bytes April 17 2024 17:36:04.
autocomplete.py File 8954 bytes April 17 2024 17:36:04.
autocomplete_w.py File 20109 bytes April 17 2024 17:36:04.
autoexpand.py File 3216 bytes April 17 2024 17:36:04.
browser.py File 8314 bytes April 17 2024 17:36:04.
calltip.py File 6318 bytes April 17 2024 17:36:04.
calltip_w.py File 7158 bytes April 17 2024 17:36:04.
codecontext.py File 11326 bytes April 17 2024 17:36:04.
colorizer.py File 12992 bytes April 17 2024 17:36:04.
config-extensions.def File 2266 bytes June 05 2023 20:45:13.
config-highlight.def File 2864 bytes June 05 2023 20:45:13.
config-keys.def File 10910 bytes June 05 2023 20:45:13.
config-main.def File 3168 bytes June 05 2023 20:45:13.
config.py File 38173 bytes April 17 2024 17:36:04.
config_key.py File 14465 bytes April 17 2024 17:36:04.
configdialog.py File 104524 bytes April 17 2024 17:36:04.
debugger.py File 19104 bytes April 17 2024 17:36:04.
debugger_r.py File 12140 bytes April 17 2024 17:36:04.
debugobj.py File 4055 bytes April 17 2024 17:36:04.
debugobj_r.py File 1082 bytes April 17 2024 17:36:04.
delegator.py File 1043 bytes April 17 2024 17:36:04.
dynoption.py File 2017 bytes April 17 2024 17:36:04.
editor.py File 65614 bytes April 17 2024 17:36:04.
extend.txt File 3642 bytes June 05 2023 20:45:13.
filelist.py File 3896 bytes April 17 2024 17:36:04.
format.py File 15777 bytes April 17 2024 17:36:04.
grep.py File 7479 bytes April 17 2024 17:36:04.
help.html File 62214 bytes June 05 2023 20:45:13.
help.py File 11734 bytes April 17 2024 17:36:04.
help_about.py File 8981 bytes April 17 2024 17:36:04.
history.py File 4043 bytes April 17 2024 17:36:04.
hyperparser.py File 12883 bytes April 17 2024 17:36:04.
idle.py File 454 bytes April 17 2024 17:36:04.
idle.pyw File 570 bytes June 05 2023 20:45:13.
iomenu.py File 20632 bytes April 17 2024 17:36:04.
macosx.py File 9662 bytes April 17 2024 17:36:04.
mainmenu.py File 3918 bytes April 17 2024 17:36:04.
multicall.py File 18648 bytes April 17 2024 17:36:04.
outwin.py File 5788 bytes April 17 2024 17:36:04.
parenmatch.py File 7204 bytes April 17 2024 17:36:04.
pathbrowser.py File 3193 bytes April 17 2024 17:36:04.
percolator.py File 3130 bytes April 17 2024 17:36:04.
pyparse.py File 19947 bytes April 17 2024 17:36:04.
pyshell.py File 57247 bytes April 17 2024 17:36:04.
query.py File 14898 bytes April 17 2024 17:36:04.
redirector.py File 6875 bytes April 17 2024 17:36:04.
replace.py File 9889 bytes April 17 2024 17:36:04.
rpc.py File 21137 bytes April 17 2024 17:36:04.
run.py File 20293 bytes April 17 2024 17:36:04.
runscript.py File 8781 bytes April 17 2024 17:36:04.
scrolledlist.py File 4465 bytes April 17 2024 17:36:04.
search.py File 5566 bytes April 17 2024 17:36:04.
searchbase.py File 7537 bytes April 17 2024 17:36:04.
searchengine.py File 7472 bytes April 17 2024 17:36:04.
sidebar.py File 13585 bytes April 17 2024 17:36:04.
squeezer.py File 12840 bytes April 17 2024 17:36:04.
stackviewer.py File 4454 bytes April 17 2024 17:36:04.
statusbar.py File 1441 bytes April 17 2024 17:36:04.
textview.py File 6813 bytes April 17 2024 17:36:04.
tooltip.py File 6565 bytes April 17 2024 17:36:04.
tree.py File 16357 bytes April 17 2024 17:36:04.
undo.py File 11046 bytes April 17 2024 17:36:04.
window.py File 2616 bytes April 17 2024 17:36:04.
zoomheight.py File 4203 bytes April 17 2024 17:36:04.
zzdummy.py File 961 bytes April 17 2024 17:36:04.

Reading File: //opt/alt/python37/lib64//python3.7/idlelib/grep.py

"""Grep dialog for Find in Files functionality.

   Inherits from SearchDialogBase for GUI and uses searchengine
   to prepare search pattern.
"""
import fnmatch
import os
import sys

from tkinter import StringVar, BooleanVar
from tkinter.ttk import Checkbutton  # Frame imported in ...Base

from idlelib.searchbase import SearchDialogBase
from idlelib import searchengine

# Importing OutputWindow here fails due to import loop
# EditorWindow -> GrepDialog -> OutputWindow -> EditorWindow


def grep(text, io=None, flist=None):
    """Open the Find in Files dialog.

    Module-level function to access the singleton GrepDialog
    instance and open the dialog.  If text is selected, it is
    used as the search phrase; otherwise, the previous entry
    is used.

    Args:
        text: Text widget that contains the selected text for
              default search phrase.
        io: iomenu.IOBinding instance with default path to search.
        flist: filelist.FileList instance for OutputWindow parent.
    """
    root = text._root()
    engine = searchengine.get(root)
    if not hasattr(engine, "_grepdialog"):
        engine._grepdialog = GrepDialog(root, engine, flist)
    dialog = engine._grepdialog
    searchphrase = text.get("sel.first", "sel.last")
    dialog.open(text, searchphrase, io)


def walk_error(msg):
    "Handle os.walk error."
    print(msg)


def findfiles(folder, pattern, recursive):
    """Generate file names in dir that match pattern.

    Args:
        folder: Root directory to search.
        pattern: File pattern to match.
        recursive: True to include subdirectories.
    """
    for dirpath, _, filenames in os.walk(folder, onerror=walk_error):
        yield from (os.path.join(dirpath, name)
                    for name in filenames
                    if fnmatch.fnmatch(name, pattern))
        if not recursive:
            break


class GrepDialog(SearchDialogBase):
    "Dialog for searching multiple files."

    title = "Find in Files Dialog"
    icon = "Grep"
    needwrapbutton = 0

    def __init__(self, root, engine, flist):
        """Create search dialog for searching for a phrase in the file system.

        Uses SearchDialogBase as the basis for the GUI and a
        searchengine instance to prepare the search.

        Attributes:
            flist: filelist.Filelist instance for OutputWindow parent.
            globvar: String value of Entry widget for path to search.
            globent: Entry widget for globvar.  Created in
                create_entries().
            recvar: Boolean value of Checkbutton widget for
                traversing through subdirectories.
        """
        super().__init__(root, engine)
        self.flist = flist
        self.globvar = StringVar(root)
        self.recvar = BooleanVar(root)

    def open(self, text, searchphrase, io=None):
        """Make dialog visible on top of others and ready to use.

        Extend the SearchDialogBase open() to set the initial value
        for globvar.

        Args:
            text: Multicall object containing the text information.
            searchphrase: String phrase to search.
            io: iomenu.IOBinding instance containing file path.
        """
        SearchDialogBase.open(self, text, searchphrase)
        if io:
            path = io.filename or ""
        else:
            path = ""
        dir, base = os.path.split(path)
        head, tail = os.path.splitext(base)
        if not tail:
            tail = ".py"
        self.globvar.set(os.path.join(dir, "*" + tail))

    def create_entries(self):
        "Create base entry widgets and add widget for search path."
        SearchDialogBase.create_entries(self)
        self.globent = self.make_entry("In files:", self.globvar)[0]

    def create_other_buttons(self):
        "Add check button to recurse down subdirectories."
        btn = Checkbutton(
                self.make_frame()[0], variable=self.recvar,
                text="Recurse down subdirectories")
        btn.pack(side="top", fill="both")

    def create_command_buttons(self):
        "Create base command buttons and add button for Search Files."
        SearchDialogBase.create_command_buttons(self)
        self.make_button("Search Files", self.default_command, isdef=True)

    def default_command(self, event=None):
        """Grep for search pattern in file path. The default command is bound
        to <Return>.

        If entry values are populated, set OutputWindow as stdout
        and perform search.  The search dialog is closed automatically
        when the search begins.
        """
        prog = self.engine.getprog()
        if not prog:
            return
        path = self.globvar.get()
        if not path:
            self.top.bell()
            return
        from idlelib.outwin import OutputWindow  # leave here!
        save = sys.stdout
        try:
            sys.stdout = OutputWindow(self.flist)
            self.grep_it(prog, path)
        finally:
            sys.stdout = save

    def grep_it(self, prog, path):
        """Search for prog within the lines of the files in path.

        For the each file in the path directory, open the file and
        search each line for the matching pattern.  If the pattern is
        found,  write the file and line information to stdout (which
        is an OutputWindow).

        Args:
            prog: The compiled, cooked search pattern.
            path: String containing the search path.
        """
        folder, filepat = os.path.split(path)
        if not folder:
            folder = os.curdir
        filelist = sorted(findfiles(folder, filepat, self.recvar.get()))
        self.close()
        pat = self.engine.getpat()
        print(f"Searching {pat!r} in {path} ...")
        hits = 0
        try:
            for fn in filelist:
                try:
                    with open(fn, errors='replace') as f:
                        for lineno, line in enumerate(f, 1):
                            if line[-1:] == '\n':
                                line = line[:-1]
                            if prog.search(line):
                                sys.stdout.write(f"{fn}: {lineno}: {line}\n")
                                hits += 1
                except OSError as msg:
                    print(msg)
            print(f"Hits found: {hits}\n(Hint: right-click to open locations.)"
                  if hits else "No hits.")
        except AttributeError:
            # Tk window has been closed, OutputWindow.text = None,
            # so in OW.write, OW.text.insert fails.
            pass


def _grep_dialog(parent):  # htest #
    from tkinter import Toplevel, Text, SEL, END
    from tkinter.ttk import Frame, Button
    from idlelib.pyshell import PyShellFileList

    top = Toplevel(parent)
    top.title("Test GrepDialog")
    x, y = map(int, parent.geometry().split('+')[1:])
    top.geometry(f"+{x}+{y + 175}")

    flist = PyShellFileList(top)
    frame = Frame(top)
    frame.pack()
    text = Text(frame, height=5)
    text.pack()

    def show_grep_dialog():
        text.tag_add(SEL, "1.0", END)
        grep(text, flist=flist)
        text.tag_remove(SEL, "1.0", END)

    button = Button(frame, text="Show GrepDialog", command=show_grep_dialog)
    button.pack()

if __name__ == "__main__":
    from unittest import main
    main('idlelib.idle_test.test_grep', verbosity=2, exit=False)

    from idlelib.idle_test.htest import run
    run(_grep_dialog)

SILENT KILLER Tool