#!/usr/bin/env python ''' This file is part of the PyPhantomJS project. Copyright (C) 2011 James Roe This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . ''' # automatically convert Qt types by using api 2 import sip for item in ('QDate', 'QDateTime', 'QString', 'QTextStream', 'QTime' 'QUrl', 'QVariant'): sip.setapi(item, 2) import os import sys from PyQt4.QtCore import qInstallMsgHandler from PyQt4.QtGui import QApplication, QIcon from plugincontroller import do_action # load plugins if running script directly if __name__ == '__main__': from plugincontroller import load_plugins load_plugins() import resources from __init__ import __version__ from config import Config from phantom import Phantom from utils import argParser, MessageHandler # make keyboard interrupt quit program import signal signal.signal(signal.SIGINT, signal.SIG_DFL) # output unicode safe text from utils import SafeStreamFilter sys.stdout = SafeStreamFilter(sys.stdout) sys.stderr = SafeStreamFilter(sys.stderr) def debug(debug_type): def excepthook(type_, value, tb): import traceback # print the exception... traceback.print_exception(type_, value, tb) print # ...then start the debugger in post-mortem mode pdb.pm() # we are NOT in interactive mode if not hasattr(sys, 'ps1') or sys.stderr.target.isatty(): import pdb from PyQt4.QtCore import pyqtRemoveInputHook pyqtRemoveInputHook() if debug_type == 'exception': sys.excepthook = excepthook elif debug_type == 'program': pdb.set_trace() def parseArgs(app, args): # Handle all command-line options p = argParser() arg_data = p.parse_known_args(args) args = arg_data[0] args.script_args = arg_data[1] # register an alternative Message Handler messageHandler = MessageHandler(args.verbose) qInstallMsgHandler(messageHandler.process) file_check = (args.cookies_file, args.config) for file_ in file_check: if file_ is not None and not os.path.exists(file_): sys.exit("No such file or directory: '%s'" % file_) if args.config: config = Config(app, args.config) # apply settings for setting in config.settings: setattr(args, config.settings[setting]['mapping'], config.property(setting)) split_check = ( (args.proxy, 'proxy'), ) for arg, name in split_check: if arg: item = arg.split(':') if len(item) < 2 or not len(item[1]): p.print_help() sys.exit(1) setattr(args, name, item) do_action('ParseArgs', args) if args.debug: debug(args.debug) # verbose flag got changed on us, so we reload the flag if messageHandler.verbose != args.verbose: messageHandler.verbose = args.verbose if args.script is None: p.print_help() sys.exit(1) if not os.path.exists(args.script): sys.exit("No such file or directory: '%s'" % args.script) return args def main(): app = QApplication(sys.argv) app.setWindowIcon(QIcon(':/resources/pyphantomjs-icon.png')) app.setApplicationName('PyPhantomJS') app.setOrganizationName('Umaclan Development') app.setOrganizationDomain('www.umaclan.com') app.setApplicationVersion(__version__) args = parseArgs(app, sys.argv[1:]) phantom = Phantom(app, args) do_action('Main') if phantom.execute(): app.exec_() return phantom.returnValue() do_action('PyPhantomJS') if __name__ == '__main__': sys.exit(main())