3 � fҐ � @ s� d Z dZddlmZmZmZ ddlmZ ddlZddl Z ddl Zddlm Z ddlmZ ddlmZ ddlZddlZddlZd d ddd ddddddddddgZdadadd� Zdd� Zdd� Zdd � Zeadade jddd!fd"d�Zd6d#d�Z d7d$d �Z!d%d� Z"d&d'� Z#d(d� Z$G d)d � d �Z%G d*d � d �Z&e jfd+d�Z'd8d,d�Z(e jfd-d�Z)d.d� Z*d/d� Z+d0d� Z,d1d� Z-d9d2d�Z.d3d4� Z/e0d5k�r�e'� dS ):z�Support module for CGI (Common Gateway Interface) scripts. This module defines a number of utilities for use by CGI scripts written in Python. z2.6� )�StringIO�BytesIO� TextIOWrapper)�MappingN)� FeedParser)�Message)�warn�MiniFieldStorage�FieldStorage�parse�parse_qs� parse_qsl�parse_multipart�parse_header�test�print_exception� print_environ� print_form�print_directory�print_arguments�print_environ_usage�escape� c G sH t r.t r.ytt d�aW n tk r, Y nX ts8tantat| � dS )a� Write a log message, if there is a log file. Even though this function is called initlog(), you should always use log(); log is a variable that is set either to initlog (initially), to dolog (once the log file has been opened), or to nolog (when logging is disabled). The first argument is a format string; the remaining arguments (if any) are arguments to the % operator, so e.g. log("%s: %s", "a", "b") will write "a: b" to the log file, followed by a newline. If the global logfp is not None, it should be a file object to which log data is written. If the global logfp is None, the global logfile may be a string giving a filename to open, in append mode. This file should be world writable!!! If the file can't be opened, logging is silently disabled (since there is no safe place where we could send an error message). �aN)�logfile�logfp�open�OSError�nolog�log�dolog)�allargs� r"