mirror of
https://github.com/clockworkpi/launcher.git
synced 2025-12-14 18:58:50 +01:00
```
def Click(self):
if self._PsIndex > len(self._MyList) -1:
```
* use this to avoid PsIndex out of the range of self._MyList
* download games and showed up
This commit is contained in:
parent
2bb22f3914
commit
85d67dc218
@ -152,7 +152,7 @@ class GPUDriverPage(Page):
|
|||||||
self._Scroller.SetCanvasHWND(self._HWND)
|
self._Scroller.SetCanvasHWND(self._HWND)
|
||||||
|
|
||||||
def Click(self):
|
def Click(self):
|
||||||
if len(self._MyList) == 0:
|
if self._PsIndex > len(self._MyList) -1:
|
||||||
return
|
return
|
||||||
|
|
||||||
cur_li = self._MyList[self._PsIndex]
|
cur_li = self._MyList[self._PsIndex]
|
||||||
|
|||||||
@ -185,7 +185,7 @@ def dict_factory(cursor, row):
|
|||||||
return d
|
return d
|
||||||
|
|
||||||
class GameStorePage(Page):
|
class GameStorePage(Page):
|
||||||
_FootMsg = ["Nav","","","Back","Select"]
|
_FootMsg = ["Nav","","Up","Back","Select"]
|
||||||
_MyList = []
|
_MyList = []
|
||||||
_ListFont = MyLangManager.TrFont("notosanscjk12")
|
_ListFont = MyLangManager.TrFont("notosanscjk12")
|
||||||
|
|
||||||
@ -214,7 +214,7 @@ class GameStorePage(Page):
|
|||||||
def SyncSqlite(self):
|
def SyncSqlite(self):
|
||||||
try:
|
try:
|
||||||
conn = sqlite3.connect("aria2tasks.db")
|
conn = sqlite3.connect("aria2tasks.db")
|
||||||
conn.row_factory = sqlite3.Row
|
conn.row_factory = dict_factory
|
||||||
c = conn.cursor()
|
c = conn.cursor()
|
||||||
ret = c.execute("SELECT * FROM tasks").fetchall()
|
ret = c.execute("SELECT * FROM tasks").fetchall()
|
||||||
conn.close()
|
conn.close()
|
||||||
@ -232,14 +232,17 @@ class GameStorePage(Page):
|
|||||||
start_y = 0
|
start_y = 0
|
||||||
last_height = 0
|
last_height = 0
|
||||||
|
|
||||||
repos = self._MyStack.Last()
|
repos = []
|
||||||
|
stk = self._MyStack.Last()
|
||||||
|
repos.extend(stk)
|
||||||
if self._MyStack.Length() == 1: # on top
|
if self._MyStack.Length() == 1: # on top
|
||||||
sqlite3_menu= self.SyncSqlite()
|
sqlite3_menu= self.SyncSqlite()
|
||||||
if sqlite3_menu != None and len(sqlite3_menu) > 0:
|
if sqlite3_menu != None and len(sqlite3_menu) > 0:
|
||||||
print(sqlite3_menu)
|
print(sqlite3_menu)
|
||||||
repos.extend(sqlite3_menu )
|
repos.extend(sqlite3_menu )
|
||||||
|
|
||||||
|
print(repos)
|
||||||
|
|
||||||
for i,u in enumerate( repos ):
|
for i,u in enumerate( repos ):
|
||||||
#print(i,u)
|
#print(i,u)
|
||||||
li = InfoPageListItem()
|
li = InfoPageListItem()
|
||||||
@ -289,7 +292,7 @@ class GameStorePage(Page):
|
|||||||
self._Scroller.SetCanvasHWND(self._HWND)
|
self._Scroller.SetCanvasHWND(self._HWND)
|
||||||
|
|
||||||
def Click(self):
|
def Click(self):
|
||||||
if len(self._MyList) == 0:
|
if self._PsIndex > len(self._MyList) -1:
|
||||||
return
|
return
|
||||||
|
|
||||||
cur_li = self._MyList[self._PsIndex]
|
cur_li = self._MyList[self._PsIndex]
|
||||||
@ -301,7 +304,8 @@ class GameStorePage(Page):
|
|||||||
if cur_li._Value["type"] == "dir":
|
if cur_li._Value["type"] == "dir":
|
||||||
remote_file_url = cur_li._Value["file"]
|
remote_file_url = cur_li._Value["file"]
|
||||||
menu_file = remote_file_url.split("master")[1] #assume master branch
|
menu_file = remote_file_url.split("master")[1] #assume master branch
|
||||||
local_menu_file = "%s/aria2Download%s" % (os.path.expanduser('~'),menu_file )
|
local_menu_file = "%s/aria2download%s" % (os.path.expanduser('~'),menu_file )
|
||||||
|
print(local_menu_file)
|
||||||
if FileExists( local_menu_file ) == False:
|
if FileExists( local_menu_file ) == False:
|
||||||
print(local_menu_file, "non-existed")
|
print(local_menu_file, "non-existed")
|
||||||
gid,ret = config.RPC.urlDownloading(remote_file_url)
|
gid,ret = config.RPC.urlDownloading(remote_file_url)
|
||||||
@ -323,7 +327,8 @@ class GameStorePage(Page):
|
|||||||
self._Downloading = None
|
self._Downloading = None
|
||||||
with open(local_menu_file) as json_file:
|
with open(local_menu_file) as json_file:
|
||||||
local_menu_json = json.load(json_file)
|
local_menu_json = json.load(json_file)
|
||||||
self._MyStack.Push(local_menu_json["lists"])
|
print(local_menu_json)
|
||||||
|
self._MyStack.Push(local_menu_json["list"])
|
||||||
|
|
||||||
self.SyncList()
|
self.SyncList()
|
||||||
self._Screen.Draw()
|
self._Screen.Draw()
|
||||||
@ -331,28 +336,32 @@ class GameStorePage(Page):
|
|||||||
|
|
||||||
else:
|
else:
|
||||||
#download the game probably
|
#download the game probably
|
||||||
|
|
||||||
remote_file_url = cur_li._Value["file"]
|
remote_file_url = cur_li._Value["file"]
|
||||||
menu_file = remote_file_url.split("master")[1]
|
menu_file = remote_file_url.split("master")[1]
|
||||||
local_menu_file = "%s/aria2Download%s" % (os.path.expanduser('~'),menu_file )
|
local_menu_file = "%s/aria2download%s" % (os.path.expanduser('~'),menu_file )
|
||||||
|
|
||||||
|
if FileExists( local_menu_file ) == False:
|
||||||
|
gid,ret = config.RPC.urlDownloading(remote_file_url)
|
||||||
|
if ret == False:
|
||||||
|
gid = config.RPC.addUri( remote_file_url, options={"out": menu_file})
|
||||||
|
self._Downloading = remote_file_url
|
||||||
|
try:
|
||||||
|
conn = sqlite3.connect("aria2tasks.db")
|
||||||
|
c = conn.cursor()
|
||||||
|
c.execute("INSERT INTO tasks(gid,title,file,type,status,fav) VALUES ('"+gid+"','"+cur_li._Value["title"]+"','"+cur_li._Value["file"]+"','"+cur_li._Value["type"]+"','active','0')")
|
||||||
|
|
||||||
if config.RPC.urlDownloading(remote_file_url) == False:
|
conn.commit()
|
||||||
gid = config.RPC.addUri( remote_file_url, options={"out": menu_file})
|
conn.close()
|
||||||
self._Downloading = remote_file_url
|
except Exception as ex:
|
||||||
|
print("SQLITE3 ",ex)
|
||||||
|
|
||||||
try:
|
self._Screen._MsgBox.SetText("Getting the game now")
|
||||||
conn = sqlite3.connect("aria2tasks.db")
|
self._Screen._MsgBox.Draw()
|
||||||
c = conn.cursor()
|
self._Screen.SwapAndShow()
|
||||||
c.execute("INSERT INTO tasks VALUES ('"+gid+"','"+cur_li._Value["title"]+"','"+cur_li._Value["file"]+"','"+cur_li._Value["type"]+"','active')")
|
|
||||||
|
|
||||||
conn.commit()
|
else:
|
||||||
conn.close()
|
print("file downloaded")# maybe check it if is installed,then execute it
|
||||||
except Exception as ex:
|
|
||||||
print(ex)
|
|
||||||
|
|
||||||
self._Screen._MsgBox.SetText("Getting the game now")
|
|
||||||
self._Screen._MsgBox.Draw()
|
|
||||||
seff._Screen.SwapAndShow()
|
|
||||||
|
|
||||||
def OnLoadCb(self):
|
def OnLoadCb(self):
|
||||||
self._Scrolled = 0
|
self._Scrolled = 0
|
||||||
@ -376,7 +385,14 @@ class GameStorePage(Page):
|
|||||||
|
|
||||||
if IsKeyStartOrA(event.key):
|
if IsKeyStartOrA(event.key):
|
||||||
self.Click()
|
self.Click()
|
||||||
|
|
||||||
|
if event.key == CurKeys["X"]:
|
||||||
|
if self._MyStack.Length() > 1:
|
||||||
|
self._MyStack.Pop()
|
||||||
|
self.SyncList()
|
||||||
|
self._Screen.Draw()
|
||||||
|
self._Screen.SwapAndShow()
|
||||||
|
|
||||||
if event.key == CurKeys["Up"]:
|
if event.key == CurKeys["Up"]:
|
||||||
self.ScrollUp()
|
self.ScrollUp()
|
||||||
self._Screen.Draw()
|
self._Screen.Draw()
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user