string s;
s = bufstr_get(me.listDemo, i);
- if(substring(s, 0, 1) == "/")
- s = substring(s, 1, strlen(s) - 1); // remove the first forward slash
-
+ if (substring(s, 0, 1) == "/") {
+ s = substring(s, 1, strlen(s) - 1); // remove the first forward slash
+ }
return s;
}
void getDemos_for_ext(entity me, string ext, float subdir)
{
string s;
- if (subdir)
- s="demos/*/";
- else
- s="demos/";
- if(me.filterString)
- s=strcat(s, me.filterString, ext);
- else
- s=strcat(s, "*", ext);
+ if (subdir) {
+ s = "demos/*/";
+ } else {
+ s = "demos/";
+ }
+ if (me.filterString) {
+ s = strcat(s, me.filterString, ext);
+ } else {
+ s = strcat(s, "*", ext);
+ }
float list, i, n;
list = search_begin(s, false, true);
- if(list >= 0)
- {
+ if (list >= 0) {
n = search_getsize(list);
- for(i = 0; i < n; ++i)
- {
- s = search_getfilename(list, i); // get initial full file name
- s = substring(s, 6, (strlen(s) - 6 - 4)); // remove "demos/" prefix and ".dem" suffix
- s = strdecolorize(s); // remove any pre-existing colors
- if(subdir)
- {
- s = strreplace("/", "^7/", s); // clear colors at the forward slash
+ for (i = 0; i < n; ++i) {
+ s = search_getfilename(list, i); // get initial full file name
+ s = substring(s, 6, (strlen(s) - 6 - 4)); // remove "demos/" prefix and ".dem" suffix
+ s = strdecolorize(s); // remove any pre-existing colors
+ if (subdir) {
+ s = strreplace("/", "^7/", s); // clear colors at the forward slash
s = strcat("/", rgb_to_hexcolor(SKINCOLOR_DEMOLIST_SUBDIR), s); // add a forward slash for sorting, then color
bufstr_add(me.listDemo, s, true);
- }
- else { bufstr_add(me.listDemo, s, true); }
+ } else { bufstr_add(me.listDemo, s, true); }
}
search_end(list);
}
- if (subdir)
+ if (subdir) {
getDemos_for_ext(me, ext, false);
+ }
}
void XonoticDemoList_getDemos(entity me)
{
- if (me.listDemo >= 0)
+ if (me.listDemo >= 0) {
buf_del(me.listDemo);
+ }
me.listDemo = buf_create();
- if (me.listDemo < 0)
- {
+ if (me.listDemo < 0) {
me.nItems = 0;
return;
}
getDemos_for_ext(me, ".dem", true);
me.nItems = buf_getsize(me.listDemo);
- if(me.nItems > 0)
+ if (me.nItems > 0) {
buf_sort(me.listDemo, 128, false);
+ }
}
void XonoticDemoList_destroy(entity me)
{
- if(me.nItems > 0)
+ if (me.nItems > 0) {
buf_del(me.listDemo);
+ }
}
void XonoticDemoList_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize)
void XonoticDemoList_drawListBoxItem(entity me, int i, vector absSize, bool isSelected, bool isFocused)
{
string s;
- if(isSelected)
+ if (isSelected) {
draw_Fill('0 0 0', '1 1 0', SKINCOLOR_LISTBOX_SELECTED, SKINALPHA_LISTBOX_SELECTED);
- else if(isFocused)
- {
+ } else if (isFocused) {
me.focusedItemAlpha = getFadedAlpha(me.focusedItemAlpha, SKINALPHA_LISTBOX_FOCUSED, SKINFADEALPHA_LISTBOX_FOCUSED);
draw_Fill('0 0 0', '1 1 0', SKINCOLOR_LISTBOX_FOCUSED, me.focusedItemAlpha);
}
- s = me.demoName(me,i);
+ s = me.demoName(me, i);
s = draw_TextShortenToWidth(s, me.columnNameSize, 0, me.realFontSize);
draw_Text(me.realUpperMargin * eY + (me.columnNameOrigin + 0.00 * (me.columnNameSize - draw_TextWidth(s, 0, me.realFontSize))) * eX, s, me.realFontSize, SKINCOLOR_TEXT, SKINALPHA_TEXT, 1);
}
void DemoList_Refresh_Click(entity btn, entity me)
{
me.getDemos(me);
- me.setSelected(me, 0); //always select the first element after a list update
+ me.setSelected(me, 0); // always select the first element after a list update
}
void DemoList_Filter_Change(entity box, entity me)
{
- if(me.filterString)
+ if (me.filterString) {
strunzone(me.filterString);
+ }
- if(box.text != "")
- {
- if (strstrofs(box.text, "*", 0) >= 0 || strstrofs(box.text, "?", 0) >= 0)
+ if (box.text != "") {
+ if (strstrofs(box.text, "*", 0) >= 0 || strstrofs(box.text, "?", 0) >= 0) {
me.filterString = strzone(box.text);
- else
+ } else {
me.filterString = strzone(strcat("*", box.text, "*"));
- }
- else
+ }
+ } else {
me.filterString = string_null;
+ }
me.getDemos(me);
}
void DemoConfirm_ListClick_Check_Gamestatus(entity me)
{
- if(!(gamestatus & (GAME_CONNECTED | GAME_ISSERVER))) // we're not in a match, lets watch the demo
- {
+ if (!(gamestatus & (GAME_CONNECTED | GAME_ISSERVER))) { // we're not in a match, lets watch the demo
me.startDemo(me);
- }
- else // already in a match, player has to confirm
- {
+ } else { // already in a match, player has to confirm
DialogOpenButton_Click_withCoords(
me,
main.demostartconfirmDialog,
float XonoticDemoList_keyDown(entity me, float scan, float ascii, float shift)
{
- if(scan == K_ENTER || scan == K_KP_ENTER)
- {
+ if (scan == K_ENTER || scan == K_KP_ENTER) {
DemoConfirm_ListClick_Check_Gamestatus(me);
return 1;
- }
- else
- {
+ } else {
return SUPER(XonoticDemoList).keyDown(me, scan, ascii, shift);
}
}