def status(publish_path): u''' 检查发布库的编译状态 ''' publish_path, root_path = StaticPackage.get_roots(publish_path) if not publish_path: ui.error(u'不是发布库') return 1 package = StaticPackage(root_path, publish_path) files = package.get_publish_files() for filename in files: filetype = os.path.splitext(filename)[1] source, mode = package.parse(filename) try: rfiles = package.get_relation_files(source, all = True) except PackageNotFoundException, e: ui.error(u'%s package not found' % e.url) else: modified, not_exists = package.listener.check(filename, rfiles) if len(modified) or len(not_exists): for modified_file in modified: ui.msg('M ' + modified_file) for not_exists_file in not_exists: ui.msg('! ' + not_exists_file)
def link(path, link_path, force = False): u''' 将发布库与源库进行映射 如果库设置了url,则同时使用.package文件进行连接,需要工作区支持,如果没有url,则只进行本地连接。''' publish_path, root_path = StaticPackage.get_roots(path) if not publish_path and not root_path and link_path: publish_path, root_path = StaticPackage.get_roots(link_path) path, link_path = link_path, path if not publish_path: publish_path = os.path.realpath(link_path) else: root_path = os.path.realpath(link_path) if not root_path: ui.error('package not found') package = StaticPackage(root_path, publish_path = publish_path) if not os.path.exists(publish_path): if force: os.makedirs(publish_path) else: ui.msg(u'%s path not exists, run opm link path -f to create it.' % publish_path) return 1 package.link() ui.msg(u'linked publish %s to %s' % (publish_path, root_path))
def workspace(root_path): u''' 源库所在工作区 ''' if StaticPackage.get_root(root_path): ui.msg(Workspace.get_workspace(root_path)) else: ui.msg(u'不是一个源库') return 1
def init(root_path, publish_path = None, force = False): u''' 初始化一个新的库 初始化一个新的库,建立template-config.xml配置文件及常用的目录,如果指定了 -p 参数,还可以自动建立与发布目录的连接''' # 确保不要init了一个工作区 if Workspace.get_workspace(root_path) == root_path: ui.error(u'工作区不能被初始化') return 1 # 确保不要init了一个publish库 if StaticPackage.get_publish(root_path): ui.error(u'发布目录不能被初始化') return 1 ui.msg(u'初始化%s' % root_path) try: StaticPackage.init(root_path) ui.msg(u'创建配置文件') except PackageExistsException: ui.error(u'已经存在') return 1 pathnames = ['test', 'doc', 'src', 'lib', 'res'] for name in pathnames: path = os.path.join(root_path, name) if not os.path.exists(path): os.makedirs(path) ui.msg(u'生成默认目录 %s' % name) workspace_path = Workspace.get_workspace(root_path) if not workspace_path: ui.msg(u'没有工作区,请参照 opm help load') else: workspace = Workspace(workspace_path) if not workspace.has_package(root_path): workspace.add_package(root_path) ui.msg(u'加入本地工作区') else: ui.msg(u'本地工作区中已存在') ui.msg(u'成功!') if publish_path: link(root_path, publish_path, force = force)
def compile(filename, package = None, force = False, no_build_files = False): u'编译一个css/js文件' filename = os.path.realpath(filename) if not package: publish_path, root_path = StaticPackage.get_roots(filename) if not root_path: ui.error(u'没有找到源文件') return 1 else: package = StaticPackage(root_path, publish_path) try: modified, not_exists = package.compile(filename, force = force) except IOError, e: ui.error('%s file not found' % e.filename) return 1
def incs(filename, all = False, reverse = False): u''' 某文件所有依赖的文件 ''' filename = os.path.realpath(filename) root_path = StaticPackage.get_root(filename) package = StaticPackage(root_path) filetype = os.path.splitext(filename)[1] if reverse: if filetype == '.css': ui.error(u'Not support yet, sorry.') return 1 else: files = package.get_included(filename, all = all) else: files = package.get_relation_files(filename, all = all) for file in files: ui.msg(file)
def libs(root_path, show_url = False, all = False, reverse = False): u''' 库的相关依赖库 ''' root_path = StaticPackage.get_root(root_path) if not root_path: ui.error(u'不是源库') return 1 package = StaticPackage(root_path) # 这个库没有设置url,不可能被别的库依赖 if not package.url: ui.error(u'no url') return 1 # 显示依赖自己的 if reverse: try: libs = package.get_reverse_libs(all = all) except PackageNotFoundException, e: ui.error(u'%s package not found' % e.url) return 1
def publish(path, publish_path = None, force = False, rebuild = False): u'''将整个发布库进行编译''' do_link = False # 指定了第二个参数,则path一定是一个源库,第二个参数则是发布库,并自动进行link if publish_path: root_path = StaticPackage.get_root(path) path = publish_path # 发布整个库 do_link = True # 没有指定第二个参数,则path一定是一个发布库 else: publish_path, root_path = StaticPackage.get_roots(path) if not publish_path: ui.msg(u'No publish path.') else: package = StaticPackage(root_path, publish_path = publish_path) if not package.publish_path: ui.msg(u'No publish path.') else: ui.msg(u'publish to %s' % (path,) + (' with rebuild' if rebuild else '')) if rebuild: # 遍历磁盘目录,慢 all_files = package.get_publish_files() else: # 只搜索合并索引,快 all_files = package.listener.get_files() for filename in all_files: compile(filename, package = package, force = force, no_build_files = True) buildfiles(package = package) if do_link: package.link()
def listen(environ, start_response): ''' 监听请求 ''' if environ['DOCUMENT_URI'].endswith('/net.test'): return print_request(environ, start_response) DEBUG = debug filename = os.path.realpath(environ['REQUEST_FILENAME']) url = environ['DOCUMENT_URI'] force = False # 是否强制重新编译 # 没有 referer 时强制重新编译 if not 'HTTP_REFERER' in environ.keys(): force = True try: publish_path, root_path = StaticPackage.get_roots(filename, workspace = workspace) except PackageNotFoundException, e: ui.error(u'%s package not found' % e.url)
def source(publish_path): u''' 映射的源库路径 ''' if StaticPackage.get_publish(publish_path): StaticPackage.get_root(publish_path) else: ui.error(u'不是一个发布库')
def root(root_path): u''' 源库的根路径 ''' ui.msg(StaticPackage.get_root(root_path))