国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

Android源代碼倉庫及其管理工具Repo分析詳解

 更新時間:2018年01月02日 10:43:14   作者:羅升陽  
本篇文章主要介紹了Android源代碼倉庫及其管理工具Repo分析詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

軟件工程由于需要不斷迭代開發(fā),因此要對源代碼進行版本管理。Android源代碼工程(AOSP)也不例外,它采用Git來進行版本管理。AOSP作為一個大型開放源代碼工程,由許許多多子項目組成,因此不能簡單地用Git進行管理,它在Git的基礎(chǔ)上建立了一套自己的代碼倉庫,并且使用工具Repo進行管理。工欲善其事,必先利其器。本文就對AOSP代碼倉庫及其管理工具repo進行分析,以便提高我們?nèi)粘i_發(fā)效率。

《Android系統(tǒng)源代碼情景分析》——點擊下載

現(xiàn)代的代碼版本管理工具,SVN和Git是最流行的。SVN是一種集中式的代碼管理工具,需要有一個中心服務(wù)器,而Git是一種分布式的代碼管理工具。不需要一個中心服務(wù)器。不需要中心服務(wù)器意味著在沒有網(wǎng)絡(luò)的情況下,Git也能進行版本管理。因此,單從這一點出發(fā),Git就比SVN要方便很多。當然,Git和SVN相比,還有許多不同的理念設(shè)計,但是總的來說,Git越來越受到大家的青睞,尤其是在開源社區(qū)。君不見,Linux是采用Git進行版本管理,而越來越火的GitHub,提供也是Git代碼管理服務(wù)。本文不打算分析Git與SVN的區(qū)別,以及Git的使用方法,不過強烈建議大家先去了解Git,然后再看下面的內(nèi)容。這里推薦一本Git書籍《Pro Git》,它是GitHub的員工Scott Chacon撰寫的,對Git的使用及其原理都介紹得非常詳細和清晰。

前面提到,AOSP是由許許多項目組成的,例如,在Android 4.2中,就包含了329個項目,每一個項目都是一個獨立的Git倉庫。這意味著,如果我們要創(chuàng)建一個AOSP分支來做feature開發(fā),那么就需要到每一個子項目去創(chuàng)建對應(yīng)的分支。這顯然不能手動地到每一個子項目里面去創(chuàng)建分支,必須要采用一種自動化的方式來處理。這些自動化處理工作就是由Repo工具來完成的。當然,Repo工具所負責的自動化工作不只是創(chuàng)建分支那么簡單,查看分支狀態(tài)、提交代碼、更新代碼等基礎(chǔ)Git操作它都可以完成。

Repo工具實際上是由一系列的Python腳本組成的,這些Python腳本通過調(diào)用Git命令來完成自己的功能。比較有意思的是,組成Repo工具的那些Python腳本本身也是一個Git倉庫。這個Git倉庫在AOSP里面就稱為Repo倉庫。我們每次執(zhí)行Repo命令的時候,Repo倉庫都會對自己進行一次更新。

上面我們討論的是Repo倉庫,但是實際上我們執(zhí)行Repo命令想操作的是AOSP。這就要求Repo命令要知道AOSP都包含有哪些子項目,并且要知道這些子項目的名稱、倉庫地址是什么。換句話說,就是Repo命令要知道AOSP所有子項目的Git倉庫元信息。我們知道,AOSP也是不斷地迭代法變化的,例如,它的每一個版本所包含的子項目可能都是不一樣的。這意味著需要通過另外一個Git倉庫來管理AOSP所有的子項目的Git倉庫元信息。這個Git倉庫在AOSP里面就稱為Manifest倉庫。

到目前為止,我們提到了三種類型的Git倉庫,分別是Repo倉庫、Manifest倉庫和AOSP子項目倉庫。Repo倉庫通過Manifest倉庫可以獲得所有AOSP子項目倉庫的元信息。有了這些元信息之后,我們就可以通過Repo倉庫里面的Python腳本來操作AOSP的子項目。那么,Repo倉庫和Manifest倉庫又是怎么來的呢?答案是通過一個獨立的Repo腳本來獲取,這個Repo腳本位于AOSP的一個官方網(wǎng)站上,我們可以通過HTTP協(xié)議來下載。

現(xiàn)在,我們就通過一個圖來來勾勒一下整個AOSP的Picture,它由Repo腳本、Repo倉庫、Manifest倉庫和AOSP子項目倉庫組成,如圖1所示:

圖1 Repo腳本、Repo倉庫、Manifest倉庫和AOSP子項目倉庫

接下來我們就看看上述腳本和倉庫是怎么來的。

1. Repo腳本

官方網(wǎng)站可以知道,Repo腳本可以通過以下命令來獲?。?br />

$ curl http://commondatastorage.googleapis.com/git-repo-downloads/repo > ~/bin/repo 
$ chmod a+x ~/bin/repo 

也就是可以通過curl工具從http://commondatastorage.googleapis.com/git-repo-downloads/repo獲得,并且保存在文件~/bin/repo中。由于~/bin/repo是一個python腳本,我們通過chmod命令賦予它可執(zhí)行的權(quán)限,以便接下來我們可以通過repo命令來運行它。

2. Repo倉庫

我們下載好Repo腳本之后,要選通過以下命令來安裝一個Repo倉庫:

$ repo init -u https://android.googlesource.com/platform/manifest 

這個命令實際上是包含了兩個操作:安裝Repo倉庫和Manifest倉庫。其中,Manifest倉庫的地址由-u后來帶的參數(shù)給出。這一小節(jié)我們先分析Repo倉庫的安裝過程,在接下來的第3小節(jié)中,再分析Manifest倉庫的安裝過程。

我們看看Repo腳本是如何執(zhí)行repo init命令的:

def main(orig_args): 
 repo_main, rel_repo_dir = _FindRepo() 
 cmd, opt, args = _ParseArguments(orig_args)  
 wrapper_path = os.path.abspath(__file__) 
 my_main, my_git = _RunSelf(wrapper_path) 
 
 if not repo_main: 
  if opt.help: 
   _Usage() 
  if cmd == 'help': 
   _Help(args) 
  if not cmd: 
   _NotInstalled() 
  if cmd == 'init': 
   if my_git: 
    _SetDefaultsTo(my_git) 
   try: 
    _Init(args) 
   except CloneFailure: 
    ...... 
    sys.exit(1) 
   repo_main, rel_repo_dir = _FindRepo() 
  else: 
   _NoCommands(cmd) 
  if my_main: 
  repo_main = my_main 
  ver_str = '.'.join(map(str, VERSION)) 
 me = [repo_main, 
    '--repo-dir=%s' % rel_repo_dir, 
    '--wrapper-version=%s' % ver_str, 
    '--wrapper-path=%s' % wrapper_path, 
    '--'] 
 me.extend(orig_args) 
 me.extend(extra_args) 
 try: 
  os.execv(repo_main, me) 
 except OSError as e: 
  ...... 
  sys.exit(148)  
if __name__ == '__main__': 
 main(sys.argv[1:]) 

_FindRepo在從當前目錄開始往上遍歷直到根據(jù)目錄。如果中間某一個目錄下面存在一個.repo/repo目錄,并且該.repo/repo存在一個main.py文件,那么就會認為當前是AOSP中執(zhí)行Repo腳本,這時候它就會返回文件main.py的絕對路徑和當前查找目錄下的.repo子目錄的絕對路徑給調(diào)用者。在上述情況下,實際上是說明Repo倉庫已經(jīng)安裝過了。

_FindRepo的實現(xiàn)如下所示:

repodir = '.repo'   # name of repo's private directory 
S_repo = 'repo'    # special repo repository 
REPO_MAIN = S_repo + '/main.py' # main script  
def _FindRepo(): 
 """Look for a repo installation, starting at the current directory. 
 """ 
 curdir = os.getcwd() 
 repo = None  
 olddir = None 
 while curdir != '/' \ 
  and curdir != olddir \ 
  and not repo: 
  repo = os.path.join(curdir, repodir, REPO_MAIN) 
  if not os.path.isfile(repo): 
   repo = None 
   olddir = curdir 
   curdir = os.path.dirname(curdir) 
 return (repo, os.path.join(curdir, repodir)) 

 _ParseArguments無非是對Repo的參數(shù)進行解析,得到要執(zhí)行的命令及其對應(yīng)的參數(shù)。例如,當我們調(diào)用“repo init -u https://android.googlesource.com/platform/manifest”的時候,就表示要執(zhí)行的命令是init,這個命令后面跟的參數(shù)是“-u https://android.googlesource.com/platform/manifest”。同時,如果我們調(diào)用“repo sync”,就表示要執(zhí)行的命令是sync,這個命令沒有參數(shù)。

_RunSelf檢查Repo腳本所在目錄是否存在一個Repo倉庫,如果存在的話,就從該倉庫克隆一個新的倉庫到執(zhí)行Repo腳本的目錄來。實際上就是從本地克隆一個新的Repo倉庫。如果不存在的話,那么就需要從遠程地址克隆一個Repo倉庫到本地來。這個遠程地址是Hard Code在Repo腳本里面。

_RunSelf的實現(xiàn)如下所示:

def _RunSelf(wrapper_path): 
 my_dir = os.path.dirname(wrapper_path) 
 my_main = os.path.join(my_dir, 'main.py') 
 my_git = os.path.join(my_dir, '.git') 
 
 if os.path.isfile(my_main) and os.path.isdir(my_git): 
  for name in ['git_config.py', 
         'project.py', 
         'subcmds']: 
   if not os.path.exists(os.path.join(my_dir, name)): 
    return None, None 
  return my_main, my_git 
 return None, None 

從這里我們就可以看出,如果Repo腳本所在的目錄存在一個Repo倉庫,那么要滿足以下條件:

(1). 存在一個.git目錄;
(2). 存在一個main.py文件;
(3). 存在一個git_config.py文件;
(4). 存在一個project.py文件;
(5). 存在一個subcmds目錄。

上述目錄和文件實際上都是一個標準的Repo倉庫所具有的。

我們再回到main函數(shù)中。如果調(diào)用_FindRepo得到的repo_main的值等于空,那么就說明當前目錄還沒有安裝Repo倉庫,這時候Repo后面所跟的參數(shù)只能是help或者init,否則的話,就會顯示錯誤信息。如果Repo后面跟的參數(shù)是help,就打印出Repo腳本的幫助文檔。

我們關(guān)注Repo后面跟的參數(shù)是init的情況。這時候看一下調(diào)用_RunSelf的返回值my_git是否不等于空。如果不等于空的話,那么就說明Repo腳本所在目錄存一個Repo倉庫,這時候就調(diào)用_SetDefaultsTo設(shè)置等一會要克隆的Repo倉庫源。

_SetDefaultsTo的實現(xiàn)如下所示:

GIT = 'git'  
REPO_URL = 'https://gerrit.googlesource.com/git-repo' 
REPO_REV = 'stable'  
def _SetDefaultsTo(gitdir): 
 global REPO_URL 
 global REPO_REV  
 REPO_URL = gitdir 
 proc = subprocess.Popen([GIT, 
              '--git-dir=%s' % gitdir, 
              'symbolic-ref', 
              'HEAD'], 
             stdout = subprocess.PIPE, 
             stderr = subprocess.PIPE) 
 REPO_REV = proc.stdout.read().strip() 
 proc.stdout.close()  
 proc.stderr.read() 
 proc.stderr.close()  
 if proc.wait() != 0: 
  _print('fatal: %s has no current branch' % gitdir, file=sys.stderr) 
  sys.exit(1) 

如果Repo腳本所在目錄不存在一個Repo倉庫,那么默認就將https://gerrit.googlesource.com/git-repo設(shè)置為一會要克隆的Repo倉庫源,并且要克隆的分支是stable。否則的話,就以該Repo倉庫作為克隆源,并且以該Repo倉庫的當前分支作為要克隆的分支。

從前面的分析就可以知道,當我們執(zhí)行"repo init"命令的時候:

(1). 如果我們只是從網(wǎng)上下載了一個Repo腳本,那么在執(zhí)行Repo命令的時候,就會從遠程克隆一個Repo倉庫到當前執(zhí)行Repo腳本的目錄來。

(2). 如果我們從網(wǎng)上下載的是一個帶有Repo倉庫的Repo腳本,那么在執(zhí)行Repo命令的時候,就可以從本地克隆一個Repo倉庫到當前執(zhí)行Repo腳本的目錄來。

我們再繼續(xù)看main函數(shù)的實現(xiàn),它接下來調(diào)用_Init在當前執(zhí)行Repo腳本的目錄下安裝一個Repo倉庫:

def _Init(args): 
 """Installs repo by cloning it over the network. 
 """ 
 opt, args = init_optparse.parse_args(args) 
 ...... 
 
 url = opt.repo_url 
 if not url: 
  url = REPO_URL 
  extra_args.append('--repo-url=%s' % url) 
 
 branch = opt.repo_branch 
 if not branch: 
  branch = REPO_REV 
  extra_args.append('--repo-branch=%s' % branch) 
 
 ...... 
 
 if not os.path.isdir(repodir): 
  try: 
   os.mkdir(repodir) 
  except OSError as e: 
   ...... 
   sys.exit(1) 
 
 _CheckGitVersion() 
 try: 
  if NeedSetupGnuPG(): 
   can_verify = SetupGnuPG(opt.quiet) 
  else: 
   can_verify = True 
 
  dst = os.path.abspath(os.path.join(repodir, S_repo)) 
  _Clone(url, dst, opt.quiet) 
 
  if can_verify and not opt.no_repo_verify: 
   rev = _Verify(dst, branch, opt.quiet) 
  else: 
   rev = 'refs/remotes/origin/%s^0' % branch 
 
  _Checkout(dst, branch, rev, opt.quiet) 
 except CloneFailure: 
  ...... 

如果我們在執(zhí)行Repo腳本的時候,沒有通過--repo-url和--repo-branch來指定Repo倉庫的源地址和分支,那么就使用由REPO_URL和REPO_REV所指定的源地址和分支。從前面的分析可以知道,REPO_URL和REPO_REV要么指向遠程地址https://gerrit.googlesource.com/git-repo和分支stable,要么指向Repo腳本所在目錄的Repo倉庫和該倉庫的當前分支。

_Init函數(shù)繼續(xù)檢查當前執(zhí)行Repo腳本的目錄是否存在一個.repo目錄。如果不存在的話,那么就新創(chuàng)建一個。接著是否需要驗證等一會克隆回來的Repo倉庫的GPG。如果需要驗證的話,那么就會在調(diào)用_Clone函數(shù)來克隆好Repo倉庫之后,調(diào)用_Verify函數(shù)來驗證該Repo倉庫的GPG。

最關(guān)鍵的地方就在于函數(shù)_Clone函數(shù)和_Checkout函數(shù)的調(diào)用,前者用來從url指定的地方克隆一個倉庫到dst指定的地方來,實際上就是克隆到當前目錄下的./repo/repo目錄來,后者在克隆回來的倉庫中將branch分支checkout出來。

函數(shù)_Clone的實現(xiàn)如下所示:

def _Clone(url, local, quiet): 
 """Clones a git repository to a new subdirectory of repodir 
 """ 
 try: 
  os.mkdir(local) 
 except OSError as e: 
  _print('fatal: cannot make %s directory: %s' % (local, e.strerror), 
      file=sys.stderr) 
  raise CloneFailure()  
 cmd = [GIT, 'init', '--quiet'] 
 try: 
  proc = subprocess.Popen(cmd, cwd = local) 
 except OSError as e: 
 ......  
 ......  
 _InitHttp() 
 _SetConfig(local, 'remote.origin.url', url) 
 _SetConfig(local, 'remote.origin.fetch', 
          '+refs/heads/*:refs/remotes/origin/*') 
 if _DownloadBundle(url, local, quiet): 
  _ImportBundle(local) 
 else: 
  _Fetch(url, local, 'origin', quiet) 

這個函數(shù)首先是調(diào)用"git init"在當前目錄下的.repo/repo子目錄初始化一個Git倉庫,接著再調(diào)用_SetConfig函來設(shè)置該Git倉庫的url信息等。再接著調(diào)用_DownloadBundle來檢查指定的url是否存在一個clone.bundle文件。如果存在這個clone.bundle文件的話,就以它作為Repo倉庫的克隆源。

函數(shù)_DownloadBundle的實現(xiàn)如下所示:

def _DownloadBundle(url, local, quiet): 
 if not url.endswith('/'): 
  url += '/' 
 url += 'clone.bundle' 
 ......  
 if not url.startswith('http:') and not url.startswith('https:'): 
  return False  
 dest = open(os.path.join(local, '.git', 'clone.bundle'), 'w+b') 
 try: 
  try: 
   r = urllib.request.urlopen(url) 
  except urllib.error.HTTPError as e: 
   if e.code in [403, 404]: 
    return False 
   ...... 
   raise CloneFailure() 
  except urllib.error.URLError as e: 
   ...... 
   raise CloneFailure() 
  try: 
   if not quiet: 
    _print('Get %s' % url, file=sys.stderr) 
   while True: 
    buf = r.read(8192) 
    if buf == '': 
     return True 
    dest.write(buf) 
  finally: 
   r.close() 
 finally: 
  dest.close() 

Bundle文件是Git提供的一種機制,用來解決不能正常通過git、ssh和http等網(wǎng)絡(luò)協(xié)議從遠程地址克隆Git倉庫的問題。簡單來說,就是我們可以用“git bundle”命令來在一個Git倉庫創(chuàng)建一個Bundle文件,這個Bundle文件就會包含Git倉庫的提交歷史。把這個Bundle文件通過其它方式拷貝到另一臺機器上,就可以將它作為一個本地Git倉庫來使用,而不用去訪問遠程網(wǎng)絡(luò)。

回到函數(shù)_Clone中,如果存在對應(yīng)的clone.bundle文件,并且能成功下載到該clone.bundle,接下來就調(diào)用函數(shù)_ImportBundle將它作為源倉庫克隆為新的Repo倉庫。函數(shù)_ImportBundle的實現(xiàn)如下所示:

def _ImportBundle(local): 
 path = os.path.join(local, '.git', 'clone.bundle') 
 try: 
  _Fetch(local, local, path, True) 
 finally: 
  os.remove(path) 

 結(jié)合_Clone函數(shù)和_ImportBundle函數(shù)就可以看出,從clone.bundle文件克隆Repo倉庫和從遠程url克隆Repo倉庫都是通過函數(shù)_Fetch來實現(xiàn)的。區(qū)別就在于調(diào)用函數(shù)_Fetch時指定的第三個參數(shù),前者是已經(jīng)下載到本地的一個clone.bundle文件路徑,后者是origin(表示遠程倉庫名稱)。

函數(shù)_Fetch的實現(xiàn)如下所示:

def _Fetch(url, local, src, quiet): 
 if not quiet: 
  _print('Get %s' % url, file=sys.stderr)  
 cmd = [GIT, 'fetch'] 
 if quiet: 
  cmd.append('--quiet') 
  err = subprocess.PIPE 
 else: 
  err = None 
 cmd.append(src) 
 cmd.append('+refs/heads/*:refs/remotes/origin/*') 
 cmd.append('refs/tags/*:refs/tags/*') 
 
 proc = subprocess.Popen(cmd, cwd = local, stderr = err) 
 if err: 
  proc.stderr.read() 
  proc.stderr.close() 
 if proc.wait() != 0: 
  raise CloneFailure() 

函數(shù)_Fetch實際上就是通過“git fetch”從指定的倉庫源克隆一個新的Repo倉庫到當前目錄下的.repo/repo子目錄來。

注意,以上只是克隆好了一個Repo倉庫,接下來還需要從這個Repo倉庫checkout出一個分支來,才能正常工作。從Repo倉庫checkout出一個分支是通過調(diào)用函數(shù)_Checkout來實現(xiàn)的:

def _Checkout(cwd, branch, rev, quiet): 
 """Checkout an upstream branch into the repository and track it. 
 """ 
 cmd = [GIT, 'update-ref', 'refs/heads/default', rev] 
 if subprocess.Popen(cmd, cwd = cwd).wait() != 0: 
  raise CloneFailure() 
 
 _SetConfig(cwd, 'branch.default.remote', 'origin') 
 _SetConfig(cwd, 'branch.default.merge', 'refs/heads/%s' % branch) 
 
 cmd = [GIT, 'symbolic-ref', 'HEAD', 'refs/heads/default'] 
 if subprocess.Popen(cmd, cwd = cwd).wait() != 0: 
  raise CloneFailure() 
 
 cmd = [GIT, 'read-tree', '--reset', '-u'] 
 if not quiet: 
  cmd.append('-v') 
 cmd.append('HEAD') 
 if subprocess.Popen(cmd, cwd = cwd).wait() != 0: 
  raise CloneFailure() 

要checkout出來的分支由參數(shù)branch指定。從前面的分析可以知道,如果當前執(zhí)行的Repo腳本所在目錄存在一個Repo倉庫,那么參數(shù)branch描述的就是該倉庫當前checkout出來的分支。否則的話,參數(shù)branch描述的就是從遠程倉庫克隆回來的“stable”分支。

需要注意的是,這里從倉庫checkout出分支不是使用“git checkout”命令來實現(xiàn)的,而是通過更底層的Git命令“git update-ref”來實現(xiàn)的。實際上,“git checkout”命令也是通過“git update-ref”命令來實現(xiàn)的,只不過它進行了更高層的封裝,更方便使用。如果我們?nèi)シ治鼋M成Repo倉庫的那些Python腳本命令,就會發(fā)現(xiàn)它們基本上都是通過底層的Git命令來完成Git功能的。

3. Manifest倉庫

我們接著再分析下面這個命令的執(zhí)行:

repo init -u https://android.googlesource.com/platform/manifest 

如前所述,這個命令安裝好Repo倉庫之后,就會調(diào)用該Repo倉庫下面的main.py腳本,對應(yīng)的文件為.repo/repo/main.py,它的入口函數(shù)的實現(xiàn)如下所示:

def _Main(argv): 
 result = 0 
 
 opt = optparse.OptionParser(usage="repo wrapperinfo -- ...") 
 opt.add_option("--repo-dir", dest="repodir", 
         help="path to .repo/") 
 ...... 
 
 repo = _Repo(opt.repodir) 
 try: 
  try: 
   init_ssh() 
   init_http() 
   result = repo._Run(argv) or 0 
  finally: 
   close_ssh() 
 except KeyboardInterrupt: 
  ...... 
  result = 1 
 except ManifestParseError as mpe: 
  ...... 
  result = 1 
 except RepoChangedException as rce: 
  # If repo changed, re-exec ourselves. 
  # 
  argv = list(sys.argv) 
  argv.extend(rce.extra_args) 
  try: 
   os.execv(__file__, argv) 
  except OSError as e: 
   ...... 
   result = 128 
 
 sys.exit(result) 
 
if __name__ == '__main__': 
 _Main(sys.argv[1:]) 

從前面的分析可以知道,通過參數(shù)--repo-dir傳進來的是AOSP根目錄下的.repo目錄,這是一個隱藏目錄,里面保存的是Repo倉庫、Manifest倉庫,以及各個AOSP子項目倉庫。函數(shù)_Main首先是調(diào)用init_ssh和init_http來初始化網(wǎng)絡(luò)環(huán)境,接著再調(diào)用前面創(chuàng)建的一個_Repo對象的成員函數(shù)_Run來解析要執(zhí)行的命令,并且執(zhí)行這個命令。

_Repo類的成員函數(shù)_Run的實現(xiàn)如下所示:

from subcmds import all_commands 
 class _Repo(object): 
 def __init__(self, repodir): 
  self.repodir = repodir 
  self.commands = all_commands 
  # add 'branch' as an alias for 'branches' 
  all_commands['branch'] = all_commands['branches'] 
  def _Run(self, argv): 
  result = 0 
  name = None 
  glob = [] 
 
  for i in range(len(argv)): 
   if not argv[i].startswith('-'): 
    name = argv[i] 
    if i > 0: 
     glob = argv[:i] 
    argv = argv[i + 1:] 
    break 
  if not name: 
   glob = argv 
   name = 'help' 
   argv = [] 
  gopts, _gargs = global_options.parse_args(glob)  
  ......  
  try: 
   cmd = self.commands[name] 
  except KeyError: 
   ...... 
   return 1  
  cmd.repodir = self.repodir 
  cmd.manifest = XmlManifest(cmd.repodir)  
  ......  
  try: 
   result = cmd.Execute(copts, cargs) 
  except DownloadError as e: 
   ...... 
   result = 1 
  except ManifestInvalidRevisionError as e: 
   ...... 
   result = 1 
  except NoManifestException as e: 
   ...... 
   result = 1 
  except NoSuchProjectError as e: 
   ...... 
   result = 1 
  finally: 
   ......  
  return result 

 Repo腳本能執(zhí)行的命令都放在目錄.repo/repo/subcmds中,該目錄每一個python文件都對應(yīng)一個Repo命令。例如,“repo init”表示要執(zhí)行命令腳本是.repo/repo/subcmds/init.py。

_Repo類的成員函數(shù)_Run首先是在repo后面所帶的參數(shù)中,不是以橫線“-”開始的第一個選項,該選項就代表要執(zhí)行的命令,該命令的名稱就保存在變量name中。接著根據(jù)變量name的值在_Repo類的成員變量commands中找到對應(yīng)的命令模塊cmd,并且指定該命令模塊cmd的成員變量repodir和manifest的值。命令模塊cmd的成員變量repodir描述的就是AOSP的.repo目錄,成員變量manifest指向的是一個XmlManifest對象,它描述的是AOSP的Repo倉庫和Manifest倉庫。

我們看看XmlManifest類的構(gòu)造函數(shù),它定義在文件.repo/repo/xml_manifest.py文件中:

class XmlManifest(object): 
 """manages the repo configuration file"""  
 def __init__(self, repodir): 
  self.repodir = os.path.abspath(repodir) 
  self.topdir = os.path.dirname(self.repodir) 
  self.manifestFile = os.path.join(self.repodir, MANIFEST_FILE_NAME) 
  ......  
  self.repoProject = MetaProject(self, 'repo', 
   gitdir  = os.path.join(repodir, 'repo/.git'), 
   worktree = os.path.join(repodir, 'repo'))  
  self.manifestProject = MetaProject(self, 'manifests', 
   gitdir  = os.path.join(repodir, 'manifests.git'), 
   worktree = os.path.join(repodir, 'manifests'))  
  ...... 

XmlManifest作了描述了AOSP的Repo目錄(repodir)、AOSP 根目錄(topdir)和Manifest.xml文件(manifestFile)之外,還使用兩個MetaProject對象描述了AOSP的Repo倉庫(repoProject)和Manifest倉庫(manifestProject)。

在AOSP中,每一個子項目(或者說倉庫)都用一個Project對象來描述。Project類定義在文件.repo/repo/project.py文件中,用來封裝對各個項目的基礎(chǔ)Git操作,例如,對項目進行暫存、提交和更新等。它的構(gòu)造函數(shù)如下所示:

class Project(object): 
 def __init__(self, 
        manifest, 
        name, 
        remote, 
        gitdir, 
        worktree, 
        relpath, 
        revisionExpr, 
        revisionId, 
        rebase = True, 
        groups = None, 
        sync_c = False, 
        sync_s = False, 
        clone_depth = None, 
        upstream = None, 
        parent = None, 
        is_derived = False, 
        dest_branch = None): 
  """Init a Project object. 
  Args: 
   manifest: The XmlManifest object. 
   name: The `name` attribute of manifest.xml's project element. 
   remote: RemoteSpec object specifying its remote's properties. 
   gitdir: Absolute path of git directory. 
   worktree: Absolute path of git working tree. 
   relpath: Relative path of git working tree to repo's top directory. 
   revisionExpr: The `revision` attribute of manifest.xml's project element. 
   revisionId: git commit id for checking out. 
   rebase: The `rebase` attribute of manifest.xml's project element. 
   groups: The `groups` attribute of manifest.xml's project element. 
   sync_c: The `sync-c` attribute of manifest.xml's project element. 
   sync_s: The `sync-s` attribute of manifest.xml's project element. 
   upstream: The `upstream` attribute of manifest.xml's project element. 
   parent: The parent Project object. 
   is_derived: False if the project was explicitly defined in the manifest; 
         True if the project is a discovered submodule. 
   dest_branch: The branch to which to push changes for review by default. 
  """ 
  self.manifest = manifest 
  self.name = name 
  self.remote = remote 
  self.gitdir = gitdir.replace('\\', '/') 
  if worktree: 
   self.worktree = worktree.replace('\\', '/') 
  else: 
   self.worktree = None 
  self.relpath = relpath 
  self.revisionExpr = revisionExpr 
 
  if  revisionId is None \ 
   and revisionExpr \ 
   and IsId(revisionExpr): 
   self.revisionId = revisionExpr 
  else: 
   self.revisionId = revisionId 
 
  self.rebase = rebase 
  self.groups = groups 
  self.sync_c = sync_c 
  self.sync_s = sync_s 
  self.clone_depth = clone_depth 
  self.upstream = upstream 
  self.parent = parent 
  self.is_derived = is_derived 
  self.subprojects = [] 
 
  self.snapshots = {} 
  self.copyfiles = [] 
  self.annotations = [] 
  self.config = GitConfig.ForRepository( 
          gitdir = self.gitdir, 
          defaults = self.manifest.globalConfig) 
 
  if self.worktree: 
   self.work_git = self._GitGetByExec(self, bare=False) 
  else: 
   self.work_git = None 
  self.bare_git = self._GitGetByExec(self, bare=True) 
  self.bare_ref = GitRefs(gitdir) 
  self.dest_branch = dest_branch 
 
  # This will be filled in if a project is later identified to be the 
  # project containing repo hooks. 
  self.enabled_repo_hooks = [] 

Project類構(gòu)造函數(shù)的各個參數(shù)的含義見注釋,這里為了方便描述,用中文描述一下:

  1. manifest:指向一個XmlManifest對象,描述AOSP的Repo倉庫和Manifest倉庫元信息
  2. name:項目名稱
  3. remote:描述項目對應(yīng)的遠程倉庫元信息
  4. gitdir:項目的Git倉庫目錄
  5. worktree:項目的工作目錄
  6. relpath:項目的相對于AOSP根目錄的工作目錄

revisionExpr、revisionId、rebase、groups、sync_c、sync_s和upstream:每一個項目在.repo/repo/manifest.xml文件中都有對應(yīng)的描述,這幾個屬性的值就來自于該manifest.xml文件對自己的描述的,它們的含義可以參考.repo/repo/docs/manifest-format.txt文件

parent:父項目

is_derived:如果一個項目含有子模塊(也是一個Git倉庫),那么這些子模塊也會用一個Project對象來描述,這些Project的

is_derived屬性會設(shè)置為true

dest_branch:用來code review的分支

這里重點說一下項目的Git倉庫目錄和工作目錄的概念。一般來說,一個項目的Git倉庫目錄(默認為.git目錄)是位于工作目錄下面的,但是Git支持將一個項目的Git倉庫目錄和工作目錄分開來存放。在AOSP中,Repo倉庫的Git目錄(.git)位于工作目錄(.repo/repo)下,Manifest倉庫的Git目錄有兩份拷貝,一份(.git)位于工作目錄(.repo/manifests)下,另外一份位于.repo/manifests.git目錄,其余的AOSP子項目的工作目錄和Git目錄都是分開存放的,其中,工作目錄位于AOSP根目錄下,Git目錄位于.repo/repo/projects目錄下。

此外,每一個AOSP子項目的工作目錄也有一個.git目錄,不過這個.git目錄是一個符號鏈接,鏈接到.repo/repo/projects對應(yīng)的Git目錄。這樣,我們就既可以在AOSP子項目的工作目錄下執(zhí)行Git命令,也可以在其對應(yīng)的Git目錄下執(zhí)行Git命令。一般來說,要訪問到工作目錄的命令(例如git status)需要在工作目錄下執(zhí)行,而不需要訪問工作目錄(例如git log)可以在Git目錄下執(zhí)行。

Project類有兩個成員變量work_git和bare_git,它們指向的都是一個_GitGetByExec對象。用來封裝對Git命令的執(zhí)行。其中,前者在執(zhí)行Git命令的時候,會將當前目錄設(shè)置為項目的工作目錄,而后者在執(zhí)行的時候,不會設(shè)置當前目錄,但是會將環(huán)境變量GIT_DIR的值設(shè)置為項目的Git目錄,也就是.repo/projects目錄下面的那些目錄。通過這種方式,Project類就可以根據(jù)需要來在工作目錄或者Git目錄下執(zhí)行Git命令。

回到XmlManifest類的構(gòu)造函數(shù)中,由于Repo和Manifest也是屬于Git倉庫,所以我們也需要創(chuàng)建一個Project對象來描述它們。不過,由于它們是比較特殊的Git倉庫(用來描述AOSP子項目元信息的Git倉庫),所以我們就使用另外一個類型為MetaProject的對象來描述它們。MetaProject類是從Project類繼承下來的,定義在project.py文件中,如下所示:

class MetaProject(Project): 
 """A special project housed under .repo. 
 """ 
 def __init__(self, manifest, name, gitdir, worktree): 
  Project.__init__(self, 
           manifest = manifest, 
           name = name, 
           gitdir = gitdir, 
           worktree = worktree, 
           remote = RemoteSpec('origin'), 
           relpath = '.repo/%s' % name, 
           revisionExpr = 'refs/heads/master', 
           revisionId = None, 
           groups = None) 

既然MetaProject類是從Project類繼承下來的,那么它們的Git操作幾乎都可以通過Project類來完成的。實際上,MetaProject類和Project類目前的區(qū)別不是太大,可以認為是基本相同的。使用MetaProject類來描述Repo倉庫和Manifest倉庫,主要是為了強調(diào)它們是用來描述AOSP子項目倉庫的元信息的。

回到_Repo類的成員函數(shù)_Run中,創(chuàng)建好用來描述Repo倉庫和Manifest倉庫的XmlManifest對象之后,就開始執(zhí)行跟在repo腳本后面的不帶橫線“-”的選項所表示的命令。在我們這個場景中,這個命令就是init,它對應(yīng)的Python模塊為.repo/repo/subcmds/init.py,入口函數(shù)為定義在該模塊的Init類的成員函數(shù)Execute,它的實現(xiàn)如下所示:

class Init(InteractiveCommand, MirrorSafeCommand): 
  ......  
 def Execute(self, opt, args): 
  ...... 
 
  self._SyncManifest(opt) 
  self._LinkManifest(opt.manifest_name)  
  ...... 

Init類的成員函數(shù)Execute主要就是調(diào)用另外兩個成員函數(shù)_SyncManifest和_LinkManifest來完成克隆Manifest倉庫的工作。

Init類的成員函數(shù)_SyncManifest的實現(xiàn)如下所示:

class Init(InteractiveCommand, MirrorSafeCommand): 
 ...... 
  def _SyncManifest(self, opt): 
  m = self.manifest.manifestProject 
  is_new = not m.Exists 
   if is_new: 
    ......  
   m._InitGitDir(mirror_git=mirrored_manifest_git) 
 
   if opt.manifest_branch: 
    m.revisionExpr = opt.manifest_branch 
   else: 
    m.revisionExpr = 'refs/heads/master 
  else: 
   if opt.manifest_branch: 
    m.revisionExpr = opt.manifest_branch 
   else: 
    m.PreSync() 
 
  ...... 
   if not m.Sync_NetworkHalf(is_new=is_new): 
   ...... 
   sys.exit(1)  
  if opt.manifest_branch: 
   m.MetaBranchSwitch(opt.manifest_branch) 
  ......  
  m.Sync_LocalHalf(syncbuf) 
  ......  
  if is_new or m.CurrentBranch is None: 
   if not m.StartBranch('default'): 
    ...... 
    sys.exit(1) 

 Init類的成員函數(shù)_SyncManifest執(zhí)行以下操作:

(1). 檢查本地是否存在Manifest倉庫,即檢查用來描述Manifest倉庫MetaProject對象m的成員變量mExists值是否等于true。如果不等于的話,那么就說明本地還沒有安裝過Manifest倉庫。這時候就需要調(diào)用該MetaProject對象m的成員函數(shù)_InitGitDir來在.repo/manifests目錄初始化一個Git倉庫。

(2). 調(diào)用用來描述Manifest倉庫MetaProject對象m的成員函數(shù)Sync_NetworkHalf來從遠程倉庫中克隆一個新的Manifest倉庫到本地來,或者更新本地的Manifest倉庫。這個遠程倉庫的地址即為在執(zhí)行"repo init"命令時,通過-u指定的url,即https://android.googlesource.com/platform/manifest。

(3). 檢查"repo init"命令后面是否通過-b指定要在Manifest倉庫中checkout出來的分支。如果有的話,那么就調(diào)用用來描述Manifest倉庫MetaProject對象m的成員函數(shù)MetaBranchSwitch做一些清理工作,以便接下來可以checkout到指定的分支。

(4). 調(diào)用用來描述Manifest倉庫MetaProject對象m的成員函數(shù)Sync_LocaHalf來執(zhí)行checkout分支的操作。注意,要切換的分支在前面已經(jīng)記錄在MetaProject對象m的成員變量revisionExpr中。

(5). 如果前面執(zhí)行的是新安裝Manifest倉庫的操作,并且沒有通過-b選項指定要checkout的分支,那么默認就checkout出一個default分支。

接下來,我們就主要分析MetaProject類的成員函數(shù)_InitGitDir、Sync_NetworkHalf和Sync_LocaHalf的實現(xiàn)。這幾個函數(shù)實際上都是由MetaProject的父類Project來實現(xiàn)的,因此,下面我們就分析Project類的成員函數(shù)_InitGitDir、Sync_NetworkHalf和Sync_LocaHalf的實現(xiàn)。

Project類的成員函數(shù)_InitGitDir的成員函數(shù)的實現(xiàn)如下所示:

class Project(object): 
 ...... 
 
 def _InitGitDir(self, mirror_git=None): 
  if not os.path.exists(self.gitdir): 
   os.makedirs(self.gitdir) 
   self.bare_git.init() 
   ...... 

Project類的成員函數(shù)_InitGitDir首先是檢查項目的Git目錄是否已經(jīng)存在。如果不存在,那么就會首先創(chuàng)建這個Git目錄,然后再調(diào)用成員變量bare_git所描述的一個_GitGetByExec對象的成員函數(shù)init來在該目錄下初始化一個Git倉庫。

_GitGetByExec類的成員函數(shù)init是通過另外一個成員函數(shù)__getattr__來實現(xiàn)的,如下所示:

class Project(object): 
 ...... 
 
 class _GitGetByExec(object): 
  ...... 
 
  def __getattr__(self, name): 
   """Allow arbitrary git commands using pythonic syntax. 
 
   This allows you to do things like: 
    git_obj.rev_parse('HEAD') 
 
   Since we don't have a 'rev_parse' method defined, the __getattr__ will 
   run. We'll replace the '_' with a '-' and try to run a git command. 
   Any other positional arguments will be passed to the git command, and the 
   following keyword arguments are supported: 
    config: An optional dict of git config options to be passed with '-c'. 
 
   Args: 
    name: The name of the git command to call. Any '_' characters will 
      be replaced with '-'. 
 
   Returns: 
    A callable object that will try to call git with the named command. 
   """ 
   name = name.replace('_', '-') 
   def runner(*args, **kwargs): 
    cmdv = [] 
    config = kwargs.pop('config', None) 
    ...... 
    if config is not None: 
     ...... 
     for k, v in config.items(): 
      cmdv.append('-c') 
      cmdv.append('%s=%s' % (k, v)) 
    cmdv.append(name) 
    cmdv.extend(args) 
    p = GitCommand(self._project, 
            cmdv, 
            bare = self._bare, 
            capture_stdout = True, 
            capture_stderr = True) 
    if p.Wait() != 0: 
     ...... 
    r = p.stdout 
    try: 
     r = r.decode('utf-8') 
    except AttributeError: 
     pass 
    if r.endswith('\n') and r.index('\n') == len(r) - 1: 
     return r[:-1] 
    return r 
   return runner 

從注釋可以知道,_GitGetByExec類的成員函數(shù)__getattr__使用了一個trick,將_GitGetByExec類沒有實現(xiàn)的成員函數(shù)間接地以屬性的形式來獲得,并且將該沒有實現(xiàn)的成員函數(shù)的名稱作為git的一個參數(shù)來執(zhí)行。也就是說,當執(zhí)行_GitGetByExec.init()的時候,實際上是透過成員函數(shù)__getattr__執(zhí)行了一個"git init"命令。這個命令就正好是用來初始化一個Git倉庫。

我們再來看Project類的成員函數(shù)Sync_NetworkHalf的實現(xiàn):

class Project(object): 
 ......  
 def Sync_NetworkHalf(self, 
   quiet=False, 
   is_new=None, 
   current_branch_only=False, 
   clone_bundle=True, 
   no_tags=False): 
  """Perform only the network IO portion of the sync process. 
    Local working directory/branch state is not affected. 
  """ 
  if is_new is None: 
   is_new = not self.Exists 
  if is_new: 
   self._InitGitDir()  
  ......  
  if not self._RemoteFetch(initial=is_new, quiet=quiet, alt_dir=alt_dir, 
               current_branch_only=current_branch_only, 
               no_tags=no_tags): 
   return False 
    ...... 

Project類的成員函數(shù)Sync_NetworkHalf主要執(zhí)行以下的操作:

(1). 檢查本地是否已經(jīng)存在對應(yīng)的Git倉庫。如果不存在,那么就先調(diào)用另外一個成員函數(shù)_InitGitDir來初始化該Git倉庫。

(2). 調(diào)用另外一個成員函籹_RemoteFetch來從遠程倉庫更新本地倉庫。

Project類的成員函數(shù)_RemoteFetch的實現(xiàn)如下所示:

class Project(object): 
......  
def _RemoteFetch(self, name=None, 
          current_branch_only=False, 
          initial=False, 
          quiet=False, 
          alt_dir=None, 
          no_tags=False): 
  ......  
  cmd = ['fetch'] 
  ......  
  ok = False 
  for _i in range(2): 
   ret = GitCommand(self, cmd, bare=True, ssh_proxy=ssh_proxy).Wait() 
   if ret == 0: 
    ok = True 
    break 
   elif current_branch_only and is_sha1 and ret == 128: 
    # Exit code 128 means "couldn't find the ref you asked for"; if we're in sha1 
    # mode, we just tried sync'ing from the upstream field; it doesn't exist, thus 
    # abort the optimization attempt and do a full sync. 
    break 
   time.sleep(random.randint(30, 45))    
  ...... 

Project類的成員函數(shù)_RemoteFetch的核心操作就是調(diào)用“git fetch”命令來從遠程倉庫更新本地倉庫。

接下來我們再看MetaProject類的成員函數(shù)Sync_LocaHalf的實現(xiàn):

class Project(object): 
 ......  
 def Sync_LocalHalf(self, syncbuf): 
  """Perform only the local IO portion of the sync process. 
    Network access is not required. 
  """ 
  ...... 
  revid = self.GetRevisionId(all_refs) 
   ...... 
   self._InitWorkTree() 
  head = self.work_git.GetHead() 
  if head.startswith(R_HEADS): 
   branch = head[len(R_HEADS):] 
   try: 
    head = all_refs[head] 
   except KeyError: 
    head = None 
  else: 
   branch = None 
 
  ......  
  if head == revid: 
   # No changes; don't do anything further. 
   # 
   return 
 
  branch = self.GetBranch(branch) 
   ......  
  if not branch.LocalMerge: 
   # The current branch has no tracking configuration. 
   # Jump off it to a detached HEAD. 
   # 
   syncbuf.info(self, 
          "leaving %s; does not track upstream", 
          branch.name) 
   try: 
    self._Checkout(revid, quiet=True) 
   except GitError as e: 
    syncbuf.fail(self, e) 
    return 
   ...... 
   return  
  ...... 

這里我們只分析一種比較簡單的情況,就是當前要checkout的分支是一個干凈的分支,它沒有做過修改,也沒有設(shè)置跟蹤遠程分支。這時候Project類的成員函數(shù)_RemoteFetch的主要執(zhí)行以下操作:

(1). 調(diào)用另外一個成員函數(shù)GetRevisionId獲得即將要checkout的分支,保存在變量revid中。

(2). 調(diào)用成員變量work_git所描述的一個_GitGetByExec對象的成員函數(shù)GetHead獲得項目當前checkout的分支,只存在變量head中。

(3). 如果即將要checkout的分支revid就是當前已經(jīng)checkout分支,那么就什么也不用做。否則繼續(xù)往下執(zhí)行。

(4). 調(diào)用另外一個成員函數(shù)GetBranch獲得用來描述當前分支的一個Branch對象。

(5). 如果上述Branch對象的屬性LocalMerge的值等于None,也就是屬于我們討論的情況,那么就調(diào)用另外一個成員函數(shù)_Checkout真正執(zhí)行checkout分支revid的操作。

如果要checkout的分支revid不是一個干凈的分支,也就是它正在跳蹤遠程分支,并且在本地做過提交,這些提交又沒有上傳到遠程分支去,那么就需要執(zhí)行一些merge或者rebase的操作。不過無論如何,這些操作都是通過標準的Git命令來完成的。

我們接著再看Project類的成員函數(shù)_Checkout的實現(xiàn):

class Project(object): 
 ...... 
 
 def _Checkout(self, rev, quiet=False): 
  cmd = ['checkout'] 
  if quiet: 
   cmd.append('-q') 
  cmd.append(rev) 
  cmd.append('--') 
  if GitCommand(self, cmd).Wait() != 0: 
   if self._allrefs: 
    raise GitError('%s checkout %s ' % (self.name, rev)) 

Project類的成員函數(shù)_Checkout的實現(xiàn)很簡單,它通過GitCommand類構(gòu)造了一個“git checkout”命令,將參數(shù)rev描述的分支checkout出來。

至此,我們就將Manifest倉庫從遠程地址https://android.googlesource.com/platform/manifest克隆到本地來了,并且checkout出了指定的分支?;氐絀nit類的成員函數(shù)Execute中,它接下來還要調(diào)用另外一個成員函數(shù)_LinkManifest來執(zhí)行一個符號鏈接的操作。

Init類的成員函數(shù)_LinkManifest的實現(xiàn)如下所示:

class Init(InteractiveCommand, MirrorSafeCommand): 
 ...... 
 
 def _LinkManifest(self, name): 
  if not name: 
   print('fatal: manifest name (-m) is required.', file=sys.stderr) 
   sys.exit(1) 
 
  try: 
   self.manifest.Link(name) 
  except ManifestParseError as e: 
   print("fatal: manifest '%s' not available" % name, file=sys.stderr) 
   print('fatal: %s' % str(e), file=sys.stderr) 
   sys.exit(1) 

參數(shù)name的值一般就等于“default.xml”,表示Manifest倉庫中的default.xml文件,Init類的成員函數(shù)_LinkManifest通過調(diào)用成員變量manifest所描述的一個XmlManifest對象的成員函數(shù)Link來執(zhí)行符號鏈接的操作,它定義在文件.repo/repo/xml_manifest.py文件,它的實現(xiàn)如下所示:

class XmlManifest(object): 
 """manages the repo configuration file""" 
 ...... 
 
 def Link(self, name): 
  """Update the repo metadata to use a different manifest. 
  """ 
  ...... 
 
  try: 
   if os.path.lexists(self.manifestFile): 
    os.remove(self.manifestFile) 
   os.symlink('manifests/%s' % name, self.manifestFile) 
  except OSError as e: 
   raise ManifestParseError('cannot link manifest %s: %s' % (name, str(e))) 

XmlManifest類的成員變量manifestFile的值等于$(AOSP)/.repo/manifest.xml,通過調(diào)用os.symlink就將它符號鏈接至$(AOSP)/.repo/manifests/<name>文件去。這樣無論Manifest倉庫中用來描述AOSP子項目的xml文件是什么名稱,都可以統(tǒng)一通過$(AOSP)/.repo/manifest.xml文件來訪問。

前面提到,Manifest倉庫中用來描述AOSP子項目的xml文件名稱默認就為default.xml,它的內(nèi)容如下所示:

<?xml version="1.0" encoding="UTF-8"?> 
<manifest>  
 <remote name="aosp" 
      fetch=".." 
      review="https://android-review.googlesource.com/" /> 
 <default revision="refs/tags/android-4.2_r1" 
      remote="aosp" 
      sync-j="4" />  
 <project path="build" name="platform/build" > 
  <copyfile src="core/root.mk" dest="Makefile" /> 
 </project> 
 <project path="abi/cpp" name="platform/abi/cpp" /> 
 <project path="bionic" name="platform/bionic" /> 
 ......  
</manifest> 

關(guān)于該xml文件的詳細描述可以參考.repo/repo/docs/manifest-format.txt文件。一般來說,該xml包含有四種類型的標簽:

remote:用來指定遠程倉庫信息。屬性name描述的是一個遠程倉庫的名稱,屬性fetch用作項目名稱的前緣,在構(gòu)造項目倉庫遠程地址時使用到,屬性review描述的是用作code review的server地址。

default:當project標簽沒有指定default標簽的屬性時,默認就使用在default標簽列出的屬性。屬性revision描述的是項目默認檢出的分支,屬性remote描述的是默認使用的遠程倉庫名稱,必須要對應(yīng)的remote標簽的name屬性值,屬性sync-j描述的是從遠程倉庫更新項目時使用的并行任務(wù)數(shù)。

project:每一個AOSP子項目在這里都對應(yīng)有一個projec標簽,用來描述項目的元信息。屬性path描述的是項目相對于遠程倉庫URL的路徑,屬性name描述的是項目的名稱,也是相對于 AOSP根目錄的目錄名稱。例如,如果遠程倉庫URL為https://android.googlesource.com/platform,那么AOSP子項目bionic對應(yīng)的遠程倉庫URL就為https://android.googlesource.com/platform/bionic,并且它的工作目錄位于$(AOSP)/bionic。

copyfile:作為project的子標簽,表示要將從遠程倉庫更新回來的文件拷貝到指定的另外一個文件去。

至些,我們就分析完成Manifest倉庫的克隆過程了。在此基礎(chǔ)上,我們再分析AOSP子項目倉庫的克隆過程或者針對AOSP子項目的各種Repo命令就容易多了。

4. AOSP子項目倉庫

執(zhí)行完成repo init命令之后,我們就可以繼續(xù)執(zhí)行repo sync命令來克隆或者同步AOSP子項目了:

$ repo sync 

與repo init命令類似,repo sync命令的執(zhí)行過程如下所示:

1. Repo腳本找到Repo倉庫里面的main.py文件,并且執(zhí)行它的入口函數(shù)_Main;

2. Repo倉庫里面的main.py文件的入口函數(shù)_Main調(diào)用_Repo類的成員函數(shù)_Run對Repo腳本傳遞進來的參數(shù)進行解析;

3. _Repo類的成員函數(shù)_Run解析參數(shù)發(fā)現(xiàn)要執(zhí)行的命令是sync,于是就在subcmds目錄中找到一個名稱為sync.py的文件,并且調(diào)用定義在它里面的一個名稱為Sync的類的成員函數(shù)Execute;

4. Sync類的成員函數(shù)Execute解析Manifest倉庫的default.xml文件,并且克隆或者同步出在default.xml文件里面列出的每一個AOSP子項目。

在第3步中,Repo倉庫的每一個Python文件是如何與一個Repo命令關(guān)聯(lián)起來的呢?原來在Repo倉庫的subcmds目錄中,有一個__init__.py文件,每當subcmds被import時,定義在它里面的命令就會被執(zhí)行,如下所示:

all_commands = {}  
my_dir = os.path.dirname(__file__) 
for py in os.listdir(my_dir): 
 if py == '__init__.py': 
  continue  
 if py.endswith('.py'): 
  name = py[:-3] 
  clsn = name.capitalize() 
  while clsn.find('_') > 0: 
   h = clsn.index('_') 
   clsn = clsn[0:h] + clsn[h + 1:].capitalize() 
   mod = __import__(__name__, 
           globals(), 
           locals(), 
           ['%s' % name]) 
  mod = getattr(mod, name) 
  try: 
   cmd = getattr(mod, clsn)() 
  except AttributeError: 
   raise SyntaxError('%s/%s does not define class %s' % ( 
             __name__, py, clsn)) 
 
  name = name.replace('_', '-') 
  cmd.NAME = name 
  all_commands[name] = cmd 

__init__.py會列出subcmds目錄中的所有Python文件(除了__init__.py),并且里面找到對應(yīng)的類,然后再創(chuàng)建這個類的一個對象,并且以文件名為關(guān)鍵字將該對象保存在全局變量all_commands中。例如,對于sync.py文件,它的文件名稱去掉后綴名后為sync,再將sync的首字母大寫,得到Sync。也就是說,sync.py需要定義一個Sync類,并且這個類需要直接或者間接地從Command類繼承下來。Command類有一個成員函數(shù)Execute,它的各個子類需要對它進行重寫,以實現(xiàn)各自的功能。

_Repo類的成員函數(shù)_Run就是通過subcmds模塊里面的全局變量all_commands,并且根據(jù)Repo腳本傳進行來的第一個不帶橫線“-”的參數(shù)來找到對應(yīng)的Command對象,然后調(diào)用它的成員函數(shù)Execute的。

Sync類的成員函數(shù)Execute的實現(xiàn)如下所示:

class Sync(Command, MirrorSafeCommand): 
 ...... 
 
 def Execute(self, opt, args): 
  ...... 
 
  mp = self.manifest.manifestProject 
  ...... 
 
  if not opt.local_only: 
   mp.Sync_NetworkHalf(quiet=opt.quiet, 
             current_branch_only=opt.current_branch_only, 
             no_tags=opt.no_tags) 
  ...... 
 
  if mp.HasChanges: 
   ...... 
   mp.Sync_LocalHalf(syncbuf) 
   ...... 
 
  all_projects = self.GetProjects(args, 
                  missing_ok=True, 
                  submodules_ok=opt.fetch_submodules) 
  ...... 
 
  if not opt.local_only: 
   to_fetch = [] 
   ...... 
   to_fetch.extend(all_projects) 
   to_fetch.sort(key=self._fetch_times.Get, reverse=True) 
 
   fetched = self._Fetch(to_fetch, opt) 
   ...... 
 
   if opt.network_only: 
    # bail out now; the rest touches the working tree 
    return 
 
   # Iteratively fetch missing and/or nested unregistered submodules 
   while True: 
    ...... 
    all_projects = self.GetProjects(args, 
                    missing_ok=True, 
                    submodules_ok=opt.fetch_submodules) 
    missing = [] 
    for project in all_projects: 
     if project.gitdir not in fetched: 
      missing.append(project) 
    if not missing: 
     break 
    ...... 
    fetched.update(self._Fetch(missing, opt)) 
 
  if self.UpdateProjectList(): 
   sys.exit(1) 
   ......  
  for project in all_projects: 
   ...... 
   if project.worktree: 
    project.Sync_LocalHalf(syncbuf)  
  ...... 

Sync類的成員函數(shù)Execute的核以執(zhí)行流程如下所示:

(1). 獲得用來描述Manifest倉庫的MetaProject對象mp。

(2). 如果在執(zhí)行repo sync命令時,沒有指定--local-only選項,那么就調(diào)用MetaProject對象mp的成員函數(shù)Sync_NetworkHalf從遠程倉庫下載更新本地Manifest倉庫。

(3). 如果Mainifest倉庫發(fā)生過更新,那么就調(diào)用MetaProject對象mp的成員函數(shù)Sync_LocalHalf來合并這些更新到本地的當前分支來。

(4). 調(diào)用Sync的父類Command的成員函數(shù)GetProjects獲得由Manifest倉庫的default.xml文件定義的所有AOSP子項目信息,或者由參數(shù)args所指定的AOSP子項目的信息。這些AOSP子項目信息都是通過Project對象來描述,并且保存在變量all_projects中。

(5). 如果在執(zhí)行repo sync命令時,沒有指定--local-only選項,那么就對保存在變量all_projects中的AOSP子項目進行網(wǎng)絡(luò)更新,也就是從遠程倉庫中下載更新到本地倉庫來,這是通過調(diào)用Sync類的成員函數(shù)_Fetch來完成的。Sync類的成員函數(shù)_Fetch實際上又是通過調(diào)用Project類的成員函數(shù)Sync_NetworkHalf來將遠程倉庫的更新下載到本地倉庫來的。

(6). 由于AOSP子項目可能會包含有子模塊,因此當對它們進行了遠程更新之后,需要檢查它們是否包含有子模塊。如果包含有子模塊,并且執(zhí)行repo sync腳本時指定有--fetch-submodules選項,那么就需要對AOSP子項目的子模塊進行遠程更新。調(diào)用Sync的父類Command的成員函數(shù)GetProjects的時候,如果將參數(shù)submodules_ok的值設(shè)置為true,那么得到的AOSP子項目列表就包含有子模塊。將這個AOSP子項目列表與之前獲得的AOSP子項目列表fetched進行一個比較,就可以知道有哪些子模塊是需要更新的。需要更新的子模塊都保存在變量missing中。由于子模塊也是用Project類來描述的,因此,我們可以像遠程更新AOSP子項目一樣,調(diào)用Sync類的成員函數(shù)_Fetch來更新它們的子模塊。

(7). 調(diào)用Sync類的成員函數(shù)UpdateProjectList更新$(AOSP)/.repo目錄下的project.list文件。$(AOSP)/.repo/project.list記錄的是上一次遠程同步后所有的AOSP子項目名稱。以后每一次遠程同步之后,Sync類的成員函數(shù)UpdateProjectList就會通過該文件來檢查是否存在某些AOSP子項目被刪掉了。如果存在這樣的AOSP子項目,并且這些AOSP子項目沒有發(fā)生修改,那么就會將它們的工作目錄刪掉。

(8). 到目前為止,Sync類的成員函數(shù)對AOSP子項目所做的操作僅僅是下載遠程倉庫的更新到本地來,但是還沒有將這些更新合并到本地的當前分支來,因此,這時候就需要調(diào)用Project類的成員函數(shù)Sync_LocalHalf來執(zhí)行合并更新的操作。

從上面的步驟可以看出,init sync命令的核心操作就是收集每一個需要同步的AOSP子項目所對應(yīng)的Project對象,然后再調(diào)用這些Project對象的成員函數(shù)Sync_NetwokHalft和Sync_LocalHalf進行同步。關(guān)于Project類的成員函數(shù)Sync_NetwokHalft和Sync_LocalHalf,我們在前面分析Manifest倉庫的克隆過程時,已經(jīng)分析過了,它們無非就是通過git fetch、git rebase或者git merge等基本Git命令來完成自己的功能。

以上我們分析的就是AOSP子項目倉庫的克隆或者同步過程,為了更進一步加深對Repo倉庫的理解,接下來我們再分析另外一個用來在AOSP上創(chuàng)建Topic的命令repo start。

5. 在AOSP上創(chuàng)建Topic

在Git的世界里,分支(branch)是一個很核心的概念。Git鼓勵你在修復(fù)Bug或者開發(fā)新的Feature時,都創(chuàng)建一個新的分支。創(chuàng)建Git分支的代價是很小的,而且速度很快,因此,不用擔心創(chuàng)建Git分支是一件不討好的事情,而應(yīng)該盡可能多地使用分支。

同樣的,我們下載好AOSP代碼之后,如果需要在上面進行修改,或者增加新的功能,那么就要在新的分支上面進行。Repo倉庫提供了一個repo start命令,用來在AOSP上創(chuàng)建分支,也稱為Topic。這個命令的用法如下所示:

$ repo start BRANCH_NAME [PROJECT_LIST] 

參數(shù)BRANCH_NAME指定新的分支名稱,后面的PROJECT_LIST是可選的。如果指定了PROJECT_LIST,就表示只對特定的AOSP子項目創(chuàng)建分支,否則的話,就對所有的AOSP子項目創(chuàng)建分支。

根據(jù)前面我們對repo sync命令的分析可以知道,當我們執(zhí)行repo start命令的時候,最終定義在Repo倉庫的subcmds/start.py文件里面的Start類的成員函數(shù)Execute會被調(diào)用,它的實現(xiàn)如下所示:

class Start(Command): 
 ...... 
 
 def Execute(self, opt, args): 
  ...... 
 
  nb = args[0] 
  if not git.check_ref_format('heads/%s' % nb): 
   print("error: '%s' is not a valid name" % nb, file=sys.stderr) 
   sys.exit(1) 
 
  err = [] 
  projects = [] 
  if not opt.all: 
   projects = args[1:] 
   if len(projects) < 1: 
    print("error: at least one project must be specified", file=sys.stderr) 
    sys.exit(1) 
 
  all_projects = self.GetProjects(projects) 
 
  pm = Progress('Starting %s' % nb, len(all_projects)) 
  for project in all_projects: 
   pm.update() 
   ...... 
   if not project.StartBranch(nb): 
    err.append(project) 
  pm.end() 
 
  ...... 

參數(shù)args[0]保存的是要創(chuàng)建的分支的名稱,參數(shù)args[1:]保存的是要創(chuàng)建分支的AOSP子項目名稱列表,Start類的成員函數(shù)Execute分別將它們保存變量nb和projects中。

Start類的成員函數(shù)Execute接下來調(diào)用父類Command的成員函數(shù)GetProjects,并且以變量projects為參數(shù),就可以獲得所有需要創(chuàng)建新分支nb的AOSP子項目列表all_projects。在all_projects中,每一個AOSP子項目都用一個Project對象來描述。

最后,Start類的成員函數(shù)Execute就遍歷all_projects里面的每一個Project對象,并且調(diào)用它們的成員函數(shù)StartBranch來執(zhí)行創(chuàng)建新分支的操作。

Project類的成員函數(shù)StartBranch的實現(xiàn)如下所示:

class Project(object): 
 ...... 
 
 def StartBranch(self, name): 
  """Create a new branch off the manifest's revision. 
  """ 
  head = self.work_git.GetHead() 
  if head == (R_HEADS + name): 
   return True 
 
  all_refs = self.bare_ref.all 
  if (R_HEADS + name) in all_refs: 
   return GitCommand(self, 
            ['checkout', name, '--'], 
            capture_stdout = True, 
            capture_stderr = True).Wait() == 0 
 
  branch = self.GetBranch(name) 
  branch.remote = self.GetRemote(self.remote.name) 
  branch.merge = self.revisionExpr 
  revid = self.GetRevisionId(all_refs) 
 
  if head.startswith(R_HEADS): 
   try: 
    head = all_refs[head] 
   except KeyError: 
    head = None 
 
  if revid and head and revid == head: 
   ref = os.path.join(self.gitdir, R_HEADS + name) 
   try: 
    os.makedirs(os.path.dirname(ref)) 
   except OSError: 
    pass 
   _lwrite(ref, '%s\n' % revid) 
   _lwrite(os.path.join(self.worktree, '.git', HEAD), 
       'ref: %s%s\n' % (R_HEADS, name)) 
   branch.Save() 
   return True 
 
  if GitCommand(self, 
         ['checkout', '-b', branch.name, revid], 
         capture_stdout = True, 
         capture_stderr = True).Wait() == 0: 
   branch.Save() 
   return True 
  return False 

Project類的成員函數(shù)StartBranch的執(zhí)行過程如下所示:

(1). 獲得項目的當前分支head,這是通過調(diào)用Project類的成員函數(shù)GetHead來實現(xiàn)的。

(2). 項目當前的所有分支保存在Project類的成員變量bare_ref所描述的一個GitRefs對象的成員變量all中。如果要創(chuàng)建的分支name已經(jīng)項目的一個分支,那么就直接通過GitCommand類調(diào)用git checkout命令來將該分支檢出即可,而不用創(chuàng)建新的分支。否則繼續(xù)往下執(zhí)行。

(3). 創(chuàng)建一個Branch對象來描述即將要創(chuàng)建的分支。Branch類的成員變量remote描述的分支所要追蹤的遠程倉庫,另外一個成員變量merge描述的是分支要追蹤的遠程倉庫的分支。這個要追蹤的遠程倉庫分支由Manifest倉庫的default.xml文件描述,并且保存在Project類的成員變量revisionExpr中。

(4). 調(diào)用Project類的成員函數(shù)GetRevisionId獲得項目要追蹤的遠程倉庫分支的sha1值,并且保存在變量revid中。

(5). 由于新創(chuàng)建的分支name需要追蹤的遠程倉庫分支為revid,因此如果項目的當前分支head剛好就是項目要追蹤的遠程倉庫分支revid,那么創(chuàng)建新分支name就變得很簡單,只要在項目的Git目錄(位于.repo/projects目錄下)下的refs/heads子目錄以name名稱創(chuàng)建一個文件,并且往這個文件寫入寫入revid的值,以表明新分支name是在要追蹤的遠程分支revid的基礎(chǔ)上創(chuàng)建的。這樣的一個簡單的Git分支就創(chuàng)建完成了。不過我們還要修改項目工作目錄下的.git/HEAD文件,將它的內(nèi)容寫為剛才創(chuàng)建的文件的路徑名稱,這樣才能將項目的當前分支切換為剛才新創(chuàng)建的分支。從這個過程就可以看出,創(chuàng)建的一個Git分支,不過就是創(chuàng)建一個包含一個sha1值的文件,因此代價是非常小的。如果項目的當前分支head剛好不是項目要追蹤的遠程倉庫分支revid,那么就繼續(xù)往下執(zhí)行。

(6). 執(zhí)行到這里的時候,就表明我們要創(chuàng)建的分支不存在,并且我們需要在一個不是當前分支的分支的基礎(chǔ)上創(chuàng)建該新分支,這時候就需要通過調(diào)用帶-b選項的git checkout命令來完成創(chuàng)建新分支的操作了。選項-b后面的參數(shù)就表明要在哪一個分支的基礎(chǔ)上創(chuàng)建分支。新的分支創(chuàng)建出來之后,還需要將它的文件拷貝到項目的工作目錄去。

至此,我們就分析完成在AOSP上創(chuàng)建新分支的過程了,也就是repo start命令的執(zhí)行過程。更多的repo命令,例如repo uplad、repo diff和repo status等,可以以參考官方文檔http://source.android.com/source/using-repo.html,它們的執(zhí)行過程和我們前面分析repo sync、repo start都是類似,不同的是它們執(zhí)行其它的Git命令。有興趣的小伙伴自己嘗試自己去分析一下

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

相關(guān)文章

最新評論

最新国产精品网址在线观看| 亚洲男人在线天堂网| 日本啪啪啪啪啪啪啪| 天天日天天鲁天天操| 人妻素人精油按摩中出| 欧美熟妇一区二区三区仙踪林| 欧美日韩亚洲国产无线码| 女蜜桃臀紧身瑜伽裤| 久久久久久久久久性潮| 国产密臀av一区二区三| 亚洲一区二区三区偷拍女厕91| 日韩欧美中文国产在线| 天天干夜夜操天天舔| 国产精品视频资源在线播放| 成年人午夜黄片视频资源| 99热99这里精品6国产| 91色网站免费在线观看| 18禁美女羞羞免费网站| www日韩毛片av| 91色网站免费在线观看| 经典av尤物一区二区| 99热国产精品666| 亚洲免费在线视频网站| av手机在线免费观看日韩av| 超黄超污网站在线观看| 中文字幕高清免费在线人妻| 中文字幕在线欧美精品| 免费在线黄色观看网站| 国产亚洲欧美另类在线观看| 性欧美日本大妈母与子| 成人亚洲精品国产精品| 一本一本久久a久久精品综合不卡| 午夜频道成人在线91| 香蕉片在线观看av| 国产一区二区火爆视频| 在线观看国产网站资源| 在线不卡成人黄色精品| 老有所依在线观看完整版| 北条麻妃高跟丝袜啪啪| av在线shipin| 国产在线拍揄自揄视频网站| 日本阿v视频在线免费观看| 日本高清撒尿pissing| 337p日本大胆欧美人| 天天日天天干天天干天天日| 精品一线二线三线日本| 女生自摸在线观看一区二区三区| 香蕉av影视在线观看| 国产一区av澳门在线观看| 岛国免费大片在线观看| 丝袜亚洲另类欧美变态| 免费在线福利小视频| 久久久噜噜噜久久熟女av| 性感美女福利视频网站| 少妇一区二区三区久久久| 91精品国产麻豆国产| 日本人妻欲求不满中文字幕| av森泽佳奈在线观看| 男人和女人激情视频| yy6080国产在线视频| 午夜久久香蕉电影网| 淫秽激情视频免费观看| 把腿张开让我插进去视频| 护士特殊服务久久久久久久 | 综合激情网激情五月天| 第一福利视频在线观看| 青青青青青操视频在线观看| 日比视频老公慢点好舒服啊| 国产av国片精品一区二区| 在线亚洲天堂色播av电影| 人妻丝袜精品中文字幕| 快插进小逼里大鸡吧视频| 午夜美女少妇福利视频| 亚洲欧美成人综合在线观看| 岳太深了紧紧的中文字幕| 91成人在线观看免费视频| 精品国产亚洲av一淫| 黄色片黄色片wyaa| 日本最新一二三区不卡在线 | 人人妻人人爽人人澡人人精品| 色花堂在线av中文字幕九九| 黄网十四区丁香社区激情五月天| 中文字幕之无码色多多| 五十路av熟女松本翔子| 日本韩国在线观看一区二区| 久草视频在线免播放| aⅴ五十路av熟女中出| 91社福利《在线观看| 日本免费一级黄色录像| 国产精品久久久久久久女人18| 日本熟妇色熟妇在线观看| 色哟哟在线网站入口| 亚洲av无硬久久精品蜜桃| 91桃色成人网络在线观看| 日本韩国免费一区二区三区视频| 夜夜操,天天操,狠狠操| 成人30分钟免费视频| 狍和女人的王色毛片| 99精品一区二区三区的区| 亚洲精品高清自拍av| 日本xx片在线观看| 91极品大一女神正在播放| 日韩伦理短片在线观看| 521精品视频在线观看| 99国内小视频在现欢看| 天天摸天天日天天操| 婷婷综合蜜桃av在线| 人人妻人人澡欧美91精品| 视频啪啪啪免费观看| 亚洲 欧美 精品 激情 偷拍| av手机免费在线观看高潮| 女警官打开双腿沦为性奴| 国产成人综合一区2区| 青青社区2国产视频| 超污视频在线观看污污污 | 成人激情文学网人妻| 在线视频这里只有精品自拍| 亚洲成人国产综合一区| 绝色少妇高潮3在线观看| 天天日天天做天天日天天做| 1区2区3区4区视频在线观看| 久草极品美女视频在线观看| 99精品亚洲av无码国产另类| 亚洲午夜电影之麻豆| 久久久久久久一区二区三| 又色又爽又黄又刺激av网站| 午夜91一区二区三区| 香港一级特黄大片在线播放| 狠狠的往里顶撞h百合| 天天日天天做天天日天天做| 天天日天天添天天爽| 婷婷午夜国产精品久久久| 91色网站免费在线观看| 亚洲成人av一区在线| 91精品免费久久久久久| 可以在线观看的av中文字幕| 在线不卡成人黄色精品| 亚洲午夜精品小视频| 亚洲天天干 夜夜操| 亚洲欧美激情人妻偷拍| 国产一区二区神马久久| 国产九色91在线视频| 中国把吊插入阴蒂的视频| 亚洲av男人天堂久久| 福利国产视频在线观看| 风流唐伯虎电视剧在线观看| 视频 一区二区在线观看| 1000部国产精品成人观看视频| 伊人开心婷婷国产av| 国产在线自在拍91国语自产精品| 超碰97人人澡人人| 在线亚洲天堂色播av电影| 欧洲国产成人精品91铁牛tv| 日韩亚洲高清在线观看| 天天日天天天天天天天天天天| 骚逼被大屌狂草视频免费看| mm131美女午夜爽爽爽| 天天日天天摸天天爱| 欧美亚洲免费视频观看| 中文字幕第三十八页久久| 亚洲精品久久综合久| 欧美第一页在线免费观看视频| 午夜国产福利在线观看| 丰满少妇人妻xxxxx| 最新日韩av传媒在线| 中文字幕乱码人妻电影| 亚洲1069综合男同| 99久久激情婷婷综合五月天| 啪啪啪18禁一区二区三区 | 大鸡巴插入美女黑黑的阴毛| jul—619中文字幕在线| 中文字幕最新久久久| 涩涩的视频在线观看视频| 欧洲日韩亚洲一区二区三区| 日本熟妇丰满厨房55| 国产精品久久久久网| 超pen在线观看视频公开97| 男人的天堂av日韩亚洲| 一区二区熟女人妻视频| 亚洲综合在线观看免费| 国产伊人免费在线播放| 中文人妻AV久久人妻水| 少妇一区二区三区久久久| 激情伦理欧美日韩中文字幕| 国产福利在线视频一区| 亚洲av成人免费网站| a v欧美一区=区三区| 91成人精品亚洲国产| 国产露脸对白在线观看| 成人免费毛片aaaa| 国产视频精品资源网站| 亚洲高清国产自产av| 国产亚洲精品视频合集| 天天操天天干天天日狠狠插| 亚洲卡1卡2卡三卡四老狼| 啊用力插好舒服视频| 国产精品亚洲在线观看| 亚洲最大黄 嗯色 操 啊| 91一区精品在线观看| 一区二区麻豆传媒黄片| 国产福利小视频二区| 国产av自拍偷拍盛宴| 中文字幕日韩无敌亚洲精品| 综合国产成人在线观看| 亚洲 国产 成人 在线| 精品久久久久久久久久久久人妻| 天天日天天爽天天爽| 成人24小时免费视频| 亚洲av琪琪男人的天堂| 午夜精品久久久久麻豆影视| 青青青青青青青青青青草青青 | 黄色视频在线观看高清无码 | 欧美一区二区三区高清不卡tv| 扒开让我视频在线观看| 国产三级精品三级在线不卡| 亚洲伊人av天堂有码在线| 久久精品亚洲成在人线a| av在线免费资源站| 成熟丰满熟妇高潮xx×xx| 在线制服丝袜中文字幕| av新中文天堂在线网址| 亚洲精品福利网站图片| 天天日夜夜操天天摸| 亚洲精品欧美日韩在线播放| 日韩人妻在线视频免费| 一二三区在线观看视频| 欧美精品中文字幕久久二区| 午夜激情久久不卡一区二区| chinese国产盗摄一区二区| 内射久久久久综合网| 粉嫩小穴流水视频在线观看| 国产一区二区欧美三区| chinese国产盗摄一区二区| 亚洲粉嫩av一区二区三区| 精品久久久久久久久久中文蒉| 香蕉aⅴ一区二区三区| 超碰97人人澡人人| 国产精品污污污久久| 国产女孩喷水在线观看| 青青青青视频在线播放| 中文人妻AV久久人妻水| 少妇一区二区三区久久久| 亚洲欧美自拍另类图片| 亚洲精品 欧美日韩| 日本在线一区二区不卡视频| 中文字幕日韩人妻在线三区| 亚洲欧美福利在线观看| 午夜美女少妇福利视频| 天天躁日日躁狠狠躁av麻豆| 午夜久久久久久久99| 日韩精品电影亚洲一区| 女生自摸在线观看一区二区三区 | 欧美专区日韩专区国产专区| 国产高清在线观看1区2区| 国产又粗又黄又硬又爽| 综合一区二区三区蜜臀| free性日本少妇| 热思思国产99re| 91九色国产porny蝌蚪| 色吉吉影音天天干天天操| 五十路息与子猛烈交尾视频| 中文字幕日韩人妻在线三区| 91麻豆精品秘密入口在线观看| 欧美一区二区三区久久久aaa| aⅴ五十路av熟女中出| 精品少妇一二三视频在线| 在线观看成人国产电影| 青青青青爽手机在线| tube69日本少妇| 亚洲精品国产综合久久久久久久久| 国产精品亚洲а∨天堂免| 亚洲免费av在线视频| 2022国产精品视频| 顶级尤物粉嫩小尤物网站| av黄色成人在线观看| 青青青青爽手机在线| 少妇人妻久久久久视频黄片| 青青草成人福利电影| 亚洲av第国产精品| 91精品国产高清自在线看香蕉网 | 日日操夜夜撸天天干| 日本高清在线不卡一区二区| 国产老熟女伦老熟妇ⅹ| 五十路熟女av天堂| 偷青青国产精品青青在线观看| 最后99天全集在线观看| 大鸡八强奸视频在线观看| 水蜜桃一区二区三区在线观看视频 | 欧美性感尤物人妻在线免费看| 青青青aaaa免费| av新中文天堂在线网址| 操操网操操伊剧情片中文字幕网| 偷拍自拍亚洲美腿丝袜| av亚洲中文天堂字幕网| 视频一区二区在线免费播放| 十八禁在线观看地址免费| 在线观看的a站 最新| 521精品视频在线观看| 亚洲精品欧美日韩在线播放| 一区二区三区国产精选在线播放| 亚洲老熟妇日本老妇| 懂色av蜜桃a v| 中文字幕一区二 区二三区四区| 国产午夜激情福利小视频在线| 久草极品美女视频在线观看| 亚洲国产中文字幕啊啊啊不行了| 天天色天天爱天天爽| 欧美80老妇人性视频| 黄页网视频在线免费观看| 成人av免费不卡在线观看| 新97超碰在线观看| 中文字幕人妻一区二区视频 | 在线观看av观看av| 偷拍美女一区二区三区| 啊啊啊视频试看人妻| 福利午夜视频在线合集| 欧美区一区二区三视频| 日韩无码国产精品强奸乱伦| 蜜桃色婷婷久久久福利在线| 成人亚洲国产综合精品| 蜜桃色婷婷久久久福利在线| 国产麻豆91在线视频| 伊人综合免费在线视频| 懂色av蜜桃a v| 亚洲福利天堂久久久久久| 中文字幕第一页国产在线| 中国黄片视频一区91| 天天色天天操天天透| 精品suv一区二区69| 一区二区三区麻豆福利视频| 噜噜色噜噜噜久色超碰| 91国内精品自线在拍白富美| 不戴胸罩引我诱的隔壁的人妻| 一级黄片久久久久久久久| 色综合天天综合网国产成人| 五十路息与子猛烈交尾视频| 亚洲av日韩av网站| 91精品啪在线免费| 日本性感美女三级视频| 国产成人一区二区三区电影网站| 国产精品熟女久久久久浪潮| 在线观看免费视频网| 同居了嫂子在线播高清中文| 精品人妻每日一部精品| 最新97国产在线视频| 老司机午夜精品视频资源| 888欧美视频在线| 又黄又刺激的午夜小视频| 免费在线播放a级片| 婷婷综合亚洲爱久久| 亚洲av日韩高清hd| 久久丁香婷婷六月天| 日日操夜夜撸天天干| 快点插进来操我逼啊视频| 99人妻视频免费在线| 91色九色porny| 久久热这里这里只有精品| 国产麻豆乱子伦午夜视频观看| 天天日天天操天天摸天天舔| 青草青永久在线视频18| 又大又湿又爽又紧A视频| 人妻丝袜av在线播放网址| 国产美女一区在线观看| 91精品国产综合久久久蜜 | 中文字幕av熟女人妻| 亚洲av成人免费网站| 日日操夜夜撸天天干| 啪啪啪18禁一区二区三区 | 久久精品在线观看一区二区| 欧美伊人久久大香线蕉综合| 欧美在线偷拍视频免费看| 北条麻妃av在线免费观看| 中文字幕,亚洲人妻| 欧美一区二区三区四区性视频| yellow在线播放av啊啊啊| 成人av免费不卡在线观看| 亚洲女人的天堂av| 一区二区在线观看少妇| 亚洲精品无码色午夜福利理论片| 午夜精品一区二区三区更新| eeuss鲁片一区二区三区| 亚洲国产精品久久久久久6| 亚洲Av无码国产综合色区| 在线观看视频 你懂的| 91欧美在线免费观看| 亚洲成人免费看电影| 午夜激情久久不卡一区二区| 污污小视频91在线观看| 最新的中文字幕 亚洲| 成人高清在线观看视频| 国产成人小视频在线观看无遮挡| 天堂av中文在线最新版| 青青青青爽手机在线| 国产精品久久久久久久精品视频| 中文字幕在线一区精品| 国产三级精品三级在线不卡| 香港一级特黄大片在线播放 | 无码精品一区二区三区人| 一色桃子人妻一区二区三区| 亚洲av日韩精品久久久久久hd| 亚洲午夜伦理视频在线| 午夜毛片不卡在线看| 欧美久久一区二区伊人| 男生舔女生逼逼视频| 美女张开腿让男生操在线看| av日韩在线观看大全| 亚洲精品在线资源站| 天天操天天爽天天干| 青娱乐极品视频青青草| 国内精品在线播放第一页| 精品区一区二区三区四区人妻| 日韩欧美一级黄片亚洲| gay gay男男瑟瑟在线网站| 人妻久久无码中文成人| 欧美久久一区二区伊人| 欧洲日韩亚洲一区二区三区| av亚洲中文天堂字幕网| 欧美日韩v中文在线| 欧美爆乳肉感大码在线观看| 日韩精品电影亚洲一区| 18禁污污污app下载| 97国产在线av精品| 成人精品在线观看视频| 国产精品探花熟女在线观看| 欧美偷拍亚洲一区二区| 精品美女久久久久久| 日本熟妇丰满厨房55| 亚洲1卡2卡三卡4卡在线观看| 亚洲综合在线视频可播放| 极品性荡少妇一区二区色欲| 国产黄网站在线观看播放| 国产97在线视频观看| 日本熟妇一区二区x x| 欧美激情精品在线观看| 天天操天天插天天色| 国产免费高清视频视频| 日本黄在免费看视频| 日本av在线一区二区三区| av老司机精品在线观看| 欧美 亚洲 另类综合| 青青草在观免费国产精品| 天堂av在线播放免费| 最新91九色国产在线观看| 香蕉91一区二区三区| 亚洲中文精品人人免费| 亚洲男人的天堂a在线| 国产高清97在线观看视频| nagger可以指黑人吗| 欧美韩国日本国产亚洲| 伊人日日日草夜夜草| 一二三中文乱码亚洲乱码one| 欧美偷拍亚洲一区二区| 久久99久久99精品影院| 午夜免费体验区在线观看| 久久机热/这里只有| 免费黄色成人午夜在线网站| 青青青激情在线观看视频| 黄工厂精品视频在线观看| 特一级特级黄色网片| 成年午夜免费无码区| 欧美日韩国产一区二区三区三州 | 国产黄色高清资源在线免费观看| 国产亚州色婷婷久久99精品| 欧美精品免费aaaaaa| 日曰摸日日碰夜夜爽歪歪| okirakuhuhu在线观看| 99久久超碰人妻国产| 无忧传媒在线观看视频| 欧美伊人久久大香线蕉综合| 欧美精品一区二区三区xxxx| 欧美日本国产自视大全| 少妇与子乱在线观看| 亚洲1卡2卡三卡4卡在线观看 | 在线免费观看欧美小视频| 亚洲av日韩av第一区二区三区| 国产chinesehd精品麻豆| 99精品国自产在线人| 国产精品熟女久久久久浪潮| 77久久久久国产精产品| 2012中文字幕在线高清| 国产精品熟女久久久久浪潮| 麻豆精品成人免费视频| 中文 成人 在线 视频| 日韩中文字幕精品淫| 在线观看操大逼视频| 亚洲一区制服丝袜美腿| 黄色资源视频网站日韩| 日本欧美视频在线观看三区| 国产清纯美女al在线| 人妻熟女在线一区二区 | 国产成人无码精品久久久电影| 天天干天天操天天插天天日| 绝顶痉挛大潮喷高潮无码| 欧美性感尤物人妻在线免费看 | 91在线视频在线精品3| 亚洲无线观看国产高清在线| 一级a看免费观看网站| 天天日天天干天天插舔舔| 蜜桃臀av蜜桃臀av| 女蜜桃臀紧身瑜伽裤| 日韩一区二区三区三州| 1024久久国产精品| 成人av免费不卡在线观看| 中文字幕熟女人妻久久久| 午夜成午夜成年片在线观看| 香港一级特黄大片在线播放| 欲满人妻中文字幕在线| 真实国模和老外性视频| 中文字幕无码日韩专区免费| 在线播放国产黄色av| 2020久久躁狠狠躁夜夜躁 | 国产精品熟女久久久久浪潮| 国产白袜脚足J棉袜在线观看| 黄色三级网站免费下载| 天堂资源网av中文字幕| 久久久久久97三级| 成年人午夜黄片视频资源| 天天射,天天操,天天说| 91精品国产麻豆国产| 中文字幕在线第一页成人 | 久久久人妻一区二区| 老鸭窝日韩精品视频观看| 视频 国产 精品 熟女 | 欧美视频中文一区二区三区| 看一级特黄a大片日本片黑人| 欧美香蕉人妻精品一区二区| 美女av色播在线播放| 欧美80老妇人性视频| 天天日天天玩天天摸| 啊慢点鸡巴太大了啊舒服视频| 特级欧美插插插插插bbbbb| 国产精品视频一区在线播放| 亚洲av一妻不如妾| 91精品激情五月婷婷在线| 100%美女蜜桃视频| 天天射夜夜操综合网| 亚洲最大免费在线观看| 国产高清在线在线视频| 丰满少妇翘臀后进式| 亚洲成人午夜电影在线观看| 国产视频一区在线观看| 欧美精品国产综合久久| 超级福利视频在线观看| 五十路熟女人妻一区二| 51国产成人精品视频| 中文字幕—97超碰网| 伊人情人综合成人久久网小说| 美日韩在线视频免费看| 一色桃子人妻一区二区三区| 久久精品久久精品亚洲人| 青青草亚洲国产精品视频| 最新97国产在线视频| 日韩视频一区二区免费观看| 久久久久久国产精品| 日本少妇高清视频xxxxx| weyvv5国产成人精品的视频| 青青青爽视频在线播放| 99的爱精品免费视频| 风流唐伯虎电视剧在线观看| 女同互舔一区二区三区| 一区二区三区精品日本| 青青青青视频在线播放| 国产亚洲四十路五十路| av在线免费观看亚洲天堂| 亚洲人妻国产精品综合| 亚洲成人精品女人久久久| 75国产综合在线视频| 日日操夜夜撸天天干| 大骚逼91抽插出水视频| 六月婷婷激情一区二区三区| 瑟瑟视频在线观看免费视频| 最近中文字幕国产在线| 久久久久久97三级| 天天爽夜夜爽人人爽QC| 成人在线欧美日韩国产| 成熟丰满熟妇高潮xx×xx| 66久久久久久久久久久| 国产真实乱子伦a视频| 亚洲av日韩精品久久久| 天天操天天干天天日狠狠插| free性日本少妇| 狠狠躁狠狠爱网站视频| 青青青aaaa免费| 精品少妇一二三视频在线| 欧美日韩高清午夜蜜桃大香蕉| 农村胖女人操逼视频| 欧美日韩熟女一区二区三区| 精品首页在线观看视频| 日本韩国在线观看一区二区| 青娱乐极品视频青青草| 欧洲欧美日韩国产在线| 国产一级精品综合av| 大香蕉玖玖一区2区| 欧美视频一区免费在线| 又粗又长 明星操逼小视频 | 97人妻总资源视频| 久久三久久三久久三久久| 天美传媒mv视频在线观看| 天天干天天日天天谢综合156| 任你操任你干精品在线视频| 91人妻精品久久久久久久网站| 色狠狠av线不卡香蕉一区二区| 中文字幕日本人妻中出| 国产成人精品午夜福利训2021| 日曰摸日日碰夜夜爽歪歪| 黄色无码鸡吧操逼视频| 少妇ww搡性bbb91| 蜜桃臀av蜜桃臀av| 久久久久久久精品成人热| 337p日本大胆欧美人| 在线网站你懂得老司机| 中文字幕在线观看极品视频| 天天日天天干天天爱| 日曰摸日日碰夜夜爽歪歪| 直接能看的国产av| 国产又大又黄免费观看| av手机免费在线观看高潮| 青青青青视频在线播放| 青草久久视频在线观看| 日韩欧美一级精品在线观看| 毛茸茸的大外阴中国视频| 五月天久久激情视频| 最新日韩av传媒在线| 一本一本久久a久久精品综合不卡| 日日操夜夜撸天天干| 中文字幕高清资源站| 天天操天天弄天天射| 在线观看911精品国产 | 黄色大片男人操女人逼| 亚洲国产中文字幕啊啊啊不行了 | 日韩特级黄片高清在线看| 婷婷色国产黑丝少妇勾搭AV| 蜜桃精品久久久一区二区| 日本中文字幕一二区视频| 久久99久久99精品影院| 精品一线二线三线日本| 直接能看的国产av| 女同互舔一区二区三区| 啊啊好大好爽啊啊操我啊啊视频 | 2017亚洲男人天堂| 国产白嫩美女一区二区| av森泽佳奈在线观看| www,久久久,com| 888欧美视频在线| 75国产综合在线视频| 亚洲欧美激情中文字幕| 黄色成年网站午夜在线观看| 精品美女久久久久久| 2022国产精品视频| 国产精品久久9999| 午夜久久香蕉电影网| 青青草原色片网站在线观看| 国产麻豆精品人妻av| 日日日日日日日日夜夜夜夜夜夜| 亚洲天堂精品久久久| 大鸡巴操b视频在线| 手机看片福利盒子日韩在线播放| 99热碰碰热精品a中文| 天天射,天天操,天天说| 日韩影片一区二区三区不卡免费 | 免费大片在线观看视频网站| 日韩精品二区一区久久| 精品av久久久久久久| 影音先锋女人av噜噜色| 91极品新人『兔兔』精品新作| 亚洲一区自拍高清免费视频| 黑人进入丰满少妇视频| 亚洲精品 日韩电影| 日韩美女综合中文字幕pp| chinese国产盗摄一区二区| 欧美一区二区三区啪啪同性| 搞黄色在线免费观看| 狠狠操狠狠操免费视频| 国产精品一二三不卡带免费视频| 人人妻人人澡欧美91精品| 1024久久国产精品| 另类av十亚洲av| 国产清纯美女al在线| 日本av熟女在线视频| 亚洲国产美女一区二区三区软件| 欧美视频综合第一页| 欧美日本国产自视大全| 99婷婷在线观看视频| 韩国爱爱视频中文字幕| 99re6热在线精品| 日韩在线视频观看有码在线| 亚洲va欧美va人人爽3p| 日本高清在线不卡一区二区| 日韩亚洲高清在线观看| 日本在线不卡免费视频| 黑人3p华裔熟女普通话| 久久久久久久久久性潮| 国产成人精品一区在线观看| 男生用鸡操女生视频动漫| 黑人巨大的吊bdsm| 91精品啪在线免费| 亚洲 图片 欧美 图片| 免费在线播放a级片| 久久精品36亚洲精品束缚| 在线不卡成人黄色精品| 天堂av在线播放免费| 免费看美女脱光衣服的视频| 任你操视频免费在线观看| 狍和女人的王色毛片| 日韩国产乱码中文字幕| 欧美色呦呦最新网址| av天堂中文免费在线| 日本成人不卡一区二区| 欧美一级色视频美日韩| 丁香花免费在线观看中文字幕| 中文字幕一区二区亚洲一区| 男人操女人逼逼视频网站| 中文字幕一区二区人妻电影冢本| 天天干狠狠干天天操| 亚洲国产40页第21页| 中国视频一区二区三区| 日本午夜爽爽爽爽爽视频在线观看 | 亚洲综合乱码一区二区| 国产不卡av在线免费| 欧美男同性恋69视频| 蜜桃专区一区二区在线观看| 日美女屁股黄邑视频| 11久久久久久久久久久| 亚洲高清一区二区三区视频在线| 成人影片高清在线观看| 亚洲欧美综合另类13p| yellow在线播放av啊啊啊| 天天做天天干天天操天天射| 在线免费观看日本伦理| 93人妻人人揉人人澡人人| 中国产一级黄片免费视频播放| 少妇人妻二三区视频| 亚洲欧美激情中文字幕| 98视频精品在线观看| 嫩草aⅴ一区二区三区| 亚洲精品三级av在线免费观看| 黄页网视频在线免费观看| 美女少妇亚洲精选av| 国产黄色高清资源在线免费观看| 九一传媒制片厂视频在线免费观看| 青青草亚洲国产精品视频| www日韩毛片av| 综合页自拍视频在线播放| 天天日天天日天天擦| 国产janese在线播放| 动漫黑丝美女的鸡巴| 曰本无码人妻丰满熟妇啪啪| 欧美黑人性暴力猛交喷水| 五十路av熟女松本翔子| 午夜福利人人妻人人澡人人爽| 日本午夜爽爽爽爽爽视频在线观看| 阿v天堂2014 一区亚洲| 播放日本一区二区三区电影| 日韩午夜福利精品试看| 免费一级特黄特色大片在线观看 | 日本高清在线不卡一区二区| 强行扒开双腿猛烈进入免费版 | 不戴胸罩引我诱的隔壁的人妻| 区一区二区三国产中文字幕| 日韩欧美中文国产在线| 黄色片黄色片wyaa| 亚洲一区二区三区偷拍女厕91 | 岛国青草视频在线观看| av完全免费在线观看av| 天天摸天天干天天操科普| 青草青永久在线视频18| 夜夜骑夜夜操夜夜奸| 啊啊好慢点插舔我逼啊啊啊视频 | 天堂中文字幕翔田av| 91p0rny九色露脸熟女| 欧美一区二区三区在线资源| 亚洲av日韩精品久久久久久hd| 成年人该看的视频黄免费| 夜夜嗨av一区二区三区中文字幕| 欧美怡红院视频在线观看| 激情色图一区二区三区| 亚洲特黄aaaa片| 国产日韩欧美美利坚蜜臀懂色| 日本又色又爽又黄又粗| yy6080国产在线视频| 国产内射中出在线观看| 自拍偷拍日韩欧美一区二区| 欧美国产亚洲中英文字幕| 老司机你懂得福利视频| 美女福利视频网址导航| 无码日韩人妻精品久久| 制服丝袜在线人妻中文字幕| 国产在线拍揄自揄视频网站| 99精品国产自在现线观看| 在线观看一区二区三级| 欧美va亚洲va天堂va| 亚洲成人三级在线播放 | 在线观看欧美黄片一区二区三区 | 黄色视频在线观看高清无码 | 直接能看的国产av| 国产污污污污网站在线| aiss午夜免费视频| 中文字幕一区二区亚洲一区| 三级黄色亚洲成人av| 久久精品国产23696| 国产夫妻视频在线观看免费| brazzers欧熟精品系列| 98精产国品一二三产区区别| 青青草原色片网站在线观看| 视频啪啪啪免费观看| 都市家庭人妻激情自拍视频| 护士特殊服务久久久久久久| 欧美久久一区二区伊人| 中国黄色av一级片| 欧美精品国产综合久久| 免费手机黄页网址大全| 夏目彩春在线中文字幕| 欧美激情电影免费在线| 又粗又长 明星操逼小视频| 亚洲av极品精品在线观看| 日本午夜爽爽爽爽爽视频在线观看 | 五月精品丁香久久久久福利社| 亚洲免费va在线播放| 青青青青在线视频免费观看| 色偷偷伊人大杳蕉综合网| 99精品免费久久久久久久久a| 天天操天天干天天艹| 欧洲精品第一页欧洲精品亚洲| 大肉大捧一进一出好爽在线视频| 成人激情文学网人妻| 又粗又长 明星操逼小视频 | 亚洲视频在线观看高清| 久久久精品999精品日本| 免费黄页网站4188| 少妇系列一区二区三区视频| 操操网操操伊剧情片中文字幕网| 亚洲国产精品美女在线观看| 亚洲嫩模一区二区三区| 精品国产午夜视频一区二区| 亚洲午夜福利中文乱码字幕| 三上悠亚和黑人665番号| 中文字幕在线乱码一区二区 | 国产剧情演绎系列丝袜高跟| 国产亚洲成人免费在线观看| 国产亚洲四十路五十路| 国产精品国产三级国产午| 天天日天天天天天天天天天天| 日韩a级精品一区二区| 中文字幕在线免费第一页| 综合一区二区三区蜜臀| 色噜噜噜噜18禁止观看| 特一级特级黄色网片| 在线观看的a站 最新| 欧美一区二区三区乱码在线播放| 亚洲日本一区二区久久久精品| 91国内精品自线在拍白富美| 亚洲 色图 偷拍 欧美| 午夜美女少妇福利视频| 日本人妻欲求不满中文字幕| 中文字幕高清免费在线人妻| 亚洲精品色在线观看视频| 天堂av中文在线最新版| 精品国产成人亚洲午夜| 免费观看国产综合视频| 午夜精品在线视频一区| 久久精品在线观看一区二区| 久久艹在线观看视频| 中文字幕中文字幕人妻| 特黄老太婆aa毛毛片| 熟妇一区二区三区高清版| 日本av熟女在线视频| 久久丁香花五月天色婷婷| 亚洲成av人无码不卡影片一| 视频一区二区在线免费播放| 最近中文2019年在线看| 777奇米久久精品一区| 亚洲中文字幕国产日韩| 亚洲粉嫩av一区二区三区| 青青在线视频性感少妇和隔壁黑丝| 中文字日产幕乱六区蜜桃| 偷拍自拍国产在线视频| 天堂中文字幕翔田av| 亚洲嫩模一区二区三区| 欧美日韩中文字幕欧美| 在线免费观看靠比视频的网站| 免费av岛国天堂网站| 欧美熟妇一区二区三区仙踪林| 韩国爱爱视频中文字幕| 亚洲免费福利一区二区三区| 青青青青青免费视频| 98视频精品在线观看| 日本xx片在线观看| 青草久久视频在线观看| 欧美日韩一区二区电影在线观看 | 欧美视频综合第一页| 午夜福利人人妻人人澡人人爽| 一色桃子人妻一区二区三区| 国产片免费观看在线观看| 欧美日韩精品永久免费网址 | 亚洲午夜电影之麻豆| 玖玖一区二区在线观看| 国产日本精品久久久久久久| 熟女人妻一区二区精品视频| 成年人啪啪视频在线观看| 人妻丰满熟妇综合网| 国产精品大陆在线2019不卡| 福利在线视频网址导航 | 无码中文字幕波多野不卡| 色综合天天综合网国产成人| 韩国黄色一级二级三级| av一本二本在线观看| 1000部国产精品成人观看视频 | 青草久久视频在线观看| 揄拍成人国产精品免费看视频| heyzo蜜桃熟女人妻| 夜夜骑夜夜操夜夜奸| 91色九色porny| 亚洲av日韩精品久久久| 国产精品入口麻豆啊啊啊| 欧美一区二区三区激情啪啪啪| 热99re69精品8在线播放| 天天日天天玩天天摸| 在线观看av2025| 99re国产在线精品| 高清一区二区欧美系列| 不卡日韩av在线观看| 亚洲欧美另类手机在线 | 青青青国产片免费观看视频| 天天操天天弄天天射| 亚洲国产美女一区二区三区软件 | 青青草在观免费国产精品| 人人妻人人爱人人草| 亚洲熟女久久久36d| 一区二区视频视频视频| 插小穴高清无码中文字幕| 亚洲区欧美区另类最新章节| 免费一级特黄特色大片在线观看 | 国产日韩精品一二三区久久久| 粉嫩欧美美人妻小视频| 亚洲av午夜免费观看| 在线观看免费视频色97| 美女大bxxxx内射| 婷婷久久一区二区字幕网址你懂得| 大白屁股精品视频国产| 日本在线不卡免费视频| 午夜大尺度无码福利视频 | 中文字幕人妻av在线观看| 97人妻总资源视频| 一区二区三区日韩久久| 亚洲精品麻豆免费在线观看| 中文字幕一区二区亚洲一区| 秋霞午夜av福利经典影视| 国产精品一区二区av国| 欧美精品亚洲精品日韩在线| 2020久久躁狠狠躁夜夜躁| 亚洲无线观看国产高清在线| 黄色黄色黄片78在线| 日本少妇人妻xxxxxhd| 日本美女性生活一级片| 天天操天天弄天天射| 日韩中文字幕在线播放第二页 | 夜夜骑夜夜操夜夜奸| 偷拍自拍视频图片免费| 美女视频福利免费看| 亚洲av色香蕉一区二区三区| 国产露脸对白在线观看| 人妻熟女中文字幕aⅴ在线| 国产极品精品免费视频 | 一区二区三区在线视频福利| 97国产在线观看高清| 久草视频在线免播放| 成年人黄色片免费网站| 亚洲一区二区三区精品视频在线| 91大屁股国产一区二区| 亚洲精品国品乱码久久久久 | 亚洲一区二区三区uij| 精品一区二区三区三区色爱| 日韩近亲视频在线观看| 国产一线二线三线的区别在哪| 亚洲日产av一区二区在线| 国产日韩精品一二三区久久久| 一区二区三区日韩久久| 欧美久久一区二区伊人| 久久午夜夜伦痒痒想咳嗽P| 日韩精品一区二区三区在线播放| 免费一级特黄特色大片在线观看 | 欧洲黄页网免费观看| 国产一区二区欧美三区| 日韩欧美高清免费在线| 成年午夜免费无码区| 亚洲va国产va欧美va在线| av一本二本在线观看| 国产麻豆精品人妻av| 日韩精品一区二区三区在线播放| 国产成人小视频在线观看无遮挡| 一区二区三区四区视频在线播放| 视频啪啪啪免费观看| 日韩国产乱码中文字幕| 精品首页在线观看视频| 欧美性受xx黑人性猛交| 51国产偷自视频在线播放| 无码国产精品一区二区高潮久久4| 熟女视频一区,二区,三区| 狠狠躁夜夜躁人人爽天天天天97| 亚洲最大免费在线观看| 亚洲一级 片内射视正片| 97成人免费在线观看网站| 日本特级片中文字幕| 91国内精品久久久久精品一| 欧美亚洲中文字幕一区二区三区| 毛片一级完整版免费| 日韩二区视频一线天婷婷五| 青青青青青手机视频| 骚逼被大屌狂草视频免费看| 一区二区视频在线观看视频在线| 成人综合亚洲欧美一区| lutube在线成人免费看| 操的小逼流水的文章| 亚洲变态另类色图天堂网| 99久久成人日韩欧美精品| 亚洲区美熟妇久久久久| av日韩在线观看大全| 91亚洲国产成人精品性色| 亚洲精品在线资源站| 福利片区一区二体验区| 夜色撩人久久7777| 免费看国产av网站| 欧美亚洲牲夜夜综合久久| 男生用鸡操女生视频动漫| 人妻素人精油按摩中出| 国产妇女自拍区在线观看| 在线观看国产网站资源| 大鸡吧插逼逼视频免费看| 伊拉克及约旦宣布关闭领空| 精品一区二区三区三区色爱| 中文字幕综合一区二区| 97精品综合久久在线| 日本性感美女视频网站| 一区国内二区日韩三区欧美| 亚洲视频在线视频看视频在线| av天堂中文免费在线| 任你操视频免费在线观看| 欧美日韩熟女一区二区三区| 夜夜骑夜夜操夜夜奸| 国产清纯美女al在线| 亚洲av色香蕉一区二区三区| 国产黑丝高跟鞋视频在线播放 | 91久久人澡人人添人人爽乱| 成人福利视频免费在线| 韩国爱爱视频中文字幕| 黄色大片男人操女人逼| 福利片区一区二体验区| 国产熟妇一区二区三区av| 青青操免费日综合视频观看| 日韩av有码中文字幕| 夜鲁夜鲁狠鲁天天在线| 91精品激情五月婷婷在线| 2022国产精品视频| 女同久久精品秋霞网| 欧美另类z0z变态| 青青青青青免费视频| 骚逼被大屌狂草视频免费看| 日韩美女福利视频网| 人人在线视频一区二区| 亚洲午夜电影之麻豆| 天天干天天操天天插天天日| 青青草视频手机免费在线观看| 亚洲一区二区三区uij| 亚洲欧美激情国产综合久久久| 亚洲av色香蕉一区二区三区| 国产janese在线播放| 免费十精品十国产网站| 搞黄色在线免费观看| 一区二区三区另类在线| 人人妻人人爱人人草| 超碰97人人做人人爱| 在线观看av亚洲情色| 亚洲1区2区3区精华液| 青青草视频手机免费在线观看| 亚洲欧美另类自拍偷拍色图| 中国老熟女偷拍第一页| 又色又爽又黄又刺激av网站| 最新国产精品网址在线观看| 在线观看免费视频网| 少妇与子乱在线观看| 亚洲成人国产av在线| chinese国产盗摄一区二区| 端庄人妻堕落挣扎沉沦| 亚洲精品无码久久久久不卡 | 大鸡巴操娇小玲珑的女孩逼| 91在线视频在线精品3| 亚洲一区二区三区精品视频在线 | 福利在线视频网址导航 | 喷水视频在线观看这里只有精品| 国产日韩欧美视频在线导航| 国产精品国产三级麻豆| 98视频精品在线观看| 国产一区二区视频观看| 91免费观看在线网站| 亚洲最大免费在线观看| 无忧传媒在线观看视频| 9色精品视频在线观看| 超碰97免费人妻麻豆| 91精品激情五月婷婷在线| 超碰在线中文字幕一区二区| 亚洲1区2区3区精华液| 老鸭窝日韩精品视频观看| 青青操免费日综合视频观看| 亚洲高清一区二区三区视频在线| 一区二区在线视频中文字幕| 国产av福利网址大全| 国产午夜激情福利小视频在线| 99精品亚洲av无码国产另类| 欧美一区二区三区乱码在线播放 | 9久在线视频只有精品| 日日夜夜大香蕉伊人| 中文字幕一区二区三区人妻大片 | gav成人免费播放| 男人天堂色男人av| 啪啪啪啪啪啪啪啪av| av俺也去在线播放| av男人天堂狠狠干| 夜鲁夜鲁狠鲁天天在线| 人人妻人人澡欧美91精品| gogo国模私拍视频| 国产九色91在线视频| 亚洲另类综合一区小说| 高潮视频在线快速观看国家快速| 天天干天天搞天天摸| 亚洲午夜电影之麻豆| 国产午夜激情福利小视频在线| 欲乱人妻少妇在线视频裸| 欧美精品亚洲精品日韩在线| 日本少妇在线视频大香蕉在线观看 | 五十路丰满人妻熟妇| 在线国产精品一区二区三区| 精品视频一区二区三区四区五区 | 久久精品视频一区二区三区四区 | 亚洲一区二区三区av网站| 亚洲欧美激情人妻偷拍| 亚洲综合另类精品小说| 国产一区二区视频观看| 亚洲在线一区二区欧美| 国产黄色片蝌蚪九色91| 在线观看av2025| 99热色原网这里只有精品| 国产高清女主播在线| 亚洲国产美女一区二区三区软件| 无码精品一区二区三区人| 亚洲一级av无码一级久久精品| 97小视频人妻一区二区| 偷偷玩弄新婚人妻h视频| 日韩二区视频一线天婷婷五| 亚洲欧美激情中文字幕| 午夜免费观看精品视频| 国产一级精品综合av| 国产aⅴ一线在线观看| 青青青青青青青青青青草青青| 老司机免费视频网站在线看| 99久久99久国产黄毛片| 91九色国产熟女一区二区| 插逼视频双插洞国产操逼插洞| 国产精品sm调教视频| 宅男噜噜噜666免费观看| 日韩人妻xxxxx| 日本免费一级黄色录像| 美女日逼视频免费观看| 日本一本午夜在线播放| 久久国产精品精品美女| 日本一区精品视频在线观看| 老司机免费视频网站在线看| 色97视频在线播放| 中文字幕最新久久久| 欧美一区二区三区久久久aaa| 人妻另类专区欧美制服| 亚洲熟女女同志女同| 婷婷综合亚洲爱久久| 久久久久91精品推荐99| 国产一区二区三免费视频 | 成年人的在线免费视频| 亚洲一区二区三区在线高清| av在线免费资源站| 熟妇一区二区三区高清版| 人妻凌辱欧美丰满熟妇| 五十路息与子猛烈交尾视频| 888欧美视频在线| 开心 色 六月 婷婷| aⅴ精产国品一二三产品| 一区二区三区美女毛片| 99精品一区二区三区的区| 大香蕉伊人中文字幕| 性色av一区二区三区久久久| 欧美精品免费aaaaaa| 亚洲 欧美 精品 激情 偷拍| 91‖亚洲‖国产熟女| 十八禁在线观看地址免费 | 中国熟女一区二区性xx| 日韩加勒比东京热二区| 国产熟妇人妻ⅹxxxx麻豆| 日韩一个色综合导航| 91she九色精品国产| 高潮喷水在线视频观看| 国产熟妇一区二区三区av| 99热99re在线播放| 一色桃子人妻一区二区三区| 国产精品成人xxxx| 天天操夜夜操天天操天天操| 亚洲男人在线天堂网| 经典av尤物一区二区| 日本在线不卡免费视频| 亚洲天堂第一页中文字幕| 国产在线免费观看成人| 91老师蜜桃臀大屁股| 成人蜜桃美臀九一一区二区三区| 国产午夜亚洲精品麻豆| 成人av亚洲一区二区| 92福利视频午夜1000看| 色偷偷伊人大杳蕉综合网| 青青伊人一精品视频| 蜜桃臀av蜜桃臀av| 欧美xxx成人在线| 中文字幕欧美日韩射射一| 日噜噜噜夜夜噜噜噜天天噜噜噜| 宅男噜噜噜666国产| 国产精品入口麻豆啊啊啊| 人人在线视频一区二区| 免费黄页网站4188| 人人妻人人爱人人草| 人妻少妇亚洲精品中文字幕| 久久久久久cao我的性感人妻| 一级A一级a爰片免费免会员| 99热久久这里只有精品| 日本熟妇色熟妇在线观看| 女同性ⅹxx女同hd| 免费黄色成人午夜在线网站| 亚洲另类综合一区小说| 欧美国品一二三产区区别 | 久久久久久9999久久久久| 经典亚洲伊人第一页| 精品一区二区三区在线观看| 中文字幕高清免费在线人妻| 日韩熟女系列一区二区三区| 免费岛国喷水视频在线观看 | 精品美女在线观看视频在线观看| 欧美性感尤物人妻在线免费看| 国产亚洲成人免费在线观看 | 大鸡巴操b视频在线| 成年人啪啪视频在线观看| av在线shipin| 亚洲精品麻豆免费在线观看 | 欧美3p在线观看一区二区三区| 欧美精品黑人性xxxx| 成年人黄视频在线观看| 99热99re在线播放| av成人在线观看一区| 亚洲中文精品人人免费| 精品国产乱码一区二区三区乱| 国产97视频在线精品| 一级黄色av在线观看| 少妇高潮一区二区三区| 视频在线亚洲一区二区| 中文字幕无码一区二区免费| 社区自拍揄拍尻屁你懂的| 日本性感美女三级视频| 丝袜长腿第一页在线| 亚洲午夜电影之麻豆| 91高清成人在线视频| 日韩欧美一级黄片亚洲| 久久久久久97三级| 99久久99久国产黄毛片| 国产精品视频欧美一区二区| 51精品视频免费在线观看| 都市激情校园春色狠狠| 偷拍自拍亚洲美腿丝袜| 2020中文字幕在线播放| av手机在线免费观看日韩av| 老司机你懂得福利视频| 九色porny九色9l自拍视频| 93人妻人人揉人人澡人人| 在线视频精品你懂的| 大胆亚洲av日韩av| 美女被肏内射视频网站| 天天操天天干天天艹| 天天操夜夜骑日日摸| 好太好爽好想要免费| 天天夜天天日天天日| 91九色国产熟女一区二区| 人妻少妇精品久久久久久 | 首之国产AV医生和护士小芳| 亚洲综合另类精品小说| 中国黄片视频一区91| 欧美专区第八页一区在线播放| 红杏久久av人妻一区| 中文字幕无码一区二区免费| 美女福利写真在线观看视频| 一区二区三区久久久91| 抽查舔水白紧大视频| 亚洲欧美色一区二区| 啊慢点鸡巴太大了啊舒服视频| 青青草原网站在线观看| 久草电影免费在线观看| 亚洲熟女综合色一区二区三区四区| 亚洲伊人av天堂有码在线| 国产女人露脸高潮对白视频| 亚洲公开视频在线观看| 国产女孩喷水在线观看| weyvv5国产成人精品的视频| 老熟妇xxxhd老熟女| 久久久麻豆精亚洲av麻花| 亚洲国产欧美国产综合在线| 在线视频精品你懂的| 91亚洲手机在线视频播放| 日韩精品一区二区三区在线播放| 亚洲一区二区三区精品乱码| 骚货自慰被发现爆操| 五十路熟女av天堂| 日本啪啪啪啪啪啪啪| 亚洲 色图 偷拍 欧美| 成人av中文字幕一区| 日韩中文字幕精品淫| 久久久人妻一区二区| 伊人综合aⅴ在线网| 日韩精品一区二区三区在线播放| 国产精品黄色的av| 国产精品成久久久久三级蜜臀av | 在线免费观看欧美小视频| 色婷婷精品大在线观看| 青青青青青青草国产| 国产在线观看免费人成短视频| 红杏久久av人妻一区| 美女av色播在线播放| 十八禁在线观看地址免费 | 亚洲精品福利网站图片| 日韩熟女系列一区二区三区| 无忧传媒在线观看视频| 亚洲一级特黄特黄黄色录像片| 任你操任你干精品在线视频| 免费观看理论片完整版| 二区中出在线观看老师| 午夜av一区二区三区| weyvv5国产成人精品的视频| 直接观看免费黄网站| 人人爽亚洲av人人爽av| 国产在线观看免费人成短视频| 国产亚州色婷婷久久99精品| 91天堂天天日天天操| 老司机免费福利视频网| 欧美亚洲免费视频观看| 成人av电影免费版| 久草电影免费在线观看| av在线免费资源站| 国产大鸡巴大鸡巴操小骚逼小骚逼| 久久精品国产999| 阿v天堂2014 一区亚洲| 亚洲av色香蕉一区二区三区| 大陆av手机在线观看| 亚洲一区二区久久久人妻| aiss午夜免费视频| 亚洲综合另类精品小说| 老师让我插进去69AV| 亚洲欧美国产麻豆综合| 在线国产日韩欧美视频| 成人久久精品一区二区三区| 国产精品久久久久久久精品视频| 超级碰碰在线视频免费观看| 午夜精品一区二区三区城中村| 午夜在线观看一区视频| 美女福利写真在线观看视频| 日韩人妻丝袜中文字幕| 福利午夜视频在线观看| 亚洲国产精品黑丝美女| 韩国男女黄色在线观看| 天天日天天干天天爱| 久久免费看少妇高潮完整版| 18禁污污污app下载| 人人爱人人妻人人澡39| 免费一级特黄特色大片在线观看| 77久久久久国产精产品| 91天堂天天日天天操| 日本午夜爽爽爽爽爽视频在线观看 | av在线免费观看亚洲天堂| 91极品新人『兔兔』精品新作| 成人影片高清在线观看| 最新国产亚洲精品中文在线| 国产精品久久久久网| 亚洲综合在线视频可播放| 免费黄高清无码国产| 精品少妇一二三视频在线| 国产精品成久久久久三级蜜臀av | 91九色porny国产蝌蚪视频| 成人av免费不卡在线观看| 黑人3p华裔熟女普通话| 欧美黑人性暴力猛交喷水| 国产成人精品一区在线观看 | 亚洲欧美另类自拍偷拍色图| 又色又爽又黄又刺激av网站| 久久久91蜜桃精品ad| 亚洲 图片 欧美 图片| 一区二区久久成人网| 国产一区二区神马久久| 班长撕开乳罩揉我胸好爽| 亚洲熟女女同志女同| 久久一区二区三区人妻欧美| 五十路老熟女码av| 亚洲中文字幕综合小综合| 天天操天天干天天日狠狠插| 韩国AV无码不卡在线播放| 韩国男女黄色在线观看| aiss午夜免费视频| 少妇高潮无套内谢麻豆| 国产黑丝高跟鞋视频在线播放| 97少妇精品在线观看| 美女张开腿让男生操在线看| 97资源人妻免费在线视频| 亚洲国产美女一区二区三区软件| 97人人妻人人澡人人爽人人精品| 亚洲高清国产自产av| av天堂资源最新版在线看| 国产精品入口麻豆啊啊啊| 色综合色综合色综合色| 成年人啪啪视频在线观看| 大香蕉伊人中文字幕| 久久久久久9999久久久久| 亚洲综合在线观看免费| 女人精品内射国产99| 国产在线免费观看成人| 夏目彩春在线中文字幕| 男生舔女生逼逼视频| 天天日天天添天天爽| 人妻久久无码中文成人| 天天综合天天综合天天网| 少妇人妻二三区视频| 91麻豆精品久久久久| eeuss鲁片一区二区三区| 岛国黄色大片在线观看| 国产福利小视频大全| 蜜臀av久久久久蜜臀av麻豆| 夜女神免费福利视频| 午夜精品久久久久麻豆影视| 久久机热/这里只有| japanese五十路熟女熟妇| 精品黑人巨大在线一区| 一区二区视频视频视频| 日韩欧美在线观看不卡一区二区| 天天射,天天操,天天说| 亚洲欧美一区二区三区电影| 91av精品视频在线| 一区二区三区美女毛片| 国产福利在线视频一区| 欧美一区二区三区在线资源| 亚洲一区二区三区在线高清| 偷拍美女一区二区三区| 日本一二三中文字幕| 99精品国产aⅴ在线观看| 欧美伊人久久大香线蕉综合| 中文字幕日本人妻中出| 不卡一不卡二不卡三| 成人高潮aa毛片免费| 久久这里只有精品热视频| 国产激情av网站在线观看| 国产精品久久久久久久久福交| av完全免费在线观看av| 亚洲 清纯 国产com| 亚洲一区二区三区久久午夜| 亚洲中文字幕人妻一区| 人妻少妇一区二区三区蜜桃| 亚洲av无女神免非久久| 国产视频网站国产视频| aⅴ五十路av熟女中出| 少妇露脸深喉口爆吞精| 夜女神免费福利视频| 亚洲av香蕉一区区二区三区犇| 在线观看av2025| 黑人巨大精品欧美视频| 91chinese在线视频| 色综合天天综合网国产成人| 75国产综合在线视频| 真实国模和老外性视频| 大香蕉伊人国产在线| 天天操天天干天天插| 国产精品久久久久久久久福交 | 婷婷色中文亚洲网68| 青青青青青青青青青青草青青 | 亚洲中文字幕综合小综合| 99精品免费久久久久久久久a| 99久久超碰人妻国产| 国产精品国产三级国产午| 一区二区三区久久久91| 91国内精品自线在拍白富美| 青娱乐极品视频青青草| 中文字幕在线第一页成人| 国产精品久久久久久久久福交| 欧美精产国品一二三产品区别大吗| 最新的中文字幕 亚洲| 黄色无码鸡吧操逼视频| 91成人在线观看免费视频| 天天想要天天操天天干| 9国产精品久久久久老师| 青草久久视频在线观看| 天天日夜夜操天天摸| 欧洲精品第一页欧洲精品亚洲| 成人av天堂丝袜在线观看| 日韩美女精品视频在线观看网站| 亚洲欧美国产综合777| 亚洲人妻30pwc| 美女福利视频网址导航| 99久久激情婷婷综合五月天| av在线免费观看亚洲天堂| 欧美久久久久久三级网| 福利午夜视频在线合集| 欧美aa一级一区三区四区| 班长撕开乳罩揉我胸好爽| 一区二区三区另类在线| 又粗又长 明星操逼小视频| 亚洲欧美成人综合视频| 欧美精品黑人性xxxx| 成人国产影院在线观看| 国产一级麻豆精品免费| 成熟熟女国产精品一区| 日本中文字幕一二区视频| 中文字幕1卡1区2区3区| 最新中文字幕免费视频| 青青青青爽手机在线| 77久久久久国产精产品| 午夜精品亚洲精品五月色| 亚洲天堂成人在线观看视频网站| 2020韩国午夜女主播在线| 99热久久极品热亚洲| 免费观看污视频网站| av中文字幕网址在线| 97精品人妻一区二区三区精品| 午夜免费观看精品视频| 2021天天色天天干| 人妻在线精品录音叫床| 老熟妇凹凸淫老妇女av在线观看| 日韩北条麻妃一区在线| 久久人人做人人妻人人玩精品vr| 国产精彩对白一区二区三区| 国产性色生活片毛片春晓精品| 日韩欧美亚洲熟女人妻| 亚洲国产成人最新资源| 亚洲成人三级在线播放| 人人妻人人澡欧美91精品| 欧美日本国产自视大全| 亚洲第一伊人天堂网| 女同久久精品秋霞网| 深田咏美亚洲一区二区| 久久久久久久精品老熟妇| 在线观看视频污一区| av高潮迭起在线观看| 青草亚洲视频在线观看| 自拍偷拍日韩欧美亚洲| 日韩欧美制服诱惑一区在线| 成熟丰满熟妇高潮xx×xx| 伊人网中文字幕在线视频| 黄片三级三级三级在线观看| 边摸边做超爽毛片18禁色戒| 91精品国产麻豆国产| 国产97在线视频观看| 天天操天天干天天艹| 91精品国产综合久久久蜜 | 国产美女一区在线观看| 伊人成人综合开心网| 亚洲成a人片777777| 青娱乐蜜桃臀av色| 岛国av高清在线成人在线| 欧美男人大鸡吧插女人视频| 亚洲欧美久久久久久久久| 亚洲国产欧美一区二区三区久久 | 国产精品人久久久久久| sw137 中文字幕 在线| 黑人3p华裔熟女普通话| 日本高清撒尿pissing| 在线国产精品一区二区三区| 欧美亚洲免费视频观看| 亚洲精品在线资源站| 啊啊啊视频试看人妻| 欧美日韩熟女一区二区三区| 又粗又硬又猛又爽又黄的| 久久久久久久99精品| 午夜av一区二区三区 | 天天干天天日天天干天天操| 国产精品系列在线观看一区二区| 精品久久婷婷免费视频| 97年大学生大白天操逼| 亚洲无码一区在线影院| 青青草成人福利电影| 把腿张开让我插进去视频| 在线播放 日韩 av| 91福利在线视频免费观看| 91精品国产高清自在线看香蕉网| 欧美日韩精品永久免费网址| 啊慢点鸡巴太大了啊舒服视频| 久久麻豆亚洲精品av| 97成人免费在线观看网站| 日辽宁老肥女在线观看视频| 揄拍成人国产精品免费看视频| 亚洲欧美人精品高清| 免费一级特黄特色大片在线观看| 国产精品国色综合久久| 在线观看911精品国产| 在线视频这里只有精品自拍| 国产精彩福利精品视频| 国产亚洲视频在线二区| 欧美精品资源在线观看| 亚洲成人黄色一区二区三区 | 亚洲欧洲av天堂综合| 国产一区二区视频观看| 色婷婷综合激情五月免费观看| 免费看美女脱光衣服的视频| 91麻豆精品久久久久| 国产日韩av一区二区在线| 亚洲av色图18p| 中文字幕在线视频一区二区三区| 成人国产小视频在线观看| 日本熟女50视频免费| 中文字幕在线第一页成人| 成人国产影院在线观看| 亚洲va欧美va人人爽3p| 成人av电影免费版| 五月激情婷婷久久综合网| 天天干夜夜操啊啊啊| 日本中文字幕一二区视频| 欧美日韩一区二区电影在线观看| 久久久精品999精品日本| aⅴ五十路av熟女中出| 成年午夜免费无码区| 亚洲va国产va欧美va在线| 美女福利视频导航网站| av在线shipin| 超碰在线观看免费在线观看| 大鸡巴操b视频在线| 国产av一区2区3区| 亚洲欧美福利在线观看| 97国产在线av精品| 亚洲狠狠婷婷综合久久app | 中国把吊插入阴蒂的视频| 五十路息与子猛烈交尾视频| 蜜桃视频17c在线一区二区| 在线视频这里只有精品自拍| 日韩美女搞黄视频免费| 久草视频在线看免费| 91精品激情五月婷婷在线| 农村胖女人操逼视频| 欧美日韩不卡一区不区二区| 欧美特级特黄a大片免费| 黄网十四区丁香社区激情五月天| 欧洲国产成人精品91铁牛tv| 老有所依在线观看完整版| 激情小视频国产在线| 国产91久久精品一区二区字幕| 最新欧美一二三视频| 久久久久久久精品老熟妇| 18禁无翼鸟成人在线| 不戴胸罩引我诱的隔壁的人妻| 国产午夜激情福利小视频在线| 天天操天天污天天射| 精品乱子伦一区二区三区免费播| 日本在线不卡免费视频| 日韩近亲视频在线观看| 丝袜国产专区在线观看| 91麻豆精品传媒国产黄色片| 久久久麻豆精亚洲av麻花| 传媒在线播放国产精品一区| 国产夫妻视频在线观看免费| 88成人免费av网站| 大陆胖女人与丈夫操b国语高清| 亚洲av黄色在线网站| 日本美女性生活一级片| 亚洲嫩模一区二区三区| 日本阿v视频在线免费观看| 欧美黑人巨大性xxxxx猛交| 91免费福利网91麻豆国产精品| 天天日天天透天天操| eeuss鲁片一区二区三区| 亚洲偷自拍高清视频| 丝袜美腿欧美另类 中文字幕| 视频一区二区在线免费播放| 日韩精品电影亚洲一区| 欧美xxx成人在线| 国产91精品拍在线观看| 亚洲视频在线观看高清| 91久久综合男人天堂| 亚洲国产在人线放午夜| 涩爱综合久久五月蜜臀| 天天日天天做天天日天天做| 美女张开两腿让男人桶av| 亚洲男人在线天堂网| 福利片区一区二体验区| 国产va在线观看精品| 精品亚洲国产中文自在线| xxx日本hd高清| 888欧美视频在线| 在线免费观看欧美小视频| 97超碰人人搞人人| 日日爽天天干夜夜操| 久久久久久cao我的性感人妻| 成人激情文学网人妻 | 日本xx片在线观看| 欧美va不卡视频在线观看| 动色av一区二区三区| 五月婷婷在线观看视频免费| 欧美偷拍亚洲一区二区| 青青青青青免费视频| 99热99re在线播放| 蜜桃视频入口久久久| 国产亚洲精品品视频在线| 大鸡吧插逼逼视频免费看| 大白屁股精品视频国产| 欧美精品国产综合久久| 免费观看理论片完整版| 国产熟妇一区二区三区av| 亚洲国产第一页在线观看| 91高清成人在线视频| 国产之丝袜脚在线一区二区三区| 青青草人人妻人人妻| 日韩北条麻妃一区在线| 精品视频一区二区三区四区五区 | 色秀欧美视频第一页| av视屏免费在线播放| 夜色福利视频在线观看| 一区二区三区四区视频| 丰满熟女午夜福利视频| 不卡一不卡二不卡三| 四川乱子伦视频国产vip| 1024久久国产精品| 沙月文乃人妻侵犯中文字幕在线| 97超碰人人搞人人| 一级黄色av在线观看| 国产av一区2区3区| 99的爱精品免费视频| 久久精品亚洲国产av香蕉| 人妻久久久精品69系列| 在线免费观看国产精品黄色| 亚洲欧美自拍另类图片| 中文字幕中文字幕 亚洲国产| 日韩精品二区一区久久| 91自产国产精品视频| 91极品新人『兔兔』精品新作| 最新日韩av传媒在线| 中文字幕日韩无敌亚洲精品| 最新国产精品拍在线观看| 综合激情网激情五月天| 日本最新一二三区不卡在线| 久久h视频在线观看| 在线观看免费av网址大全| 国产91精品拍在线观看| 黄色资源视频网站日韩| 亚洲人人妻一区二区三区 | 国产精品视频一区在线播放| 阴茎插到阴道里面的视频| 日本一区二区三区免费小视频| 精品一区二区三区三区色爱| 精品亚洲中文字幕av| 中文字幕一区二区亚洲一区| 日本午夜福利免费视频| 少妇人妻久久久久视频黄片| 午夜青青草原网在线观看| 五月精品丁香久久久久福利社| 人妻无码中文字幕专区| 日美女屁股黄邑视频| 欧美精产国品一二三产品价格| 婷婷六月天中文字幕| 国产精品伦理片一区二区| 欧美成人猛片aaaaaaa| 任你操视频免费在线观看| 91超碰青青中文字幕| 精品视频一区二区三区四区五区 | 亚洲 中文 自拍 无码| 在线免费观看靠比视频的网站| 国产午夜福利av导航| 亚洲激情av一区二区| 日韩熟女av天堂系列| 午夜免费观看精品视频| 97人妻人人澡爽人人精品| 免费男阳茎伸入女阳道视频| 日韩av大胆在线观看| 亚洲av男人的天堂你懂的| 中国产一级黄片免费视频播放| 天天摸天天干天天操科普| japanese日本熟妇另类| 欧美精品免费aaaaaa| 最新国产精品拍在线观看| 又色又爽又黄又刺激av网站| 日本人竟这样玩学生妹| 综合精品久久久久97| 91av精品视频在线| 熟女俱乐部一二三区| 人妻久久久精品69系列| 亚洲欧美综合另类13p| 日韩美女综合中文字幕pp| 日韩黄色片在线观看网站| 欧美viboss性丰满| 国产精品一二三不卡带免费视频| 视频久久久久久久人妻| 亚洲人妻av毛片在线| 亚洲变态另类色图天堂网| 亚洲av男人天堂久久| 美女视频福利免费看| 午夜影院在线观看视频羞羞羞| 91免费黄片可看视频| 成人av久久精品一区二区| 青青青青青青青在线播放视频| 免费一级特黄特色大片在线观看| 日噜噜噜夜夜噜噜噜天天噜噜噜| 97年大学生大白天操逼| 久久综合老鸭窝色综合久久 | 一区二区三区激情在线| 日本午夜福利免费视频| 欧美香蕉人妻精品一区二区| 边摸边做超爽毛片18禁色戒| 新97超碰在线观看| 午夜福利人人妻人人澡人人爽| 青青草亚洲国产精品视频| 操人妻嗷嗷叫视频一区二区| 黄色片一级美女黄色片| 黑人性生活视频免费看| 直接观看免费黄网站| 最新黄色av网站在线观看| 国产一区成人在线观看视频| 自拍 日韩 欧美激情| 亚洲国产成人在线一区| ka0ri在线视频| 国产日韩欧美视频在线导航| 99国产精品窥熟女精品| 51精品视频免费在线观看| 国产精品自拍在线视频| av在线shipin| 精品区一区二区三区四区人妻| 好了av中文字幕在线| 青草亚洲视频在线观看| 三级av中文字幕在线观看| 日日摸夜夜添夜夜添毛片性色av| av资源中文字幕在线观看| 国产精品国色综合久久| 中国把吊插入阴蒂的视频| 在线观看一区二区三级| 亚洲精品三级av在线免费观看| 国产三级精品三级在线不卡| 夫妻在线观看视频91| 91自产国产精品视频| 在线观看一区二区三级| 国产精品视频资源在线播放| 精品少妇一二三视频在线| 天天色天天舔天天射天天爽| 超碰在线观看免费在线观看| 日本少妇人妻xxxxxhd| 国产av福利网址大全| 中文字幕av熟女人妻| 日本午夜爽爽爽爽爽视频在线观看| 97超碰最新免费在线观看| 嫩草aⅴ一区二区三区| 成人av电影免费版| 色哟哟在线网站入口| 青青草国内在线视频精选| 99久久超碰人妻国产| 日本av熟女在线视频| 日本丰满熟妇大屁股久久| jul—619中文字幕在线| 亚洲视频乱码在线观看| 亚洲激情偷拍一区二区| 久久久精品999精品日本| 亚洲一区二区激情在线| 亚洲激情,偷拍视频| 91大神福利视频网| 欧美日本在线视频一区| 鸡巴操逼一级黄色气| 2022国产综合在线干| 91老熟女连续高潮对白| 91老师蜜桃臀大屁股| 国产精品久久久久网| 99精品视频之69精品视频| 日本一区二区三区免费小视频| 亚洲欧美清纯唯美另类| 青春草视频在线免费播放| 97精品人妻一区二区三区精品| 黑人大几巴狂插日本少妇| 欧美一区二区三区久久久aaa| 三级av中文字幕在线观看| 制服丝袜在线人妻中文字幕| 四虎永久在线精品免费区二区| 97人妻人人澡爽人人精品| a v欧美一区=区三区| 午夜久久久久久久精品熟女| 国产大鸡巴大鸡巴操小骚逼小骚逼| 男人和女人激情视频| 毛片一级完整版免费| 一区二区三区日本伦理| 美女视频福利免费看| 日本人妻欲求不满中文字幕| 中文字幕奴隷色的舞台50| 神马午夜在线观看视频| 亚洲区欧美区另类最新章节| 国产欧美精品一区二区高清| 亚洲av日韩高清hd| 18禁无翼鸟成人在线| 白白操白白色在线免费视频| 三上悠亚和黑人665番号| 成人动漫大肉棒插进去视频| 欧美香蕉人妻精品一区二区| 精品一区二区三区三区88| 色97视频在线播放| 在线观看亚洲人成免费网址| 硬鸡巴动态操女人逼视频| 中文 成人 在线 视频| 9国产精品久久久久老师| 亚洲另类伦春色综合小| 岛国青草视频在线观看| 天天操天天干天天日狠狠插| 搞黄色在线免费观看| 97人妻夜夜爽二区欧美极品| 免费观看丰满少妇做受| 亚洲精品在线资源站| 久青青草视频手机在线免费观看| 午夜精品一区二区三区4| 精品91自产拍在线观看一区| av黄色成人在线观看| 少妇与子乱在线观看| 日本一二三区不卡无| 蜜臀成人av在线播放| 少妇人妻100系列| 在线视频国产欧美日韩| 国产成人午夜精品福利| 91精品国产91久久自产久强| 1区2区3区不卡视频| 中文字幕免费福利视频6| 天天日天天干天天搡| 激情图片日韩欧美人妻| 青青色国产视频在线| 精品欧美一区二区vr在线观看 | 亚洲va欧美va人人爽3p| 最新97国产在线视频| 沙月文乃人妻侵犯中文字幕在线 | 亚洲欧美久久久久久久久| 欧美男同性恋69视频| av黄色成人在线观看| 狠狠的往里顶撞h百合| 男人靠女人的逼视频| 91精品国产黑色丝袜| 午夜频道成人在线91| 在线 中文字幕 一区| 午夜精品一区二区三区福利视频| 欧美va不卡视频在线观看| 中文字幕高清免费在线人妻| 激情国产小视频在线| 欧美精品欧美极品欧美视频| 天天日天天日天天擦| 久草视频福利在线首页| 天天日天天摸天天爱| 欧美一级片免费在线成人观看| 成人免费做爰高潮视频| 亚洲av男人的天堂你懂的| 99热碰碰热精品a中文| 亚洲成人av在线一区二区| 国产露脸对白在线观看| 亚洲蜜臀av一区二区三区九色 | 伊人情人综合成人久久网小说| 国产麻豆剧果冻传媒app| caoporn蜜桃视频| 欧美色呦呦最新网址| 91国产在线免费播放| 在线观看的a站 最新| 亚洲午夜在线视频福利| 青青草在观免费国产精品| 亚洲成人三级在线播放 | 可以在线观看的av中文字幕| 国产男女视频在线播放| 无码国产精品一区二区高潮久久4| 五十路息与子猛烈交尾视频| 青青青青青操视频在线观看| 亚洲av极品精品在线观看| 国产卡一卡二卡三乱码手机| 午夜精品一区二区三区城中村| 人人妻人人爱人人草| 免费黄色成人午夜在线网站| 午夜美女福利小视频| 天天艹天天干天天操| 可以免费看的www视频你懂的| 久久丁香婷婷六月天| 亚洲第17页国产精品| 风流唐伯虎电视剧在线观看| 亚洲中文精品字幕在线观看| 日本裸体熟妇区二区欧美| 夜女神免费福利视频| 91精品视频在线观看免费| 国产又大又黄免费观看| 4个黑人操素人视频网站精品91| 亚洲精品国品乱码久久久久| 国产精品成久久久久三级蜜臀av | 天天干狠狠干天天操| 午夜国产免费福利av| 91国偷自产一区二区三区精品| 欧洲黄页网免费观看| 亚洲av天堂在线播放| aaa久久久久久久久| 日本www中文字幕| 九一传媒制片厂视频在线免费观看| 无码中文字幕波多野不卡| 国产福利小视频大全| 最新的中文字幕 亚洲| 色爱av一区二区三区| 欧美一级视频一区二区| 91极品大一女神正在播放| 日本福利午夜电影在线观看| 国产丰满熟女成人视频| 亚洲一区二区三区精品视频在线| 亚洲视频在线视频看视频在线| 丝袜肉丝一区二区三区四区在线 | 亚洲中文字幕国产日韩| 亚洲精品乱码久久久本| 特黄老太婆aa毛毛片| 色花堂在线av中文字幕九九 | 偷拍美女一区二区三区| 日韩精品二区一区久久| 亚洲午夜伦理视频在线| 日韩欧美中文国产在线| 在线观看操大逼视频| 黄色视频成年人免费观看| av中文在线天堂精品| 天天干天天操天天扣| 亚洲国产精品久久久久蜜桃| 一区二区三区毛片国产一区| 欧美亚洲牲夜夜综合久久| 午夜大尺度无码福利视频| 99久久中文字幕一本人| 人妻丝袜av在线播放网址| 老司机午夜精品视频资源 | 男人天堂最新地址av| 免费观看丰满少妇做受| 国产无遮挡裸体免费直播视频| 黄色中文字幕在线播放| 久久这里只有精品热视频| 黄工厂精品视频在线观看| 色偷偷伊人大杳蕉综合网| 免费看美女脱光衣服的视频| 91国内视频在线观看| 11久久久久久久久久久| 日本a级视频老女人| av日韩在线免费播放| ka0ri在线视频| 亚洲综合一区二区精品久久| 久草视频在线一区二区三区资源站| 97超碰免费在线视频| 欧美老妇精品另类不卡片| www骚国产精品视频| 午夜在线一区二区免费| 日韩中文字幕精品淫| 亚洲一区二区三区久久受| 天天干天天啪天天舔| 欧美亚洲牲夜夜综合久久| 久久久麻豆精亚洲av麻花| 福利片区一区二体验区| 亚洲av日韩高清hd| 国产av一区2区3区| 91桃色成人网络在线观看| av中文字幕在线导航| 大鸡巴操b视频在线| 免费无码人妻日韩精品一区二区 | 欧美天堂av无线av欧美| 日韩欧美一级黄片亚洲| 免费男阳茎伸入女阳道视频| 欧美美女人体视频一区| 亚洲护士一区二区三区| 亚洲国产最大av综合| 日韩熟女av天堂系列| 97人妻人人澡爽人人精品| 日本三极片视频网站观看| 亚洲色偷偷综合亚洲AV伊人| 久久久久久cao我的性感人妻| 国产超码片内射在线| 99视频精品全部15| av高潮迭起在线观看| 五十路熟女人妻一区二| 国产揄拍高清国内精品对白| 国产精品自偷自拍啪啪啪| jul—619中文字幕在线| 337p日本大胆欧美人| 中文字幕一区的人妻欧美日韩| 91精品国产观看免费| 国产变态另类在线观看| 亚洲免费福利一区二区三区| 中文字幕在线免费第一页| 日本少妇人妻xxxxx18| 香蕉av影视在线观看| av天堂加勒比在线| 人妻av无码专区久久绿巨人| AV无码一区二区三区不卡| 97a片免费在线观看| 年轻的人妻被夫上司侵犯| 欧美成人猛片aaaaaaa| 福利午夜视频在线观看| 青青草原网站在线观看| 青草久久视频在线观看| 日本免费午夜视频网站| 在线视频免费观看网| 91免费观看在线网站| 日本av熟女在线视频| 夜夜骑夜夜操夜夜奸| avjpm亚洲伊人久久| av老司机精品在线观看| 美女少妇亚洲精选av| 日韩北条麻妃一区在线| 粉嫩小穴流水视频在线观看| 国产在线免费观看成人| 在线观看亚洲人成免费网址| 999九九久久久精品| jul—619中文字幕在线| 欧美视频不卡一区四区| 中文字幕在线观看国产片| 中文字幕一区的人妻欧美日韩| 风流唐伯虎电视剧在线观看 | 密臀av一区在线观看| 国产超码片内射在线| 国产麻豆91在线视频| 很黄很污很色的午夜网站在线观看| 最新激情中文字幕视频| 97瑟瑟超碰在线香蕉| 欧美一区二区三区激情啪啪啪 | 天天摸天天干天天操科普| 中文字幕高清在线免费播放| 啊慢点鸡巴太大了啊舒服视频| 欧美交性又色又爽又黄麻豆| 欧美日韩精品永久免费网址| 亚洲 欧美 精品 激情 偷拍| 999九九久久久精品| 插小穴高清无码中文字幕| 骚货自慰被发现爆操| 日韩伦理短片在线观看| 日韩欧美亚洲熟女人妻| 极品性荡少妇一区二区色欲| 国产亚洲国产av网站在线| 亚洲一级av大片免费观看| 欧美精品一区二区三区xxxx| 欧美黑人性暴力猛交喷水| 超碰97免费人妻麻豆| 岛国毛片视频免费在线观看| 久久久精品国产亚洲AV一| 曰本无码人妻丰满熟妇啪啪| 19一区二区三区在线播放| 少妇深喉口爆吞精韩国| 自拍偷拍日韩欧美一区二区| 自拍偷拍亚洲另类色图| 2022精品久久久久久中文字幕| 日韩加勒比东京热二区| 久久久久久久一区二区三| 93精品视频在线观看| 91超碰青青中文字幕| 不卡一不卡二不卡三| 超级福利视频在线观看| 成人H精品动漫在线无码播放| 色97视频在线播放| 适合午夜一个人看的视频| 国产成人午夜精品福利| 精品一区二区三区在线观看| 97瑟瑟超碰在线香蕉| 久青青草视频手机在线免费观看| 97黄网站在线观看| 国产欧美精品不卡在线| 啊慢点鸡巴太大了啊舒服视频| 国产精品久久久久网| 自拍偷拍,中文字幕| 99热碰碰热精品a中文| lutube在线成人免费看| 青青青青草手机在线视频免费看| av资源中文字幕在线观看| 喷水视频在线观看这里只有精品| 亚洲av色香蕉一区二区三区| av老司机精品在线观看| 粉嫩av懂色av蜜臀av| 欧美性受xx黑人性猛交| 国产精品久久久久久久久福交 | 好吊操视频这里只有精品| 精品国产污污免费网站入口自 | 免费国产性生活视频| 91人妻精品久久久久久久网站| av手机在线观播放网站| 熟女国产一区亚洲中文字幕| 成年人黄色片免费网站| 国产刺激激情美女网站| 伊人开心婷婷国产av| 久久艹在线观看视频| 国产普通话插插视频| 最新国产精品网址在线观看| 又粗又硬又猛又黄免费30| 婷婷五月亚洲综合在线| 亚洲成人免费看电影| 在线国产日韩欧美视频| 中文字幕av一区在线观看| 农村胖女人操逼视频| 亚洲成人av一区在线| 91www一区二区三区| 国产成人综合一区2区| 中国视频一区二区三区| 啊啊好大好爽啊啊操我啊啊视频| 免费啪啪啪在线观看视频| 欧美美女人体视频一区| 老司机欧美视频在线看| yy96视频在线观看| 国产欧美日韩第三页| 成人免费公开视频无毒| 少妇人妻100系列| 免费在线看的黄片视频| 只有精品亚洲视频在线观看| 一区二区三区蜜臀在线| 人妻3p真实偷拍一二区| 亚洲午夜电影在线观看| 97人妻夜夜爽二区欧美极品| 福利视频一区二区三区筱慧| 中文字幕综合一区二区| 亚洲午夜电影之麻豆| 中文字幕无码一区二区免费| 午夜av一区二区三区 | 99精品视频在线观看婷婷| 亚洲免费国产在线日韩| 人妻激情图片视频小说| 大肉大捧一进一出好爽在线视频 | 真实国模和老外性视频| 91亚洲国产成人精品性色| 国产日韩av一区二区在线| 青青草在观免费国产精品| 久久精品久久精品亚洲人| 黄色无码鸡吧操逼视频| 国产性色生活片毛片春晓精品| 热久久只有这里有精品| 一个人免费在线观看ww视频| 欧美日本aⅴ免费视频| 激情伦理欧美日韩中文字幕| 欧美日韩熟女一区二区三区| 亚洲 人妻 激情 中文| 天堂中文字幕翔田av| 亚洲一级 片内射视正片| 男人的天堂av日韩亚洲| 中国黄色av一级片| 人人妻人人人操人人人爽| aiss午夜免费视频| 亚洲精品无码久久久久不卡| 51国产成人精品视频| 国产精品sm调教视频| 无码精品一区二区三区人| 不卡一不卡二不卡三| 日韩少妇人妻精品无码专区| asmr福利视频在线观看| 在线观看国产免费麻豆| 人妻av无码专区久久绿巨人| 国产在线拍揄自揄视频网站| 热思思国产99re| 91免费放福利在线观看| 青青青青青青青青青国产精品视频| 国产成人午夜精品福利| 丰满少妇翘臀后进式| 午夜福利人人妻人人澡人人爽| 精品成人啪啪18免费蜜臀| 免费在线福利小视频| 日韩欧美一级精品在线观看| 老司机福利精品视频在线| 亚洲国产精品美女在线观看| 99热碰碰热精品a中文| 93视频一区二区三区| 天天日天天干天天要| 在线免费视频 自拍| 天堂av在线播放免费| 亚洲无码一区在线影院| 国产片免费观看在线观看| 偷拍自拍亚洲美腿丝袜| 亚洲天堂第一页中文字幕| 国产精彩福利精品视频| 91精品高清一区二区三区| 亚洲精品午夜久久久久| 久久午夜夜伦痒痒想咳嗽P| 亚洲天天干 夜夜操| 天天躁夜夜躁日日躁a麻豆| 黑人进入丰满少妇视频| 和邻居少妇愉情中文字幕| 亚洲成人熟妇一区二区三区| 色婷婷久久久久swag精品| av手机在线免费观看日韩av| 精品一区二区三区三区色爱| 亚洲第17页国产精品| 亚洲成人午夜电影在线观看| 青青青爽视频在线播放| 美女av色播在线播放| 风流唐伯虎电视剧在线观看| 天天操天天爽天天干| 国产精品sm调教视频| 夜夜嗨av蜜臀av| 蜜桃视频入口久久久| 一本久久精品一区二区| 97年大学生大白天操逼| 特大黑人巨大xxxx| 色av色婷婷人妻久久久精品高清| 涩涩的视频在线观看视频| 欧美亚洲少妇福利视频| 中文字幕网站你懂的| 亚洲麻豆一区二区三区| 免费av岛国天堂网站| 欧美80老妇人性视频| 97人妻无码AV碰碰视频| 可以免费看的www视频你懂的| 少妇一区二区三区久久久| 中文字幕在线观看国产片| 521精品视频在线观看| 亚洲熟妇久久无码精品| 久精品人妻一区二区三区| 国产美女一区在线观看| 亚洲中文字幕乱码区| 香蕉91一区二区三区| 蜜桃色婷婷久久久福利在线| 日本精品视频不卡一二三| 欧美精品免费aaaaaa| 在线观看欧美黄片一区二区三区 | 91精品免费久久久久久| 91啪国自产中文字幕在线| 亚洲一区av中文字幕在线观看| 久久精品在线观看一区二区| 插小穴高清无码中文字幕| 一级A一级a爰片免费免会员 | 亚洲精品高清自拍av| 天堂va蜜桃一区入口| 成人av中文字幕一区| 国产av福利网址大全| 91国内视频在线观看| 亚洲精品久久综合久| 懂色av之国产精品| 亚洲变态另类色图天堂网| 中国黄片视频一区91| 做爰视频毛片下载蜜桃视频1| 欧美精品一区二区三区xxxx| 99久久超碰人妻国产| 91免费放福利在线观看| 国产成人午夜精品福利| 成人av亚洲一区二区| 青青青视频手机在线观看| 亚洲欧美一区二区三区电影| 黄色成人在线中文字幕| 综合激情网激情五月五月婷婷| 中文亚洲欧美日韩无线码| 精品一区二区亚洲欧美| 天天日天天爽天天爽| 夜色撩人久久7777| 免费一级特黄特色大片在线观看| 久久精品美女免费视频| 漂亮 人妻被中出中文| 青青色国产视频在线| 国产一区二区在线欧美| 啪啪啪啪啪啪啪啪啪啪黄色| 中文字幕一区二区三区人妻大片| 天天摸天天日天天操| 亚洲人妻av毛片在线| 欧美一区二区三区乱码在线播放 | 亚洲精品国品乱码久久久久| 国产精品入口麻豆啊啊啊| av视网站在线观看| jul—619中文字幕在线| 91精品资源免费观看| 亚洲 色图 偷拍 欧美| 日比视频老公慢点好舒服啊| 老司机福利精品免费视频一区二区| 国产高潮无码喷水AV片在线观看| 美女在线观看日本亚洲一区| 嫩草aⅴ一区二区三区| 一区二区三区久久中文字幕| 婷婷久久一区二区字幕网址你懂得| 不卡一不卡二不卡三| 日韩无码国产精品强奸乱伦| 熟女国产一区亚洲中文字幕| 免费在线播放a级片| 日韩一区二区三区三州| 老司机欧美视频在线看| 顶级尤物粉嫩小尤物网站| 日韩精品一区二区三区在线播放| 午夜在线观看一区视频| 在线免费观看靠比视频的网站| 99热久久极品热亚洲| 久久久久久久久久一区二区三区| 亚洲美女美妇久久字幕组| 一区二区在线视频中文字幕| 男人的天堂在线黄色| 在线视频这里只有精品自拍| 免费在线观看视频啪啪| 鸡巴操逼一级黄色气| 国产成人无码精品久久久电影| 久久久久久九九99精品| 爱有来生高清在线中文字幕| 韩国三级aaaaa高清视频 | 91在线视频在线精品3| av日韩在线免费播放| 亚洲成人黄色一区二区三区| 日韩美女福利视频网| 久久精品国产23696| 亚洲av自拍天堂网| 精品国产在线手机在线| 欧美xxx成人在线| 污污小视频91在线观看| 美女福利视频网址导航| 国产精品久久久久久久女人18| 一区二区三区久久久91| 九九热99视频在线观看97| 大学生A级毛片免费视频| 99国内小视频在现欢看| 班长撕开乳罩揉我胸好爽| 日美女屁股黄邑视频| 天天摸天天亲天天舔天天操天天爽 | 国产精品伦理片一区二区| 99精品视频在线观看免费播放| 欧美一区二区三区久久久aaa| 一区二区三区四区中文| 欧美综合婷婷欧美综合| 色吉吉影音天天干天天操| 亚洲高清自偷揄拍自拍| 成人av中文字幕一区| 成人资源在线观看免费官网| 57pao国产一区二区| ka0ri在线视频| 在线播放一区二区三区Av无码| 欧美男人大鸡吧插女人视频| 特大黑人巨大xxxx| 欧美亚洲少妇福利视频| 一级黄片大鸡巴插入美女| 免费看国产又粗又猛又爽又黄视频| 日本裸体熟妇区二区欧美| 黑人解禁人妻叶爱071| 亚洲欧美一区二区三区电影| 91国内精品久久久久精品一| 亚洲成人熟妇一区二区三区| 伊人开心婷婷国产av| 特级无码毛片免费视频播放| 亚洲精品ww久久久久久| 2020韩国午夜女主播在线| 成人蜜桃美臀九一一区二区三区| 偷拍自拍视频图片免费| 日本中文字幕一二区视频| 国产精品亚洲在线观看| av成人在线观看一区| 欧亚乱色一区二区三区|