OpenTTD Source  1.11.0-beta1
newgrf_debug_gui.cpp
Go to the documentation of this file.
1 /*
2  * This file is part of OpenTTD.
3  * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
4  * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
5  * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
6  */
7 
10 #include "stdafx.h"
11 #include <stdarg.h>
12 #include "window_gui.h"
13 #include "window_func.h"
14 #include "fileio_func.h"
15 #include "spritecache.h"
16 #include "string_func.h"
17 #include "strings_func.h"
18 #include "textbuf_gui.h"
19 #include "vehicle_gui.h"
20 #include "zoom_func.h"
21 
22 #include "engine_base.h"
23 #include "industry.h"
24 #include "object_base.h"
25 #include "station_base.h"
26 #include "town.h"
27 #include "vehicle_base.h"
28 #include "train.h"
29 #include "roadveh.h"
30 
31 #include "newgrf_airporttiles.h"
32 #include "newgrf_debug.h"
33 #include "newgrf_object.h"
34 #include "newgrf_spritegroup.h"
35 #include "newgrf_station.h"
36 #include "newgrf_town.h"
37 #include "newgrf_railtype.h"
38 #include "newgrf_industries.h"
39 #include "newgrf_industrytiles.h"
40 
42 
43 #include "table/strings.h"
44 
45 #include "safeguards.h"
46 
48 NewGrfDebugSpritePicker _newgrf_debug_sprite_picker = { SPM_NONE, nullptr, 0, std::vector<SpriteID>() };
49 
55 static inline uint GetFeatureIndex(uint window_number)
56 {
57  return GB(window_number, 0, 24);
58 }
59 
67 static inline uint GetInspectWindowNumber(GrfSpecFeature feature, uint index)
68 {
69  assert((index >> 24) == 0);
70  return (feature << 24) | index;
71 }
72 
77 enum NIType {
80 };
81 
83 struct NIProperty {
84  const char *name;
85  ptrdiff_t offset;
86  byte read_size;
87  byte prop;
88  byte type;
89 };
90 
91 
96 struct NICallback {
97  const char *name;
98  ptrdiff_t offset;
99  byte read_size;
100  byte cb_bit;
101  uint16 cb_id;
102 };
104 static const int CBM_NO_BIT = UINT8_MAX;
105 
107 struct NIVariable {
108  const char *name;
109  byte var;
110 };
111 
113 class NIHelper {
114 public:
116  virtual ~NIHelper() {}
117 
123  virtual bool IsInspectable(uint index) const = 0;
124 
130  virtual uint GetParent(uint index) const = 0;
131 
137  virtual const void *GetInstance(uint index) const = 0;
138 
144  virtual const void *GetSpec(uint index) const = 0;
145 
150  virtual void SetStringParameters(uint index) const = 0;
151 
157  virtual uint32 GetGRFID(uint index) const = 0;
158 
167  virtual uint Resolve(uint index, uint var, uint param, bool *avail) const = 0;
168 
173  virtual bool PSAWithParameter() const
174  {
175  return false;
176  }
177 
184  virtual uint GetPSASize(uint index, uint32 grfid) const
185  {
186  return 0;
187  }
188 
195  virtual const int32 *GetPSAFirstPosition(uint index, uint32 grfid) const
196  {
197  return nullptr;
198  }
199 
200 protected:
206  void SetSimpleStringParameters(StringID string, uint32 index) const
207  {
208  SetDParam(0, string);
209  SetDParam(1, index);
210  }
211 
212 
219  void SetObjectAtStringParameters(StringID string, uint32 index, TileIndex tile) const
220  {
221  SetDParam(0, STR_NEWGRF_INSPECT_CAPTION_OBJECT_AT);
222  SetDParam(1, string);
223  SetDParam(2, index);
224  SetDParam(3, tile);
225  }
226 };
227 
228 
230 struct NIFeature {
234  const NIHelper *helper;
235 };
236 
237 /* Load all the NewGRF debug data; externalised as it is just a huge bunch of tables. */
238 #include "table/newgrf_debug_data.h"
239 
245 static inline GrfSpecFeature GetFeatureNum(uint window_number)
246 {
247  return (GrfSpecFeature)GB(window_number, 24, 8);
248 }
249 
255 static inline const NIFeature *GetFeature(uint window_number)
256 {
257  GrfSpecFeature idx = GetFeatureNum(window_number);
258  return idx < GSF_FAKE_END ? _nifeatures[idx] : nullptr;
259 }
260 
267 static inline const NIHelper *GetFeatureHelper(uint window_number)
268 {
269  return GetFeature(window_number)->helper;
270 }
271 
274  static const int LEFT_OFFSET = 5;
275  static const int RIGHT_OFFSET = 5;
276  static const int TOP_OFFSET = 5;
277  static const int BOTTOM_OFFSET = 5;
278 
280  static uint32 var60params[GSF_FAKE_END][0x20];
281 
283  uint32 caller_grfid;
284 
287 
290 
291  Scrollbar *vscroll;
292 
298  static bool HasVariableParameter(uint variable)
299  {
300  return IsInsideBS(variable, 0x60, 0x20);
301  }
302 
307  void SetCallerGRFID(uint32 grfid)
308  {
309  this->caller_grfid = grfid;
310  this->SetDirty();
311  }
312 
316  bool HasChainIndex() const
317  {
319  return f == GSF_TRAINS || f == GSF_ROADVEHICLES;
320  }
321 
326  uint GetFeatureIndex() const
327  {
328  uint index = ::GetFeatureIndex(this->window_number);
329  if (this->chain_index > 0) {
330  assert(this->HasChainIndex());
331  const Vehicle *v = Vehicle::Get(index);
332  v = v->Move(this->chain_index);
333  if (v != nullptr) index = v->index;
334  }
335  return index;
336  }
337 
342  {
343  if (this->chain_index == 0) return;
344 
345  assert(this->HasChainIndex());
346 
347  const Vehicle *v = Vehicle::Get(::GetFeatureIndex(this->window_number));
348  v = v->Move(this->chain_index);
349  if (v == nullptr) this->chain_index = 0;
350  }
351 
353  {
354  this->CreateNestedTree();
355  this->vscroll = this->GetScrollbar(WID_NGRFI_SCROLLBAR);
356  this->FinishInitNested(wno);
357 
358  this->vscroll->SetCount(0);
359  this->SetWidgetDisabledState(WID_NGRFI_PARENT, GetFeatureHelper(this->window_number)->GetParent(this->GetFeatureIndex()) == UINT32_MAX);
360 
361  this->OnInvalidateData(0, true);
362  }
363 
364  void SetStringParameters(int widget) const override
365  {
366  if (widget != WID_NGRFI_CAPTION) return;
367 
369  }
370 
371  void UpdateWidgetSize(int widget, Dimension *size, const Dimension &padding, Dimension *fill, Dimension *resize) override
372  {
373  switch (widget) {
374  case WID_NGRFI_VEH_CHAIN: {
375  assert(this->HasChainIndex());
377  size->height = std::max(size->height, GetVehicleImageCellSize((VehicleType)(VEH_TRAIN + (f - GSF_TRAINS)), EIT_IN_DEPOT).height + 2 + WD_BEVEL_TOP + WD_BEVEL_BOTTOM);
378  break;
379  }
380 
381  case WID_NGRFI_MAINPANEL:
382  resize->height = std::max(11, FONT_HEIGHT_NORMAL + 1);
383  resize->width = 1;
384 
385  size->height = 5 * resize->height + TOP_OFFSET + BOTTOM_OFFSET;
386  break;
387  }
388  }
389 
396  void WARN_FORMAT(4, 5) DrawString(const Rect &r, int offset, const char *format, ...) const
397  {
398  char buf[1024];
399 
400  va_list va;
401  va_start(va, format);
402  vseprintf(buf, lastof(buf), format, va);
403  va_end(va);
404 
405  offset -= this->vscroll->GetPosition();
406  if (offset < 0 || offset >= this->vscroll->GetCapacity()) return;
407 
408  ::DrawString(r.left + LEFT_OFFSET, r.right - RIGHT_OFFSET, r.top + TOP_OFFSET + (offset * this->resize.step_height), buf, TC_BLACK);
409  }
410 
411  void DrawWidget(const Rect &r, int widget) const override
412  {
413  switch (widget) {
414  case WID_NGRFI_VEH_CHAIN: {
415  const Vehicle *v = Vehicle::Get(this->GetFeatureIndex());
416  int total_width = 0;
417  int sel_start = 0;
418  int sel_end = 0;
419  for (const Vehicle *u = v->First(); u != nullptr; u = u->Next()) {
420  if (u == v) sel_start = total_width;
421  switch (u->type) {
422  case VEH_TRAIN: total_width += Train ::From(u)->GetDisplayImageWidth(); break;
423  case VEH_ROAD: total_width += RoadVehicle::From(u)->GetDisplayImageWidth(); break;
424  default: NOT_REACHED();
425  }
426  if (u == v) sel_end = total_width;
427  }
428 
429  int width = r.right + 1 - r.left - WD_BEVEL_LEFT - WD_BEVEL_RIGHT;
430  int skip = 0;
431  if (total_width > width) {
432  int sel_center = (sel_start + sel_end) / 2;
433  if (sel_center > width / 2) skip = std::min(total_width - width, sel_center - width / 2);
434  }
435 
437  int h = GetVehicleImageCellSize((VehicleType)(VEH_TRAIN + (f - GSF_TRAINS)), EIT_IN_DEPOT).height;
438  int y = (r.top + r.bottom - h) / 2;
439  DrawVehicleImage(v->First(), r.left + WD_BEVEL_LEFT, r.right - WD_BEVEL_RIGHT, y + 1, INVALID_VEHICLE, EIT_IN_DETAILS, skip);
440 
441  /* Highlight the articulated part (this is different to the whole-vehicle highlighting of DrawVehicleImage */
442  if (_current_text_dir == TD_RTL) {
443  DrawFrameRect(r.right - sel_end + skip, y, r.right - sel_start + skip, y + h, COLOUR_WHITE, FR_BORDERONLY);
444  } else {
445  DrawFrameRect(r.left + sel_start - skip, y, r.left + sel_end - skip, y + h, COLOUR_WHITE, FR_BORDERONLY);
446  }
447  break;
448  }
449  }
450 
451  if (widget != WID_NGRFI_MAINPANEL) return;
452 
453  uint index = this->GetFeatureIndex();
454  const NIFeature *nif = GetFeature(this->window_number);
455  const NIHelper *nih = nif->helper;
456  const void *base = nih->GetInstance(index);
457  const void *base_spec = nih->GetSpec(index);
458 
459  uint i = 0;
460  if (nif->variables != nullptr) {
461  this->DrawString(r, i++, "Variables:");
462  for (const NIVariable *niv = nif->variables; niv->name != nullptr; niv++) {
463  bool avail = true;
464  uint param = HasVariableParameter(niv->var) ? NewGRFInspectWindow::var60params[GetFeatureNum(this->window_number)][niv->var - 0x60] : 0;
465  uint value = nih->Resolve(index, niv->var, param, &avail);
466 
467  if (!avail) continue;
468 
469  if (HasVariableParameter(niv->var)) {
470  this->DrawString(r, i++, " %02x[%02x]: %08x (%s)", niv->var, param, value, niv->name);
471  } else {
472  this->DrawString(r, i++, " %02x: %08x (%s)", niv->var, value, niv->name);
473  }
474  }
475  }
476 
477  uint psa_size = nih->GetPSASize(index, this->caller_grfid);
478  const int32 *psa = nih->GetPSAFirstPosition(index, this->caller_grfid);
479  if (psa_size != 0 && psa != nullptr) {
480  if (nih->PSAWithParameter()) {
481  this->DrawString(r, i++, "Persistent storage [%08X]:", BSWAP32(this->caller_grfid));
482  } else {
483  this->DrawString(r, i++, "Persistent storage:");
484  }
485  assert(psa_size % 4 == 0);
486  for (uint j = 0; j < psa_size; j += 4, psa += 4) {
487  this->DrawString(r, i++, " %i: %i %i %i %i", j, psa[0], psa[1], psa[2], psa[3]);
488  }
489  }
490 
491  if (nif->properties != nullptr) {
492  this->DrawString(r, i++, "Properties:");
493  for (const NIProperty *nip = nif->properties; nip->name != nullptr; nip++) {
494  const void *ptr = (const byte *)base + nip->offset;
495  uint value;
496  switch (nip->read_size) {
497  case 1: value = *(const uint8 *)ptr; break;
498  case 2: value = *(const uint16 *)ptr; break;
499  case 4: value = *(const uint32 *)ptr; break;
500  default: NOT_REACHED();
501  }
502 
503  StringID string;
504  SetDParam(0, value);
505  switch (nip->type) {
506  case NIT_INT:
507  string = STR_JUST_INT;
508  break;
509 
510  case NIT_CARGO:
511  string = value != INVALID_CARGO ? CargoSpec::Get(value)->name : STR_QUANTITY_N_A;
512  break;
513 
514  default:
515  NOT_REACHED();
516  }
517 
518  char buffer[64];
519  GetString(buffer, string, lastof(buffer));
520  this->DrawString(r, i++, " %02x: %s (%s)", nip->prop, buffer, nip->name);
521  }
522  }
523 
524  if (nif->callbacks != nullptr) {
525  this->DrawString(r, i++, "Callbacks:");
526  for (const NICallback *nic = nif->callbacks; nic->name != nullptr; nic++) {
527  if (nic->cb_bit != CBM_NO_BIT) {
528  const void *ptr = (const byte *)base_spec + nic->offset;
529  uint value;
530  switch (nic->read_size) {
531  case 1: value = *(const uint8 *)ptr; break;
532  case 2: value = *(const uint16 *)ptr; break;
533  case 4: value = *(const uint32 *)ptr; break;
534  default: NOT_REACHED();
535  }
536 
537  if (!HasBit(value, nic->cb_bit)) continue;
538  this->DrawString(r, i++, " %03x: %s", nic->cb_id, nic->name);
539  } else {
540  this->DrawString(r, i++, " %03x: %s (unmasked)", nic->cb_id, nic->name);
541  }
542  }
543  }
544 
545  /* Not nice and certainly a hack, but it beats duplicating
546  * this whole function just to count the actual number of
547  * elements. Especially because they need to be redrawn. */
548  const_cast<NewGRFInspectWindow*>(this)->vscroll->SetCount(i);
549  }
550 
551  void OnClick(Point pt, int widget, int click_count) override
552  {
553  switch (widget) {
554  case WID_NGRFI_PARENT: {
555  const NIHelper *nih = GetFeatureHelper(this->window_number);
556  uint index = nih->GetParent(this->GetFeatureIndex());
557  ::ShowNewGRFInspectWindow(GetFeatureNum(index), ::GetFeatureIndex(index), nih->GetGRFID(this->GetFeatureIndex()));
558  break;
559  }
560 
561  case WID_NGRFI_VEH_PREV:
562  if (this->chain_index > 0) {
563  this->chain_index--;
564  this->InvalidateData();
565  }
566  break;
567 
568  case WID_NGRFI_VEH_NEXT:
569  if (this->HasChainIndex()) {
570  uint index = this->GetFeatureIndex();
571  Vehicle *v = Vehicle::Get(index);
572  if (v != nullptr && v->Next() != nullptr) {
573  this->chain_index++;
574  this->InvalidateData();
575  }
576  }
577  break;
578 
579  case WID_NGRFI_MAINPANEL: {
580  /* Does this feature have variables? */
581  const NIFeature *nif = GetFeature(this->window_number);
582  if (nif->variables == nullptr) return;
583 
584  /* Get the line, make sure it's within the boundaries. */
585  int line = this->vscroll->GetScrolledRowFromWidget(pt.y, this, WID_NGRFI_MAINPANEL, TOP_OFFSET);
586  if (line == INT_MAX) return;
587 
588  /* Find the variable related to the line */
589  for (const NIVariable *niv = nif->variables; niv->name != nullptr; niv++, line--) {
590  if (line != 1) continue; // 1 because of the "Variables:" line
591 
592  if (!HasVariableParameter(niv->var)) break;
593 
594  this->current_edit_param = niv->var;
595  ShowQueryString(STR_EMPTY, STR_NEWGRF_INSPECT_QUERY_CAPTION, 9, this, CS_HEXADECIMAL, QSF_NONE);
596  }
597  }
598  }
599  }
600 
601  void OnQueryTextFinished(char *str) override
602  {
603  if (StrEmpty(str)) return;
604 
605  NewGRFInspectWindow::var60params[GetFeatureNum(this->window_number)][this->current_edit_param - 0x60] = strtol(str, nullptr, 16);
606  this->SetDirty();
607  }
608 
609  void OnResize() override
610  {
612  }
613 
619  void OnInvalidateData(int data = 0, bool gui_scope = true) override
620  {
621  if (!gui_scope) return;
622  if (this->HasChainIndex()) {
623  this->ValidateChainIndex();
624  this->SetWidgetDisabledState(WID_NGRFI_VEH_PREV, this->chain_index == 0);
625  Vehicle *v = Vehicle::Get(this->GetFeatureIndex());
626  this->SetWidgetDisabledState(WID_NGRFI_VEH_NEXT, v == nullptr || v->Next() == nullptr);
627  }
628  }
629 };
630 
631 /* static */ uint32 NewGRFInspectWindow::var60params[GSF_FAKE_END][0x20] = { {0} }; // Use spec to have 0s in whole array
632 
633 static const NWidgetPart _nested_newgrf_inspect_chain_widgets[] = {
635  NWidget(WWT_CLOSEBOX, COLOUR_GREY),
636  NWidget(WWT_CAPTION, COLOUR_GREY, WID_NGRFI_CAPTION), SetDataTip(STR_NEWGRF_INSPECT_CAPTION, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS),
637  NWidget(WWT_SHADEBOX, COLOUR_GREY),
638  NWidget(WWT_DEFSIZEBOX, COLOUR_GREY),
639  NWidget(WWT_STICKYBOX, COLOUR_GREY),
640  EndContainer(),
641  NWidget(WWT_PANEL, COLOUR_GREY),
645  NWidget(WWT_EMPTY, COLOUR_GREY, WID_NGRFI_VEH_CHAIN), SetFill(1, 0), SetResize(1, 0),
646  EndContainer(),
647  EndContainer(),
652  NWidget(WWT_RESIZEBOX, COLOUR_GREY),
653  EndContainer(),
654  EndContainer(),
655 };
656 
657 static const NWidgetPart _nested_newgrf_inspect_widgets[] = {
659  NWidget(WWT_CLOSEBOX, COLOUR_GREY),
660  NWidget(WWT_CAPTION, COLOUR_GREY, WID_NGRFI_CAPTION), SetDataTip(STR_NEWGRF_INSPECT_CAPTION, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS),
661  NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_NGRFI_PARENT), SetDataTip(STR_NEWGRF_INSPECT_PARENT_BUTTON, STR_NEWGRF_INSPECT_PARENT_TOOLTIP),
662  NWidget(WWT_SHADEBOX, COLOUR_GREY),
663  NWidget(WWT_DEFSIZEBOX, COLOUR_GREY),
664  NWidget(WWT_STICKYBOX, COLOUR_GREY),
665  EndContainer(),
670  NWidget(WWT_RESIZEBOX, COLOUR_GREY),
671  EndContainer(),
672  EndContainer(),
673 };
674 
675 static WindowDesc _newgrf_inspect_chain_desc(
676  WDP_AUTO, "newgrf_inspect_chain", 400, 300,
678  0,
679  _nested_newgrf_inspect_chain_widgets, lengthof(_nested_newgrf_inspect_chain_widgets)
680 );
681 
682 static WindowDesc _newgrf_inspect_desc(
683  WDP_AUTO, "newgrf_inspect", 400, 300,
685  0,
686  _nested_newgrf_inspect_widgets, lengthof(_nested_newgrf_inspect_widgets)
687 );
688 
698 void ShowNewGRFInspectWindow(GrfSpecFeature feature, uint index, const uint32 grfid)
699 {
700  if (!IsNewGRFInspectable(feature, index)) return;
701 
702  WindowNumber wno = GetInspectWindowNumber(feature, index);
703  WindowDesc *desc = (feature == GSF_TRAINS || feature == GSF_ROADVEHICLES) ? &_newgrf_inspect_chain_desc : &_newgrf_inspect_desc;
704  NewGRFInspectWindow *w = AllocateWindowDescFront<NewGRFInspectWindow>(desc, wno, true);
705  w->SetCallerGRFID(grfid);
706 }
707 
717 {
718  if (feature == GSF_INVALID) return;
719 
720  WindowNumber wno = GetInspectWindowNumber(feature, index);
722 }
723 
732 void DeleteNewGRFInspectWindow(GrfSpecFeature feature, uint index)
733 {
734  if (feature == GSF_INVALID) return;
735 
736  WindowNumber wno = GetInspectWindowNumber(feature, index);
738 
739  /* Reinitialise the land information window to remove the "debug" sprite if needed.
740  * Note: Since we might be called from a command here, it is important to not execute
741  * the invalidation immediately. The landinfo window tests commands itself. */
743 }
744 
754 bool IsNewGRFInspectable(GrfSpecFeature feature, uint index)
755 {
756  const NIFeature *nif = GetFeature(GetInspectWindowNumber(feature, index));
757  if (nif == nullptr) return false;
758  return nif->helper->IsInspectable(index);
759 }
760 
767 {
768  switch (GetTileType(tile)) {
769  default: return GSF_INVALID;
770  case MP_RAILWAY: return GSF_RAILTYPES;
771  case MP_ROAD: return IsLevelCrossing(tile) ? GSF_RAILTYPES : GSF_INVALID;
772  case MP_HOUSE: return GSF_HOUSES;
773  case MP_INDUSTRY: return GSF_INDUSTRYTILES;
774  case MP_OBJECT: return GSF_OBJECTS;
775 
776  case MP_STATION:
777  switch (GetStationType(tile)) {
778  case STATION_RAIL: return GSF_STATIONS;
779  case STATION_AIRPORT: return GSF_AIRPORTTILES;
780  default: return GSF_INVALID;
781  }
782  }
783 }
784 
791 {
792  switch (type) {
793  case VEH_TRAIN: return GSF_TRAINS;
794  case VEH_ROAD: return GSF_ROADVEHICLES;
795  case VEH_SHIP: return GSF_SHIPS;
796  case VEH_AIRCRAFT: return GSF_AIRCRAFT;
797  default: return GSF_INVALID;
798  }
799 }
800 
801 
802 
803 /**** Sprite Aligner ****/
804 
807  typedef std::pair<int16, int16> XyOffs;
808 
810  Scrollbar *vscroll;
812 
814  {
815  this->CreateNestedTree();
816  this->vscroll = this->GetScrollbar(WID_SA_SCROLLBAR);
817  this->FinishInitNested(wno);
818 
819  /* Oh yes, we assume there is at least one normal sprite! */
820  while (GetSpriteType(this->current_sprite) != ST_NORMAL) this->current_sprite++;
821  }
822 
823  void SetStringParameters(int widget) const override
824  {
825  const Sprite *spr = GetSprite(this->current_sprite, ST_NORMAL);
826  switch (widget) {
827  case WID_SA_CAPTION:
828  SetDParam(0, this->current_sprite);
829  SetDParamStr(1, FioGetFilename(GetOriginFileSlot(this->current_sprite)));
830  break;
831 
832  case WID_SA_OFFSETS_ABS:
833  SetDParam(0, spr->x_offs);
834  SetDParam(1, spr->y_offs);
835  break;
836 
837  case WID_SA_OFFSETS_REL: {
838  /* Relative offset is new absolute offset - starting absolute offset.
839  * Show 0, 0 as the relative offsets if entry is not in the map (meaning they have not been changed yet).
840  */
841  const auto key_offs_pair = this->offs_start_map.Find(this->current_sprite);
842  if (key_offs_pair != this->offs_start_map.end()) {
843  SetDParam(0, spr->x_offs - key_offs_pair->second.first);
844  SetDParam(1, spr->y_offs - key_offs_pair->second.second);
845  } else {
846  SetDParam(0, 0);
847  SetDParam(1, 0);
848  }
849  break;
850  }
851 
852  default:
853  break;
854  }
855  }
856 
857  void UpdateWidgetSize(int widget, Dimension *size, const Dimension &padding, Dimension *fill, Dimension *resize) override
858  {
859  switch (widget) {
860  case WID_SA_SPRITE:
861  size->height = ScaleGUITrad(200);
862  break;
863  case WID_SA_LIST:
864  resize->height = std::max(11, FONT_HEIGHT_NORMAL + 1);
865  resize->width = 1;
866  break;
867  default:
868  break;
869  }
870  }
871 
872  void DrawWidget(const Rect &r, int widget) const override
873  {
874  switch (widget) {
875  case WID_SA_SPRITE: {
876  /* Center the sprite ourselves */
877  const Sprite *spr = GetSprite(this->current_sprite, ST_NORMAL);
878  int width = r.right - r.left + 1 - WD_BEVEL_LEFT - WD_BEVEL_RIGHT;
879  int height = r.bottom - r.top + 1 - WD_BEVEL_TOP - WD_BEVEL_BOTTOM;
880  int x = -UnScaleGUI(spr->x_offs) + (width - UnScaleGUI(spr->width) ) / 2;
881  int y = -UnScaleGUI(spr->y_offs) + (height - UnScaleGUI(spr->height)) / 2;
882 
883  DrawPixelInfo new_dpi;
884  if (!FillDrawPixelInfo(&new_dpi, r.left + WD_BEVEL_LEFT, r.top + WD_BEVEL_TOP, width, height)) break;
885  DrawPixelInfo *old_dpi = _cur_dpi;
886  _cur_dpi = &new_dpi;
887 
888  DrawSprite(this->current_sprite, PAL_NONE, x, y, nullptr, ZOOM_LVL_GUI);
889 
890  _cur_dpi = old_dpi;
891 
892  break;
893  }
894 
895  case WID_SA_LIST: {
896  const NWidgetBase *nwid = this->GetWidget<NWidgetBase>(widget);
897  int step_size = nwid->resize_y;
898 
899  std::vector<SpriteID> &list = _newgrf_debug_sprite_picker.sprites;
900  int max = std::min<int>(this->vscroll->GetPosition() + this->vscroll->GetCapacity(), (uint)list.size());
901 
902  int y = r.top + WD_FRAMERECT_TOP;
903  for (int i = this->vscroll->GetPosition(); i < max; i++) {
904  SetDParam(0, list[i]);
905  DrawString(r.left + WD_FRAMERECT_LEFT, r.right - WD_FRAMERECT_RIGHT, y, STR_BLACK_COMMA, TC_FROMSTRING, SA_RIGHT | SA_FORCE);
906  y += step_size;
907  }
908  break;
909  }
910  }
911  }
912 
913  void OnClick(Point pt, int widget, int click_count) override
914  {
915  switch (widget) {
916  case WID_SA_PREVIOUS:
917  do {
918  this->current_sprite = (this->current_sprite == 0 ? GetMaxSpriteID() : this->current_sprite) - 1;
919  } while (GetSpriteType(this->current_sprite) != ST_NORMAL);
920  this->SetDirty();
921  break;
922 
923  case WID_SA_GOTO:
924  ShowQueryString(STR_EMPTY, STR_SPRITE_ALIGNER_GOTO_CAPTION, 7, this, CS_NUMERAL, QSF_NONE);
925  break;
926 
927  case WID_SA_NEXT:
928  do {
929  this->current_sprite = (this->current_sprite + 1) % GetMaxSpriteID();
930  } while (GetSpriteType(this->current_sprite) != ST_NORMAL);
931  this->SetDirty();
932  break;
933 
934  case WID_SA_PICKER:
935  this->LowerWidget(WID_SA_PICKER);
936  _newgrf_debug_sprite_picker.mode = SPM_WAIT_CLICK;
937  this->SetDirty();
938  break;
939 
940  case WID_SA_LIST: {
941  const NWidgetBase *nwid = this->GetWidget<NWidgetBase>(widget);
942  int step_size = nwid->resize_y;
943 
944  uint i = this->vscroll->GetPosition() + (pt.y - nwid->pos_y) / step_size;
945  if (i < _newgrf_debug_sprite_picker.sprites.size()) {
947  if (GetSpriteType(spr) == ST_NORMAL) this->current_sprite = spr;
948  }
949  this->SetDirty();
950  break;
951  }
952 
953  case WID_SA_UP:
954  case WID_SA_DOWN:
955  case WID_SA_LEFT:
956  case WID_SA_RIGHT: {
957  /*
958  * Yes... this is a hack.
959  *
960  * No... I don't think it is useful to make this less of a hack.
961  *
962  * If you want to align sprites, you just need the number. Generally
963  * the sprite caches are big enough to not remove the sprite from the
964  * cache. If that's not the case, just let the NewGRF developer
965  * increase the cache size instead of storing thousands of offsets
966  * for the incredibly small chance that it's actually going to be
967  * used by someone and the sprite cache isn't big enough for that
968  * particular NewGRF developer.
969  */
970  Sprite *spr = const_cast<Sprite *>(GetSprite(this->current_sprite, ST_NORMAL));
971 
972  /* Remember the original offsets of the current sprite, if not already in mapping. */
973  if (!(this->offs_start_map.Contains(this->current_sprite))) {
974  this->offs_start_map.Insert(this->current_sprite, XyOffs(spr->x_offs, spr->y_offs));
975  }
976  switch (widget) {
977  /* Move eight units at a time if ctrl is pressed. */
978  case WID_SA_UP: spr->y_offs -= _ctrl_pressed ? 8 : 1; break;
979  case WID_SA_DOWN: spr->y_offs += _ctrl_pressed ? 8 : 1; break;
980  case WID_SA_LEFT: spr->x_offs -= _ctrl_pressed ? 8 : 1; break;
981  case WID_SA_RIGHT: spr->x_offs += _ctrl_pressed ? 8 : 1; break;
982  }
983  /* Of course, we need to redraw the sprite, but where is it used?
984  * Everywhere is a safe bet. */
986  break;
987  }
988 
989  case WID_SA_RESET_REL:
990  /* Reset the starting offsets for the current sprite. */
991  this->offs_start_map.Erase(this->current_sprite);
992  this->SetDirty();
993  break;
994  }
995  }
996 
997  void OnQueryTextFinished(char *str) override
998  {
999  if (StrEmpty(str)) return;
1000 
1001  this->current_sprite = atoi(str);
1002  if (this->current_sprite >= GetMaxSpriteID()) this->current_sprite = 0;
1003  while (GetSpriteType(this->current_sprite) != ST_NORMAL) {
1004  this->current_sprite = (this->current_sprite + 1) % GetMaxSpriteID();
1005  }
1006  this->SetDirty();
1007  }
1008 
1014  void OnInvalidateData(int data = 0, bool gui_scope = true) override
1015  {
1016  if (!gui_scope) return;
1017  if (data == 1) {
1018  /* Sprite picker finished */
1019  this->RaiseWidget(WID_SA_PICKER);
1020  this->vscroll->SetCount((uint)_newgrf_debug_sprite_picker.sprites.size());
1021  }
1022  }
1023 
1024  void OnResize() override
1025  {
1026  this->vscroll->SetCapacityFromWidget(this, WID_SA_LIST);
1027  }
1028 };
1029 
1030 static const NWidgetPart _nested_sprite_aligner_widgets[] = {
1032  NWidget(WWT_CLOSEBOX, COLOUR_GREY),
1033  NWidget(WWT_CAPTION, COLOUR_GREY, WID_SA_CAPTION), SetDataTip(STR_SPRITE_ALIGNER_CAPTION, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS),
1034  NWidget(WWT_SHADEBOX, COLOUR_GREY),
1035  NWidget(WWT_STICKYBOX, COLOUR_GREY),
1036  EndContainer(),
1037  NWidget(WWT_PANEL, COLOUR_GREY),
1038  NWidget(NWID_HORIZONTAL), SetPIP(0, 0, 10),
1039  NWidget(NWID_VERTICAL), SetPIP(10, 5, 10),
1041  NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SA_PREVIOUS), SetDataTip(STR_SPRITE_ALIGNER_PREVIOUS_BUTTON, STR_SPRITE_ALIGNER_PREVIOUS_TOOLTIP), SetFill(1, 0),
1042  NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SA_GOTO), SetDataTip(STR_SPRITE_ALIGNER_GOTO_BUTTON, STR_SPRITE_ALIGNER_GOTO_TOOLTIP), SetFill(1, 0),
1043  NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SA_NEXT), SetDataTip(STR_SPRITE_ALIGNER_NEXT_BUTTON, STR_SPRITE_ALIGNER_NEXT_TOOLTIP), SetFill(1, 0),
1044  EndContainer(),
1045  NWidget(NWID_HORIZONTAL), SetPIP(10, 5, 10),
1046  NWidget(NWID_SPACER), SetFill(1, 1),
1047  NWidget(WWT_PUSHIMGBTN, COLOUR_GREY, WID_SA_UP), SetDataTip(SPR_ARROW_UP, STR_SPRITE_ALIGNER_MOVE_TOOLTIP), SetResize(0, 0),
1048  NWidget(NWID_SPACER), SetFill(1, 1),
1049  EndContainer(),
1050  NWidget(NWID_HORIZONTAL_LTR), SetPIP(10, 5, 10),
1052  NWidget(NWID_SPACER), SetFill(1, 1),
1053  NWidget(WWT_PUSHIMGBTN, COLOUR_GREY, WID_SA_LEFT), SetDataTip(SPR_ARROW_LEFT, STR_SPRITE_ALIGNER_MOVE_TOOLTIP), SetResize(0, 0),
1054  NWidget(NWID_SPACER), SetFill(1, 1),
1055  EndContainer(),
1056  NWidget(WWT_PANEL, COLOUR_DARK_BLUE, WID_SA_SPRITE), SetDataTip(STR_NULL, STR_SPRITE_ALIGNER_SPRITE_TOOLTIP),
1057  EndContainer(),
1059  NWidget(NWID_SPACER), SetFill(1, 1),
1060  NWidget(WWT_PUSHIMGBTN, COLOUR_GREY, WID_SA_RIGHT), SetDataTip(SPR_ARROW_RIGHT, STR_SPRITE_ALIGNER_MOVE_TOOLTIP), SetResize(0, 0),
1061  NWidget(NWID_SPACER), SetFill(1, 1),
1062  EndContainer(),
1063  EndContainer(),
1064  NWidget(NWID_HORIZONTAL), SetPIP(10, 5, 10),
1065  NWidget(NWID_SPACER), SetFill(1, 1),
1066  NWidget(WWT_PUSHIMGBTN, COLOUR_GREY, WID_SA_DOWN), SetDataTip(SPR_ARROW_DOWN, STR_SPRITE_ALIGNER_MOVE_TOOLTIP), SetResize(0, 0),
1067  NWidget(NWID_SPACER), SetFill(1, 1),
1068  EndContainer(),
1069  NWidget(WWT_LABEL, COLOUR_GREY, WID_SA_OFFSETS_ABS), SetDataTip(STR_SPRITE_ALIGNER_OFFSETS_ABS, STR_NULL), SetFill(1, 0), SetPadding(0, 10, 0, 10),
1070  NWidget(WWT_LABEL, COLOUR_GREY, WID_SA_OFFSETS_REL), SetDataTip(STR_SPRITE_ALIGNER_OFFSETS_REL, STR_NULL), SetFill(1, 0), SetPadding(0, 10, 0, 10),
1071  NWidget(NWID_HORIZONTAL), SetPIP(10, 5, 10),
1072  NWidget(NWID_SPACER), SetFill(1, 1),
1073  NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SA_RESET_REL), SetDataTip(STR_SPRITE_ALIGNER_RESET_BUTTON, STR_SPRITE_ALIGNER_RESET_TOOLTIP), SetFill(0, 0),
1074  NWidget(NWID_SPACER), SetFill(1, 1),
1075  EndContainer(),
1076  EndContainer(),
1077  NWidget(NWID_VERTICAL), SetPIP(10, 5, 10),
1078  NWidget(WWT_TEXTBTN, COLOUR_GREY, WID_SA_PICKER), SetDataTip(STR_SPRITE_ALIGNER_PICKER_BUTTON, STR_SPRITE_ALIGNER_PICKER_TOOLTIP), SetFill(1, 0),
1080  NWidget(WWT_MATRIX, COLOUR_GREY, WID_SA_LIST), SetResize(1, 1), SetMatrixDataTip(1, 0, STR_NULL), SetFill(1, 1), SetScrollbar(WID_SA_SCROLLBAR),
1081  NWidget(NWID_VSCROLLBAR, COLOUR_GREY, WID_SA_SCROLLBAR),
1082  EndContainer(),
1083  EndContainer(),
1084  EndContainer(),
1085  EndContainer(),
1086 };
1087 
1088 static WindowDesc _sprite_aligner_desc(
1089  WDP_AUTO, "sprite_aligner", 400, 300,
1091  0,
1092  _nested_sprite_aligner_widgets, lengthof(_nested_sprite_aligner_widgets)
1093 );
1094 
1099 {
1100  AllocateWindowDescFront<SpriteAlignerWindow>(&_sprite_aligner_desc, 0);
1101 }
VEH_AIRCRAFT
@ VEH_AIRCRAFT
Aircraft vehicle type.
Definition: vehicle_type.h:27
Train::GetDisplayImageWidth
int GetDisplayImageWidth(Point *offset=nullptr) const
Get the width of a train vehicle image in the GUI.
Definition: train_cmd.cpp:432
SpriteAlignerWindow::OnResize
void OnResize() override
Called after the window got resized.
Definition: newgrf_debug_gui.cpp:1024
MP_HOUSE
@ MP_HOUSE
A house by a town.
Definition: tile_type.h:44
WID_SA_DOWN
@ WID_SA_DOWN
Move the sprite down.
Definition: newgrf_debug_widget.h:33
INVALID_CARGO
static const byte INVALID_CARGO
Constant representing invalid cargo.
Definition: cargotype.h:52
WID_SA_RESET_REL
@ WID_SA_RESET_REL
Reset relative sprite offset.
Definition: newgrf_debug_widget.h:40
WID_NGRFI_MAINPANEL
@ WID_NGRFI_MAINPANEL
Panel widget containing the actual data.
Definition: newgrf_debug_widget.h:20
WD_FRAMERECT_TOP
@ WD_FRAMERECT_TOP
Offset at top to draw the frame rectangular area.
Definition: window_gui.h:62
TileIndex
uint32 TileIndex
The index/ID of a Tile.
Definition: tile_type.h:78
InvalidateWindowData
void InvalidateWindowData(WindowClass cls, WindowNumber number, int data, bool gui_scope)
Mark window data of the window of a given class and specific window number as invalid (in need of re-...
Definition: window.cpp:3319
newgrf_station.h
VehicleCellSize::height
uint height
Vehicle cell height.
Definition: vehicle_gui.h:78
Pool::PoolItem<&_vehicle_pool >::Get
static Titem * Get(size_t index)
Returns Titem with given index.
Definition: pool_type.hpp:329
vehicle_gui.h
NewGRFInspectWindow::chain_index
uint chain_index
For ground vehicles: Index in vehicle chain.
Definition: newgrf_debug_gui.cpp:286
WID_NGRFI_VEH_CHAIN
@ WID_NGRFI_VEH_CHAIN
Display for vehicle chain.
Definition: newgrf_debug_widget.h:19
SetScrollbar
static NWidgetPart SetScrollbar(int index)
Attach a scrollbar to a widget.
Definition: widget_type.h:1094
GB
static uint GB(const T x, const uint8 s, const uint8 n)
Fetch n bits from x, started at bit s.
Definition: bitmath_func.hpp:32
train.h
Dimension
Dimensions (a width and height) of a rectangle in 2D.
Definition: geometry_type.hpp:27
Scrollbar::GetCapacity
uint16 GetCapacity() const
Gets the number of visible elements of the scrollbar.
Definition: widget_type.h:621
newgrf_debug_widget.h
WID_NGRFI_VEH_PREV
@ WID_NGRFI_VEH_PREV
Go to previous vehicle in chain.
Definition: newgrf_debug_widget.h:17
CBM_NO_BIT
static const int CBM_NO_BIT
Mask to show no bit needs to be enabled for the callback.
Definition: newgrf_debug_gui.cpp:104
WWT_STICKYBOX
@ WWT_STICKYBOX
Sticky box (at top-right of a window, after WWT_DEFSIZEBOX)
Definition: widget_type.h:64
SetPadding
static NWidgetPart SetPadding(uint8 top, uint8 right, uint8 bottom, uint8 left)
Widget part function for setting additional space around a widget.
Definition: widget_type.h:1045
Window::GetScrollbar
const Scrollbar * GetScrollbar(uint widnum) const
Return the Scrollbar to a widget index.
Definition: window.cpp:309
WC_LAND_INFO
@ WC_LAND_INFO
Land info window; Window numbers:
Definition: window_type.h:143
NIT_INT
@ NIT_INT
The property is a simple integer.
Definition: newgrf_debug_gui.cpp:78
NewGRFInspectWindow::var60params
static uint32 var60params[GSF_FAKE_END][0x20]
The value for the variable 60 parameters.
Definition: newgrf_debug_gui.cpp:280
WID_SA_SCROLLBAR
@ WID_SA_SCROLLBAR
Scrollbar for sprite list.
Definition: newgrf_debug_widget.h:39
SpriteAlignerWindow::OnClick
void OnClick(Point pt, int widget, int click_count) override
A click with the left mouse button has been made on the window.
Definition: newgrf_debug_gui.cpp:913
Vehicle::Next
Vehicle * Next() const
Get the next vehicle of this vehicle.
Definition: vehicle_base.h:592
WWT_CAPTION
@ WWT_CAPTION
Window caption (window title between closebox and stickybox)
Definition: widget_type.h:59
WID_NGRFI_PARENT
@ WID_NGRFI_PARENT
Inspect the parent.
Definition: newgrf_debug_widget.h:16
Scrollbar::GetScrolledRowFromWidget
int GetScrolledRowFromWidget(int clickpos, const Window *const w, int widget, int padding=0, int line_height=-1) const
Compute the row of a scrolled widget that a user clicked in.
Definition: widget.cpp:1966
SA_RIGHT
@ SA_RIGHT
Right align the text (must be a single bit).
Definition: gfx_func.h:96
NewGRFInspectWindow::HasChainIndex
bool HasChainIndex() const
Check whether this feature has chain index, i.e.
Definition: newgrf_debug_gui.cpp:316
WWT_LABEL
@ WWT_LABEL
Centered label.
Definition: widget_type.h:55
NICallback
Representation of the available callbacks with information on when they actually apply.
Definition: newgrf_debug_gui.cpp:96
DrawVehicleImage
void DrawVehicleImage(const Vehicle *v, int left, int right, int y, VehicleID selection, EngineImageType image_type, int skip)
Draws an image of a vehicle chain.
Definition: vehicle_gui.cpp:1478
WWT_DEFSIZEBOX
@ WWT_DEFSIZEBOX
Default window size box (at top-right of a window, between WWT_SHADEBOX and WWT_STICKYBOX)
Definition: widget_type.h:63
Window::CreateNestedTree
void CreateNestedTree(bool fill_nested=true)
Perform the first part of the initialization of a nested widget tree.
Definition: window.cpp:1832
NIType
NIType
The type of a property to show.
Definition: newgrf_debug_gui.cpp:77
NewGrfDebugSpritePicker::sprites
std::vector< SpriteID > sprites
Sprites found.
Definition: newgrf_debug.h:30
WID_SA_LEFT
@ WID_SA_LEFT
Move the sprite to the left.
Definition: newgrf_debug_widget.h:31
NewGrfDebugSpritePicker::mode
NewGrfDebugSpritePickerMode mode
Current state.
Definition: newgrf_debug.h:27
WID_SA_LIST
@ WID_SA_LIST
Queried sprite list.
Definition: newgrf_debug_widget.h:38
Pool::PoolItem::index
Tindex index
Index of this pool item.
Definition: pool_type.hpp:227
InvalidateNewGRFInspectWindow
void InvalidateNewGRFInspectWindow(GrfSpecFeature feature, uint index)
Invalidate the inspect window for a given feature and index.
Definition: newgrf_debug_gui.cpp:716
CargoSpec::Get
static CargoSpec * Get(size_t index)
Retrieve cargo details for the given cargo ID.
Definition: cargotype.h:117
NWID_HORIZONTAL
@ NWID_HORIZONTAL
Horizontal container.
Definition: widget_type.h:73
NewGRFInspectWindow::DrawWidget
void DrawWidget(const Rect &r, int widget) const override
Draw the contents of a nested widget.
Definition: newgrf_debug_gui.cpp:411
NICallback::offset
ptrdiff_t offset
Offset of the variable in the class.
Definition: newgrf_debug_gui.cpp:98
WWT_MATRIX
@ WWT_MATRIX
Grid of rows and columns.
Definition: widget_type.h:57
NWID_HORIZONTAL_LTR
@ NWID_HORIZONTAL_LTR
Horizontal container that doesn't change the order of the widgets for RTL languages.
Definition: widget_type.h:74
HasBit
static bool HasBit(const T x, const uint8 y)
Checks if a bit in a value is set.
Definition: bitmath_func.hpp:103
UnScaleGUI
static int UnScaleGUI(int value)
Short-hand to apply GUI zoom level.
Definition: zoom_func.h:66
Scrollbar::SetCount
void SetCount(int num)
Sets the number of elements in the list.
Definition: widget_type.h:669
Sprite::height
uint16 height
Height of the sprite.
Definition: spritecache.h:17
_ctrl_pressed
bool _ctrl_pressed
Is Ctrl pressed?
Definition: gfx.cpp:35
MP_RAILWAY
@ MP_RAILWAY
A railway.
Definition: tile_type.h:42
vehicle_base.h
SetResize
static NWidgetPart SetResize(int16 dx, int16 dy)
Widget part function for setting the resize step.
Definition: widget_type.h:929
zoom_func.h
Sprite::x_offs
int16 x_offs
Number of pixels to shift the sprite to the right.
Definition: spritecache.h:19
fileio_func.h
GetFeatureHelper
static const NIHelper * GetFeatureHelper(uint window_number)
Get the NIHelper related to the window number.
Definition: newgrf_debug_gui.cpp:267
NIFeature::properties
const NIProperty * properties
The properties associated with this feature.
Definition: newgrf_debug_gui.cpp:231
NIHelper::Resolve
virtual uint Resolve(uint index, uint var, uint param, bool *avail) const =0
Resolve (action2) variable for a given index.
DrawString
int DrawString(int left, int right, int top, const char *str, TextColour colour, StringAlignment align, bool underline, FontSize fontsize)
Draw string, possibly truncated to make it fit in its allocated space.
Definition: gfx.cpp:636
EIT_IN_DETAILS
@ EIT_IN_DETAILS
Vehicle drawn in vehicle details, refit window, ...
Definition: vehicle_type.h:88
WWT_EMPTY
@ WWT_EMPTY
Empty widget, place holder to reserve space in widget array.
Definition: widget_type.h:46
MP_INDUSTRY
@ MP_INDUSTRY
Part of an industry.
Definition: tile_type.h:49
newgrf_debug.h
town.h
WWT_PUSHARROWBTN
@ WWT_PUSHARROWBTN
Normal push-button (no toggle button) with arrow caption.
Definition: widget_type.h:104
ST_NORMAL
@ ST_NORMAL
The most basic (normal) sprite.
Definition: gfx_type.h:302
WindowNumber
int32 WindowNumber
Number to differentiate different windows of the same class.
Definition: window_type.h:711
NewGRFInspectWindow::OnInvalidateData
void OnInvalidateData(int data=0, bool gui_scope=true) override
Some data on this window has become invalid.
Definition: newgrf_debug_gui.cpp:619
NICallback::cb_id
uint16 cb_id
The number of the callback.
Definition: newgrf_debug_gui.cpp:101
NICallback::name
const char * name
The human readable name of the callback.
Definition: newgrf_debug_gui.cpp:97
GSF_INVALID
@ GSF_INVALID
An invalid spec feature.
Definition: newgrf.h:92
VEH_ROAD
@ VEH_ROAD
Road vehicle type.
Definition: vehicle_type.h:25
Vehicle
Vehicle data structure.
Definition: vehicle_base.h:222
GetSpriteType
SpriteType GetSpriteType(SpriteID sprite)
Get the sprite type of a given sprite.
Definition: spritecache.cpp:131
SA_FORCE
@ SA_FORCE
Force the alignment, i.e. don't swap for RTL languages.
Definition: gfx_func.h:106
NewGRFInspectWindow::current_edit_param
byte current_edit_param
The currently edited parameter, to update the right one.
Definition: newgrf_debug_gui.cpp:289
WID_SA_SPRITE
@ WID_SA_SPRITE
The actual sprite.
Definition: newgrf_debug_widget.h:34
NIFeature::variables
const NIVariable * variables
The variables associated with this feature.
Definition: newgrf_debug_gui.cpp:233
Scrollbar
Scrollbar data structure.
Definition: widget_type.h:588
SmallMap::Insert
bool Insert(const T &key, const U &data)
Adds new item to this map.
Definition: smallmap_type.hpp:127
NewGRFInspectWindow::SetStringParameters
void SetStringParameters(int widget) const override
Initialize string parameters for a widget.
Definition: newgrf_debug_gui.cpp:364
MP_ROAD
@ MP_ROAD
A tile with road (or tram tracks)
Definition: tile_type.h:43
NIHelper
Helper class to wrap some functionality/queries in.
Definition: newgrf_debug_gui.cpp:113
SetDParam
static void SetDParam(uint n, uint64 v)
Set a string parameter v at index n in the global string parameter array.
Definition: strings_func.h:199
GetVehicleImageCellSize
VehicleCellSize GetVehicleImageCellSize(VehicleType type, EngineImageType image_type)
Get the GUI cell size for a vehicle image.
Definition: depot_gui.cpp:158
NWidgetPart
Partial widget specification to allow NWidgets to be written nested.
Definition: widget_type.h:909
SetDataTip
static NWidgetPart SetDataTip(uint32 data, StringID tip)
Widget part function for setting the data and tooltip.
Definition: widget_type.h:1013
IsLevelCrossing
static bool IsLevelCrossing(TileIndex t)
Return whether a tile is a level crossing.
Definition: road_map.h:84
IsNewGRFInspectable
bool IsNewGRFInspectable(GrfSpecFeature feature, uint index)
Can we inspect the data given a certain feature and index.
Definition: newgrf_debug_gui.cpp:754
NIProperty
Representation of the data from a NewGRF property.
Definition: newgrf_debug_gui.cpp:83
NIProperty::read_size
byte read_size
Number of bytes (i.e. byte, word, dword etc)
Definition: newgrf_debug_gui.cpp:86
DeleteNewGRFInspectWindow
void DeleteNewGRFInspectWindow(GrfSpecFeature feature, uint index)
Delete inspect window for a given feature and index.
Definition: newgrf_debug_gui.cpp:732
textbuf_gui.h
object_base.h
SmallMap< SpriteID, XyOffs >
SpriteAlignerWindow::XyOffs
std::pair< int16, int16 > XyOffs
Pair for x and y offsets of the sprite before alignment. First value contains the x offset,...
Definition: newgrf_debug_gui.cpp:807
SpriteID
uint32 SpriteID
The number of a sprite, without mapping bits and colourtables.
Definition: gfx_type.h:17
WID_SA_RIGHT
@ WID_SA_RIGHT
Move the sprite to the right.
Definition: newgrf_debug_widget.h:32
SpriteAlignerWindow::offs_start_map
SmallMap< SpriteID, XyOffs > offs_start_map
Mapping of starting offsets for the sprites which have been aligned in the sprite aligner window.
Definition: newgrf_debug_gui.cpp:811
WindowDesc
High level window description.
Definition: window_gui.h:166
NewGRFInspectWindow::TOP_OFFSET
static const int TOP_OFFSET
Position of top edge.
Definition: newgrf_debug_gui.cpp:276
ShowNewGRFInspectWindow
void ShowNewGRFInspectWindow(GrfSpecFeature feature, uint index, const uint32 grfid)
Show the inspect window for a given feature and index.
Definition: newgrf_debug_gui.cpp:698
window_gui.h
newgrf_airporttiles.h
NC_EQUALSIZE
@ NC_EQUALSIZE
Value of the NCB_EQUALSIZE flag.
Definition: widget_type.h:428
NIHelper::IsInspectable
virtual bool IsInspectable(uint index) const =0
Is the item with the given index inspectable?
GetFeature
static const NIFeature * GetFeature(uint window_number)
Get the NIFeature related to the window number.
Definition: newgrf_debug_gui.cpp:255
WDP_AUTO
@ WDP_AUTO
Find a place automatically.
Definition: window_gui.h:154
NIHelper::GetGRFID
virtual uint32 GetGRFID(uint index) const =0
Get the GRFID of the file that includes this item.
Window::resize
ResizeInfo resize
Resize information.
Definition: window_gui.h:322
NIHelper::SetStringParameters
virtual void SetStringParameters(uint index) const =0
Set the string parameters to write the right data for a STRINGn.
NICallback::read_size
byte read_size
The number of bytes (i.e. byte, word, dword etc) to read.
Definition: newgrf_debug_gui.cpp:99
NewGRFInspectWindow::BOTTOM_OFFSET
static const int BOTTOM_OFFSET
Position of bottom edge.
Definition: newgrf_debug_gui.cpp:277
_newgrf_debug_sprite_picker
NewGrfDebugSpritePicker _newgrf_debug_sprite_picker
The sprite picker.
Definition: newgrf_debug_gui.cpp:48
Window::height
int height
Height of the window (number of pixels down in y direction)
Definition: window_gui.h:320
NewGRFInspectWindow::LEFT_OFFSET
static const int LEFT_OFFSET
Position of left edge.
Definition: newgrf_debug_gui.cpp:274
NIHelper::GetPSASize
virtual uint GetPSASize(uint index, uint32 grfid) const
Allows to know the size of the persistent storage.
Definition: newgrf_debug_gui.cpp:184
INVALID_VEHICLE
static const VehicleID INVALID_VEHICLE
Constant representing a non-existing vehicle.
Definition: vehicle_type.h:55
Window::SetDirty
void SetDirty() const
Mark entire window as dirty (in need of re-paint)
Definition: window.cpp:984
WD_FRAMERECT_LEFT
@ WD_FRAMERECT_LEFT
Offset at left to draw the frame rectangular area.
Definition: window_gui.h:60
_nifeatures
static const NIFeature *const _nifeatures[]
Table with all NIFeatures.
Definition: newgrf_debug_data.h:610
MP_OBJECT
@ MP_OBJECT
Contains objects such as transmitters and owned land.
Definition: tile_type.h:51
NIT_CARGO
@ NIT_CARGO
The property is a cargo.
Definition: newgrf_debug_gui.cpp:79
IsInsideBS
static bool IsInsideBS(const T x, const size_t base, const size_t size)
Checks if a value is between a window started at some base point.
Definition: math_func.hpp:188
WID_SA_NEXT
@ WID_SA_NEXT
Skip to the next sprite.
Definition: newgrf_debug_widget.h:29
WD_FRAMERECT_RIGHT
@ WD_FRAMERECT_RIGHT
Offset at right to draw the frame rectangular area.
Definition: window_gui.h:61
GetStationType
static StationType GetStationType(TileIndex t)
Get the station type of this tile.
Definition: station_map.h:44
WWT_PUSHTXTBTN
@ WWT_PUSHTXTBTN
Normal push-button (no toggle button) with text caption.
Definition: widget_type.h:102
NWidgetBase
Baseclass for nested widgets.
Definition: widget_type.h:124
SpriteAlignerWindow::current_sprite
SpriteID current_sprite
The currently shown sprite.
Definition: newgrf_debug_gui.cpp:809
GSF_FAKE_END
@ GSF_FAKE_END
End of the fake features.
Definition: newgrf.h:90
SetMatrixDataTip
static NWidgetPart SetMatrixDataTip(uint8 cols, uint8 rows, StringID tip)
Widget part function for setting the data and tooltip of WWT_MATRIX widgets.
Definition: widget_type.h:1031
WID_SA_CAPTION
@ WID_SA_CAPTION
Caption of the window.
Definition: newgrf_debug_widget.h:26
Window::SetWidgetDisabledState
void SetWidgetDisabledState(byte widget_index, bool disab_stat)
Sets the enabled/disabled status of a widget.
Definition: window_gui.h:392
WID_SA_OFFSETS_REL
@ WID_SA_OFFSETS_REL
The sprite offsets (relative).
Definition: newgrf_debug_widget.h:36
industry.h
safeguards.h
ShowQueryString
void ShowQueryString(StringID str, StringID caption, uint maxsize, Window *parent, CharSetFilter afilter, QueryStringFlags flags)
Show a query popup window with a textbox in it.
Definition: misc_gui.cpp:1131
Sprite::width
uint16 width
Width of the sprite.
Definition: spritecache.h:18
StrEmpty
static bool StrEmpty(const char *s)
Check if a string buffer is empty.
Definition: string_func.h:60
Window::ShowNewGRFInspectWindow
virtual void ShowNewGRFInspectWindow() const
Show the NewGRF inspection window.
Definition: window_gui.h:811
NIFeature
Container for all information for a given feature.
Definition: newgrf_debug_gui.cpp:230
SpriteAlignerWindow::UpdateWidgetSize
void UpdateWidgetSize(int widget, Dimension *size, const Dimension &padding, Dimension *fill, Dimension *resize) override
Update size and resize step of a widget in the window.
Definition: newgrf_debug_gui.cpp:857
SmallMap::Erase
void Erase(Pair *pair)
Removes given pair from this map.
Definition: smallmap_type.hpp:99
DrawSprite
void DrawSprite(SpriteID img, PaletteID pal, int x, int y, const SubSprite *sub, ZoomLevel zoom)
Draw a sprite, not in a viewport.
Definition: gfx.cpp:974
NIHelper::GetSpec
virtual const void * GetSpec(uint index) const =0
Get (NewGRF) specs given an index.
NewGRFInspectWindow::caller_grfid
uint32 caller_grfid
GRFID of the caller of this window, 0 if it has no caller.
Definition: newgrf_debug_gui.cpp:283
Point
Coordinates of a point in 2D.
Definition: geometry_type.hpp:21
NIHelper::~NIHelper
virtual ~NIHelper()
Silence a warning.
Definition: newgrf_debug_gui.cpp:116
NewGRFInspectWindow::GetFeatureIndex
uint GetFeatureIndex() const
Get the feature index.
Definition: newgrf_debug_gui.cpp:326
stdafx.h
Window::window_number
WindowNumber window_number
Window number within the window class.
Definition: window_gui.h:312
VehicleType
VehicleType
Available vehicle types.
Definition: vehicle_type.h:21
NewGRFInspectWindow::OnResize
void OnResize() override
Called after the window got resized.
Definition: newgrf_debug_gui.cpp:609
BSWAP32
static uint32 BSWAP32(uint32 x)
Perform a 32 bits endianness bitswap on x.
Definition: bitmath_func.hpp:380
GetInspectWindowNumber
static uint GetInspectWindowNumber(GrfSpecFeature feature, uint index)
Get the window number for the inspect window given a feature and index.
Definition: newgrf_debug_gui.cpp:67
NIHelper::SetObjectAtStringParameters
void SetObjectAtStringParameters(StringID string, uint32 index, TileIndex tile) const
Helper to make setting the strings easier for objects at a specific tile.
Definition: newgrf_debug_gui.cpp:219
Window::InvalidateData
void InvalidateData(int data=0, bool gui_scope=true)
Mark this window's data as invalid (in need of re-computing)
Definition: window.cpp:3259
NewGRFInspectWindow::OnClick
void OnClick(Point pt, int widget, int click_count) override
A click with the left mouse button has been made on the window.
Definition: newgrf_debug_gui.cpp:551
WC_NONE
@ WC_NONE
No window, redirects to WC_MAIN_WINDOW.
Definition: window_type.h:38
EIT_IN_DEPOT
@ EIT_IN_DEPOT
Vehicle drawn in depot.
Definition: vehicle_type.h:87
NWID_VERTICAL
@ NWID_VERTICAL
Vertical container.
Definition: widget_type.h:75
WID_NGRFI_VEH_NEXT
@ WID_NGRFI_VEH_NEXT
Go to next vehicle in chain.
Definition: newgrf_debug_widget.h:18
FillDrawPixelInfo
bool FillDrawPixelInfo(DrawPixelInfo *n, int left, int top, int width, int height)
Set up a clipping area for only drawing into a certain area.
Definition: gfx.cpp:1629
NIHelper::GetInstance
virtual const void * GetInstance(uint index) const =0
Get the instance given an index.
newgrf_object.h
newgrf_spritegroup.h
WWT_CLOSEBOX
@ WWT_CLOSEBOX
Close box (at top-left of a window)
Definition: widget_type.h:67
WWT_RESIZEBOX
@ WWT_RESIZEBOX
Resize box (normally at bottom-right of a window)
Definition: widget_type.h:66
NIFeature::callbacks
const NICallback * callbacks
The callbacks associated with this feature.
Definition: newgrf_debug_gui.cpp:232
GetFeatureIndex
static uint GetFeatureIndex(uint window_number)
Get the feature index related to the window number.
Definition: newgrf_debug_gui.cpp:55
newgrf_town.h
GrfSpecFeature
GrfSpecFeature
Definition: newgrf.h:66
string_func.h
spritecache.h
NIHelper::PSAWithParameter
virtual bool PSAWithParameter() const
Used to decide if the PSA needs a parameter or not.
Definition: newgrf_debug_gui.cpp:173
Vehicle::Move
Vehicle * Move(int n)
Get the vehicle at offset n of this vehicle chain.
Definition: vehicle_base.h:634
NewGRFInspectWindow::HasVariableParameter
static bool HasVariableParameter(uint variable)
Check whether the given variable has a parameter.
Definition: newgrf_debug_gui.cpp:298
NIHelper::GetPSAFirstPosition
virtual const int32 * GetPSAFirstPosition(uint index, uint32 grfid) const
Gets the first position of the array containing the persistent storage.
Definition: newgrf_debug_gui.cpp:195
StringID
uint32 StringID
Numeric value that represents a string, independent of the selected language.
Definition: strings_type.h:16
WWT_PUSHIMGBTN
@ WWT_PUSHIMGBTN
Normal push-button (no toggle button) with image caption.
Definition: widget_type.h:103
SpriteAlignerWindow::OnInvalidateData
void OnInvalidateData(int data=0, bool gui_scope=true) override
Some data on this window has become invalid.
Definition: newgrf_debug_gui.cpp:1014
NewGrfDebugSpritePicker
Spritepicker of SpriteAligner.
Definition: newgrf_debug.h:26
EndContainer
static NWidgetPart EndContainer()
Widget part function for denoting the end of a container (horizontal, vertical, WWT_FRAME,...
Definition: widget_type.h:998
newgrf_debug_data.h
station_base.h
strings_func.h
NWID_VSCROLLBAR
@ NWID_VSCROLLBAR
Vertical scrollbar.
Definition: widget_type.h:82
GetFeatureNum
static GrfSpecFeature GetFeatureNum(uint window_number)
Get the feature number related to the window number.
Definition: newgrf_debug_gui.cpp:245
Vehicle::First
Vehicle * First() const
Get the first vehicle of this vehicle chain.
Definition: vehicle_base.h:605
SpriteAlignerWindow::DrawWidget
void DrawWidget(const Rect &r, int widget) const override
Draw the contents of a nested widget.
Definition: newgrf_debug_gui.cpp:872
DeleteWindowById
void DeleteWindowById(WindowClass cls, WindowNumber number, bool force)
Delete a window by its class and window number (if it is open).
Definition: window.cpp:1165
newgrf_industrytiles.h
RoadVehicle::GetDisplayImageWidth
int GetDisplayImageWidth(Point *offset=nullptr) const
Get the width of a road vehicle image in the GUI.
Definition: roadveh_cmd.cpp:90
WD_BEVEL_RIGHT
@ WD_BEVEL_RIGHT
Width of right bevel border.
Definition: window_gui.h:55
SpecializedVehicle< Train, Type >::From
static Train * From(Vehicle *v)
Converts a Vehicle to SpecializedVehicle with type checking.
Definition: vehicle_base.h:1162
SpriteAlignerWindow::SetStringParameters
void SetStringParameters(int widget) const override
Initialize string parameters for a widget.
Definition: newgrf_debug_gui.cpp:823
WID_NGRFI_SCROLLBAR
@ WID_NGRFI_SCROLLBAR
Scrollbar.
Definition: newgrf_debug_widget.h:21
FONT_HEIGHT_NORMAL
#define FONT_HEIGHT_NORMAL
Height of characters in the normal (FS_NORMAL) font.
Definition: gfx_func.h:177
ShowSpriteAlignerWindow
void ShowSpriteAlignerWindow()
Show the window for aligning sprites.
Definition: newgrf_debug_gui.cpp:1098
GetMaxSpriteID
uint GetMaxSpriteID()
Get a reasonable (upper bound) estimate of the maximum SpriteID used in OpenTTD; there will be no spr...
Definition: spritecache.cpp:186
NIFeature::helper
const NIHelper * helper
The class container all helper functions.
Definition: newgrf_debug_gui.cpp:234
ScaleGUITrad
static int ScaleGUITrad(int value)
Scale traditional pixel dimensions to GUI zoom level.
Definition: zoom_func.h:76
NWidget
static NWidgetPart NWidget(WidgetType tp, Colours col, int16 idx=-1)
Widget part function for starting a new 'real' widget.
Definition: widget_type.h:1113
SetMinimalSize
static NWidgetPart SetMinimalSize(int16 x, int16 y)
Widget part function for setting the minimal size.
Definition: widget_type.h:946
NIHelper::GetParent
virtual uint GetParent(uint index) const =0
Get the parent "window_number" of a given instance.
WWT_PANEL
@ WWT_PANEL
Simple depressed panel.
Definition: widget_type.h:48
SpriteAlignerWindow
Window used for aligning sprites.
Definition: newgrf_debug_gui.cpp:806
NWidgetBase::resize_y
uint resize_y
Vertical resize step (0 means not resizable).
Definition: widget_type.h:165
NIProperty::name
const char * name
A (human readable) name for the property.
Definition: newgrf_debug_gui.cpp:84
MP_STATION
@ MP_STATION
A tile of a station.
Definition: tile_type.h:46
Scrollbar::GetPosition
uint16 GetPosition() const
Gets the position of the first visible element in the list.
Definition: widget_type.h:630
WID_SA_GOTO
@ WID_SA_GOTO
Go to a given sprite.
Definition: newgrf_debug_widget.h:28
Sprite::y_offs
int16 y_offs
Number of pixels to shift the sprite downwards.
Definition: spritecache.h:20
CargoSpec::name
StringID name
Name of this type of cargo.
Definition: cargotype.h:70
Window::FinishInitNested
void FinishInitNested(WindowNumber window_number=0)
Perform the second part of the initialization of a nested widget tree.
Definition: window.cpp:1848
NWID_SPACER
@ NWID_SPACER
Invisible widget that takes some space.
Definition: widget_type.h:77
DrawFrameRect
void DrawFrameRect(int left, int top, int right, int bottom, Colours colour, FrameFlags flags)
Draw frame rectangle.
Definition: widget.cpp:175
NewGRFInspectWindow::RIGHT_OFFSET
static const int RIGHT_OFFSET
Position of right edge.
Definition: newgrf_debug_gui.cpp:275
WD_BEVEL_TOP
@ WD_BEVEL_TOP
Height of top bevel border.
Definition: window_gui.h:56
SmallMap::Find
std::vector< Pair >::const_iterator Find(const T &key) const
Finds given key in this map.
Definition: smallmap_type.hpp:41
WD_BEVEL_LEFT
@ WD_BEVEL_LEFT
Width of left bevel border.
Definition: window_gui.h:54
window_func.h
lengthof
#define lengthof(x)
Return the length of an fixed size array.
Definition: stdafx.h:377
Window::width
int width
width of the window (number of pixels to the right in x direction)
Definition: window_gui.h:319
Scrollbar::SetCapacityFromWidget
void SetCapacityFromWidget(Window *w, int widget, int padding=0)
Set capacity of visible elements from the size and resize properties of a widget.
Definition: widget.cpp:1980
MarkWholeScreenDirty
void MarkWholeScreenDirty()
This function mark the whole screen as dirty.
Definition: gfx.cpp:1610
SetPIP
static NWidgetPart SetPIP(uint8 pre, uint8 inter, uint8 post)
Widget part function for setting a pre/inter/post spaces.
Definition: widget_type.h:1075
NIVariable
Representation on the NewGRF variables.
Definition: newgrf_debug_gui.cpp:107
NWidgetBase::pos_y
int pos_y
Vertical position of top-left corner of the widget in the window.
Definition: widget_type.h:176
engine_base.h
WC_NEWGRF_INSPECT
@ WC_NEWGRF_INSPECT
NewGRF inspect (debug); Window numbers:
Definition: window_type.h:662
SetFill
static NWidgetPart SetFill(uint fill_x, uint fill_y)
Widget part function for setting filling.
Definition: widget_type.h:982
newgrf_industries.h
Window
Data structure for an opened window.
Definition: window_gui.h:276
GetTileType
static TileType GetTileType(TileIndex tile)
Get the tiletype of a given tile.
Definition: tile_map.h:96
VEH_TRAIN
@ VEH_TRAIN
Train vehicle type.
Definition: vehicle_type.h:24
Window::RaiseWidget
void RaiseWidget(byte widget_index)
Marks a widget as raised.
Definition: window_gui.h:483
WID_SA_UP
@ WID_SA_UP
Move the sprite up.
Definition: newgrf_debug_widget.h:30
WID_SA_OFFSETS_ABS
@ WID_SA_OFFSETS_ABS
The sprite offsets (absolute).
Definition: newgrf_debug_widget.h:35
GetGrfSpecFeature
GrfSpecFeature GetGrfSpecFeature(TileIndex tile)
Get the GrfSpecFeature associated with the tile.
Definition: newgrf_debug_gui.cpp:766
GetOriginFileSlot
uint GetOriginFileSlot(SpriteID sprite)
Get the (FIOS) file slot of a given sprite.
Definition: spritecache.cpp:142
CS_HEXADECIMAL
@ CS_HEXADECIMAL
Only hexadecimal characters.
Definition: string_type.h:31
NewGRFInspectWindow
Window used for inspecting NewGRFs.
Definition: newgrf_debug_gui.cpp:273
WID_SA_PREVIOUS
@ WID_SA_PREVIOUS
Skip to the previous sprite.
Definition: newgrf_debug_widget.h:27
VEH_SHIP
@ VEH_SHIP
Ship vehicle type.
Definition: vehicle_type.h:26
Rect
Specification of a rectangle with absolute coordinates of all edges.
Definition: geometry_type.hpp:47
Window::LowerWidget
void LowerWidget(byte widget_index)
Marks a widget as lowered.
Definition: window_gui.h:474
SpriteAlignerWindow::OnQueryTextFinished
void OnQueryTextFinished(char *str) override
The query window opened from this window has closed.
Definition: newgrf_debug_gui.cpp:997
WC_SPRITE_ALIGNER
@ WC_SPRITE_ALIGNER
Sprite aligner (debug); Window numbers:
Definition: window_type.h:668
NewGRFInspectWindow::WARN_FORMAT
void WARN_FORMAT(4, 5) DrawString(const Rect &r
Helper function to draw a string (line) in the window.
AWV_INCREASE
@ AWV_INCREASE
Arrow to the right or in case of RTL to the left.
Definition: widget_type.h:36
Sprite
Data structure describing a sprite.
Definition: spritecache.h:16
NIProperty::offset
ptrdiff_t offset
Offset of the variable in the class.
Definition: newgrf_debug_gui.cpp:85
NIHelper::SetSimpleStringParameters
void SetSimpleStringParameters(StringID string, uint32 index) const
Helper to make setting the strings easier.
Definition: newgrf_debug_gui.cpp:206
WD_BEVEL_BOTTOM
@ WD_BEVEL_BOTTOM
Height of bottom bevel border.
Definition: window_gui.h:57
lastof
#define lastof(x)
Get the last element of an fixed size array.
Definition: stdafx.h:393
NICallback::cb_bit
byte cb_bit
The bit that needs to be set for this callback to be enabled.
Definition: newgrf_debug_gui.cpp:100
TD_RTL
@ TD_RTL
Text is written right-to-left by default.
Definition: strings_type.h:24
_current_text_dir
TextDirection _current_text_dir
Text direction of the currently selected language.
Definition: strings.cpp:48
CS_NUMERAL
@ CS_NUMERAL
Only numeric ones.
Definition: string_type.h:28
SetDParamStr
void SetDParamStr(uint n, const char *str)
This function is used to "bind" a C string to a OpenTTD dparam slot.
Definition: strings.cpp:286
newgrf_railtype.h
WWT_TEXTBTN
@ WWT_TEXTBTN
(Toggle) Button with text
Definition: widget_type.h:53
NewGRFInspectWindow::ValidateChainIndex
void ValidateChainIndex()
Ensure that this->chain_index is in range.
Definition: newgrf_debug_gui.cpp:341
WID_SA_PICKER
@ WID_SA_PICKER
Sprite picker.
Definition: newgrf_debug_widget.h:37
FR_BORDERONLY
@ FR_BORDERONLY
Draw border only, no background.
Definition: window_gui.h:28
NewGRFInspectWindow::OnQueryTextFinished
void OnQueryTextFinished(char *str) override
The query window opened from this window has closed.
Definition: newgrf_debug_gui.cpp:601
AWV_DECREASE
@ AWV_DECREASE
Arrow to the left or in case of RTL to the right.
Definition: widget_type.h:35
DrawPixelInfo
Data about how and where to blit pixels.
Definition: gfx_type.h:155
NewGRFInspectWindow::UpdateWidgetSize
void UpdateWidgetSize(int widget, Dimension *size, const Dimension &padding, Dimension *fill, Dimension *resize) override
Update size and resize step of a widget in the window.
Definition: newgrf_debug_gui.cpp:371
roadveh.h
FioGetFilename
const char * FioGetFilename(uint8 slot)
Get the filename associated with a slot.
Definition: fileio.cpp:69
WID_NGRFI_CAPTION
@ WID_NGRFI_CAPTION
The caption bar of course.
Definition: newgrf_debug_widget.h:15
NewGRFInspectWindow::SetCallerGRFID
void SetCallerGRFID(uint32 grfid)
Set the GRFID of the item opening this window.
Definition: newgrf_debug_gui.cpp:307
WWT_SHADEBOX
@ WWT_SHADEBOX
Shade box (at top-right of a window, between WWT_DEBUGBOX and WWT_DEFSIZEBOX)
Definition: widget_type.h:62
NIProperty::prop
byte prop
The number of the property.
Definition: newgrf_debug_gui.cpp:87
SmallMap::Contains
bool Contains(const T &key) const
Tests whether a key is assigned in this map.
Definition: smallmap_type.hpp:79