代码拉取完成,页面将自动刷新
#! /usr/bin/env python2.7
# -*- coding: utf-8 -*-
## \page init.py Initialization Script
# Script to set configurations and launch Debreate
#
# Checks if the config file exists in ~/.config/debreate. If
# not, a new file will be created (~/.config/debreate/config).
# If the config file already exists but is corrupted, it will
# reset it to its default settings.
import os, sys
from command_line import GetParsedPath
from command_line import ParseArguments
from command_line import parsed_commands
from command_line import parsed_args_s
from command_line import parsed_args_v
from globals.paths import PATH_app
from globals.paths import ConcatPaths
## Module name displayed for Logger output.
# Should be set to 'init' or actual name of executable script.
script_name = os.path.basename(__file__)
# *** Command line arguments
ParseArguments(sys.argv[1:])#sys.argv以空格作为分隔符,成列表参数
# GetParsedPath must be called after ParseArguments
parsed_path = GetParsedPath()#返回的是输入的路径,即要打开的文件路径
# Compiles python source into bytecode把python文件编译成字节文件
if u'compile' in parsed_commands:
import compileall, errno
compile_dirs = (
u'dbr',
u'globals',
u'wizbin',
)
if not os.access(PATH_app, os.W_OK):#当前路径是否可写
print(u'ERROR: No write privileges for {}'.format(PATH_app))
sys.exit(errno.EACCES)
print(u'Compiling Python modules (.py) to bytecode (.pyc) ...\n')
print(u'Compiling root directory: {}'.format(PATH_app))
for F in os.listdir(PATH_app):
if os.path.isfile(F) and F.endswith(u'.py') and F != u'init.py':
print(u'编译文件:{}'.format(F))
F = ConcatPaths((PATH_app, F))
compileall.compile_file(F)#compileall是自带模块,用来编译py文件
print
for D in os.listdir(PATH_app):
D = ConcatPaths((PATH_app, D))
if os.path.isdir(D) and os.path.basename(D) in compile_dirs:
print(u'编译文件夹: {}'.format(D))
compileall.compile_dir(D)
print
sys.exit(0)
if u'clean' in parsed_commands:
import errno
if not os.access(PATH_app, os.W_OK):
print(u'ERROR: No write privileges for {}'.format(PATH_app))
sys.exit(errno.EACCES)
print(u'Cleaning Python bytecode (.pyc) ...\n')
for ROOT, DIRS, FILES in os.walk(PATH_app):
for F in FILES:
F = ConcatPaths((ROOT, F))
if os.path.isfile(F) and F.endswith(u'.pyc'):
print(u'Removing file: {}'.format(F))
os.remove(F)
sys.exit(0)
# Modules to define required version of wx
import wxversion
if u'legacy' in parsed_commands:
try:
wxversion.select([u'2.8'])
print(u'选定wx版本2.8成功')
except wxversion.VersionError:
print(u'Warning: Could not find legacy version of wx on system. Reverting to default settings.')
# Ensure that "legacy" version isn't already in use确保legacy版本已经不再使用了
if not wxversion._selected:
wxversion.select([u'3.0', u'2.8'])
import commands, gettext, wx
# Python & wx.Python encoding to UTF-8
if (sys.getdefaultencoding() != u'utf-8'):
reload(sys)
# FIXME: Recommended not to use
sys.setdefaultencoding(u'utf-8')
wx.SetDefaultPyEncoding('UTF-8')
from dbr.app import DebreateApp
# Initialize app before importing local modules导入本地模块前初始化app
debreate_app = DebreateApp()
from dbr.config import ConfCode
from dbr.config import GetAllConfigKeys
from dbr.config import GetDefaultConfigValue
from dbr.language import GetLocaleDir
from dbr.language import GT
from dbr.language import SetLocaleDir
from dbr.language import TRANSLATION_DOMAIN
from dbr.log import Logger
from dbr.workingdir import ChangeWorkingDirectory
from globals.application import VERSION_string
from globals.constants import INSTALLED
from globals.constants import PREFIX
from globals.strings import GS
from globals.system import PY_VER_STRING
from globals.system import WX_VER_STRING
from main import MainWindow
from startup.firstrun import LaunchFirstRun
from startup.startup import SetAppInitialized
# FIXME: How to check if text domain is set correctly?
if INSTALLED:#有安装文件,就设置本地目录为share/locale目录,没有的话,就是app/locale
SetLocaleDir(ConcatPaths((PREFIX, u'share/locale')))#prefi安装后就是设置好的,没有安装就是app目录,
gettext.install(TRANSLATION_DOMAIN, GetLocaleDir(), unicode=True)
#设置gettext的翻译域名、本地文件夹和是否支持Unicode编码,gettext是用来国际化翻译的工具模块
if u'.py' in script_name:#script_name=u'init.py'
script_name = script_name.split(u'.py')[0]#变成了init
exit_now = 0
if u'version' in parsed_args_s:#如果参数是v输出版本名
print(VERSION_string)
sys.exit(0)
if u'help' in parsed_args_s:
if INSTALLED:
help_output = commands.getstatusoutput(u'man debreate')
else:
help_output = commands.getstatusoutput(u'man --manpath="{}/man" debreate'.format(PATH_app))
#man文件夹下确实是用来使用man命令输出帮助的文件
if help_output[0]:
print(u'ERROR: Could not locate manpage')
sys.exit(help_output[0])
help_output = GS(help_output[1])#help_output[0]值是e,也不知道什么意思
print(u'\n'.join(help_output.split(u'\n')[2:-1]))
sys.exit(0)
if u'log-level' in parsed_args_v:
Logger.SetLogLevel(parsed_args_v[u'log-level'])
Logger.Info(script_name, u'Python version: {}'.format(PY_VER_STRING))
Logger.Info(script_name, u'wx.Python version: {}'.format(WX_VER_STRING))
Logger.Info(script_name, u'DebreateForUos version: {}'.format(VERSION_string))
Logger.Info(script_name, u'Logging level: {}'.format(Logger.GetLogLevel()))
# Check for & parse existing configuration
conf_values = GetAllConfigKeys()#从home/.config/debreate/config中读取配置
if not conf_values:
Logger.Debug(script_name, u'Launching First Run dialog ...')
first_run = LaunchFirstRun(debreate_app)
if not first_run == ConfCode.SUCCESS:
sys.exit(first_run)
conf_values = GetAllConfigKeys()
# Check that all configuration values are okay
for V in conf_values:
key = V
value = conf_values[V]
# ???: Redundant???该键对应值错误,从配置文件中读取
if value == None:
value = GetDefaultConfigValue(key)
Logger.Debug(script_name, GT(u'Configuration key "{}" = "{}", type: {}'.format(key, GS(value), type(value))))
# FIXME: ConfCode values are integers & could cause problems with config values
if conf_values[V] in (ConfCode.FILE_NOT_FOUND, ConfCode.KEY_NOT_DEFINED, ConfCode.KEY_NO_EXIST,):
first_run = LaunchFirstRun(debreate_app)
if not first_run == ConfCode.SUCCESS:
sys.exit(first_run)
break
Debreate = MainWindow(conf_values[u'position'], conf_values[u'size'])
debreate_app.SetMainWindow(Debreate)
Debreate.InitWizard()
if conf_values[u'maximize']:
Debreate.Maximize()
elif conf_values[u'center']:
from system.display import CenterOnPrimaryDisplay
# NOTE: May be a few pixels off
CenterOnPrimaryDisplay(Debreate)
working_dir = conf_values[u'workingdir']
if parsed_path:
project_file = parsed_path
Logger.Debug(script_name, GT(u'Opening project from argument: {}').format(project_file))
if Debreate.OpenProject(project_file):
working_dir = os.path.dirname(project_file)
# Set working directory
ChangeWorkingDirectory(working_dir)
Debreate.Show(True)
# Wait for window to be constructed (prevents being marked as dirty project after initialization)
wx.Yield()
# Set initializaton state to 'True'
SetAppInitialized()
debreate_app.MainLoop()
Logger.OnClose()
sys.exit(0)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。