1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993
|
/* Copyright 2000 Kjetil S. Matheussen
This program 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; either version 2
of the License, or (at your option) any later version.
This program 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. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
/******************************************************************
Main header file for the tracker. Each struct often has a source-
file with the same, or nearly the same, name.
Note, the file OS_Visual.h is OS spesific
and must be put into the OS directory it belongs te. The other
OS_*_proc.h files are not.
******************************************************************/
#ifndef TRACKER_DEFINE
#define TRACKER_DEFINE 1
#ifdef __cplusplus
# define LANGSPEC "C"
#else
# define LANGSPEC
#endif
#ifndef DEBUG
# error "Missing DEBUG option. Edit the Makefile."
#endif
#if !USE_GTK_VISUAL && !USE_GTK_REQTYPE && !USE_GTK_MENU
# define GTK_IS_USED 0
#else
# define GTK_IS_USED 1
#endif
#include <stdio.h>
#include <stdlib.h>
#include <limits.h>
#include <stdint.h>
#include <stdbool.h>
#include "debug_proc.h"
#include "memory_proc.h"
#include "nsmtracker_events.h"
#include "OS_error_proc.h"
#include "OS_Semaphores.h"
/* Unfortunately, AmigaOS has one absolute address that is legal to
read from; 4, which often makes MuForce not to report reading
from the wrong address (radiums fault, not MuFurces). By
inserting SDB at all 4 offsets, we never read from 4 if a pointer is NULL.
*/
#ifdef SYSBASEDEBUG
# define SDB int sysbasedebug;
#else
# define SDB
#endif
/* Next two lines must be placed in its own OS_depend file later. */
typedef uint32_t uint_32; /* A type that should be 64 bits, but may be 32 if 64 is _really_ slow or 64 is not available. */
/* uint_32 is allways loaded/saved as 64, and converted to 64 bit if uint_32 is 32 bit. */
#define MAX_UINT32 65534 /* Sqr(max(uint_32))-1 (rounded down)*/
//typedef int32_t STime; /* Time can be negative. */
typedef int64_t STime; /* Time can be negative. */
//typedef STime NInt;
typedef int32_t NInt;
//#define PFREQ (48000*8) /* Subseconds for STime */ /* Replaced by samplerate */
//#define LATENCY (PFREQ/200)
#define LATENCY 0 // Dont need this when the player is called from the jack thread.
#define MAXBLOCKRELTIME 6.0f
#define MINBLOCKRELTIME 0.001f
// Higher than 255 is no point.
#define MAX_BRIGHTNESS 63
enum{
PAINT_DIRECTLY = 0,
PAINT_BUFFER = 1
};
#include <OS_Visual.h>
#define R_MAX(a,b) (((a)>(b))?(a):(b))
#define R_MIN(a,b) (((a)<(b))?(a):(b))
#define R_ABS(a) ((a)<0?(-(a)):(a))
#define R_BOUNDARIES(a,b,c) (R_MIN(R_MAX((a),(b)),(c)))
static inline double scale_double(double x, double x1, double x2, double y1, double y2){
return y1 + ( ((x-x1)*(y2-y1))
/
(x2-x1)
);
}
static inline float scale(float x, float x1, float x2, float y1, float y2){
return y1 + ( ((x-x1)*(y2-y1))
/
(x2-x1)
);
}
/*********************************************************************
placement.h
*********************************************************************/
struct Placement{
int line;
SDB
uint_32 counter;
uint_32 dividor;
};
typedef struct Placement Place;
/*********************************************************************
list.h
*********************************************************************/
struct ListHeader1{
struct ListHeader1 *next;
SDB
NInt num;
};
struct ListHeader3{
struct ListHeader3 *next;
SDB
Place p;
};
#define Tline l.p.line
#define Tcounter l.p.counter
#define Tdividor l.p.dividor
struct ListHeaderP{
struct ListHeaderP *next;
SDB
STime time;
};
/*********************************************************************
hashmap.h
*********************************************************************/
struct _hash_t;
typedef struct _hash_t hash_t;
/*********************************************************************
vector.h
*********************************************************************/
typedef struct{
int num_elements;
int num_elements_allocated;
void **elements;
} vector_t;
/*********************************************************************
velocities.h
*********************************************************************/
#define MAX_VELOCITY (1<<16)
struct Velocities{
struct ListHeader3 l;
int velocity;
};
#define NextVelocity(a) ((struct Velocities *)((a)->l.next))
/*********************************************************************
notes.h
*********************************************************************/
struct Notes{
struct ListHeader3 l;
int note;
int cents;
int velocity;
Place end;
int velocity_end;
struct Velocities *velocities;
int noend;
};
#define NextNote(a) ((struct Notes *)((a)->l.next))
/*********************************************************************
patch.h
*********************************************************************/
struct Tracks;
struct Instruments;
union SuperType{
void *pointer;
int64_t int_num;
double float_num;
};
enum TimeFormat{
TIME_IN_BEATS = 0,
TIME_IN_MS = 1,
TIME_IN_S = 2
};
struct PatchVoice{
bool is_on;
int transpose;
float volume;
float start;
float length;
enum TimeFormat time_format;
};
#define MAX_PATCH_VOICES 6
// Note that Patch objects are stored directly in undo/redo (not copied), so it must not be freed, reused for other purposes, or othervice manipulated when not available.
struct Patch{
int id;
const char *name;
STime last_time; // player lock must be held when setting this value.
void (*playnote)(struct Patch *patch,int notenum,int velocity,STime time,float pan);
void (*changevelocity)(struct Patch *patch,int notenum,int velocity,STime time);
void (*stopnote)(struct Patch *patch,int notenum,int velocity,STime time);
void (*closePatch)(struct Patch *patch);
struct Instruments *instrument;
void *patchdata; // Free use by the instrument plug-in.
void (*changeTrackPan)(int newpan,struct Tracks *track);
struct PatchVoice voices[MAX_PATCH_VOICES];
int num_ons[128]; /* To keep track of how many times a voice has to be turned off. */
int notes_num_ons[128]; /* To keep track of which notes are playing. (Useful to avoid hanging notes when turning on and off voices)*/
bool peaks_are_dirty; /* Can be set to true by any thread. */
};
#define PATCH_FAILED 0
#define PATCH_SUCCESS 1
#define NextPatch(a) ((struct Patch *)((a)->l.next))
/*********************************************************************
fx.h
*********************************************************************/
struct FX{
// struct ListHeader1 l; // The next field in 'l' is not used. FX objects are stored one by one in the FXs object.
int num;
const char *name;
int color;
void (*configureFX)(struct FX *fx,struct Tracks *track);
int min;
int max;
int effect_num; // Set by the instrument plugin.
// Having pointers to variables in sliders is a bit strange, but letting sliders reference FX instead would cause bookkeeping of live and not alive FX objects.
// Not getting that bookkeeping correct would mean crashes that could be difficult to track.
// This, on the other hand, is safe, since sliders are always alive as long as the Patch is alive, and the patch always outlives an FX object.
// (The refactor to let Patch own FX hasn't been done yet. It didn't make sense when there were only MIDI instrument, but now it's too complicated to let FX live independently.
// However, when an instrument is deleted, all tracks are scanned, and FX are deleted when a patch is deleted. Same when changing patch for a track.)
float *slider_automation_value; // Pointer to the float value showing automation in slider. Value is scaled between 0-1. May be NULL.
int *slider_automation_color; // Pointer to the integer holding color number for showing automation in slider. May be NULL.
void (*treatFX)(struct FX *fx,int val,struct Tracks *track,STime time,int skip);
void (*closeFX)(struct FX *fx,struct Tracks *track);
void *fxdata; //Free use for the instrument plug-in.
void (*SaveFX)(struct FX *fx,struct Tracks *track);
};
#define FX_FAILED 0
#define FX_SUCCESS 1
/*********************************************************************
instruments.h
*********************************************************************/
// These constants are not only used internally, but they are also saved to disk.
enum{
NO_INSTRUMENT_TYPE = 0,
MIDI_INSTRUMENT_TYPE,
AUDIO_INSTRUMENT_TYPE
};
struct Tracker_Windows;
struct Instruments{
struct ListHeader1 l;
const char *instrumentname;
vector_t patches; // Not safe to traverse from player thread.
int (*getMaxVelocity)(struct Patch *patch);
int (*getFX)(struct Tracker_Windows *window,struct Tracks *track,struct FX *fx);
int (*getPatch)(struct Tracker_Windows *window,ReqType reqtype,struct Tracks *track,struct Patch *patch);
//void (*treatSpecialCommand)(char *command,struct Tracks *track);
void (*CloseInstrument)(struct Instruments *instrument);
void (*StopPlaying)(struct Instruments *instrument);
void (*PP_Update)(struct Instruments *instrument,struct Patch *patch);
void *(*CopyInstrumentData)(struct Tracks *track); //Necesarry for undo.
void (*PlayFromStartHook)(struct Instruments *instrument);
void *(*LoadFX)(struct FX *fx,struct Tracks *track);
void (*handle_fx_when_theres_a_new_patch_for_track)(struct Tracks *track, struct Patch *old_patch, struct Patch *new_patch);
void (*remove_patch)(struct Patch *patch);
void (*setPatchData)(struct Patch *patch, char *key, char *value);
char *(*getPatchData)(struct Patch *patch, char *key);
};
#define INSTRUMENT_FAILED 0
#define INSTRUMENT_SUCCESS 1
#define NextInstrument(a) ((struct Instruments *)((a)->l.next))
/*********************************************************************
stops.h
*********************************************************************/
struct Stops{
struct ListHeader3 l;
};
#define NextStop(a) ((struct Stops *)((a)->l.next))
/*********************************************************************
fxnodelines.h
*********************************************************************/
struct FXNodeLines{
struct ListHeader3 l;
int val;
};
#define NextFXNodeLine(a) ((struct FXNodeLines *)((a)->l.next))
struct FXs{
struct ListHeader1 l; /* l.num=fxnum */
struct FX *fx;
struct FXNodeLines *fxnodelines;
};
#define NextFX(a) ((struct FXs *)((a)->l.next))
/*********************************************************************
tracks.h
*********************************************************************/
struct Tracks{
struct ListHeader1 l;
struct Notes *notes;
struct Stops *stops;
int onoff;
const char *trackname;
struct Patch *patch;
struct FXs *fxs;
void *midi_instrumentdata; /* Used by the midi instrument. */
int pan;
int volume;
bool panonoff;
bool volumeonoff; /* The volume-button on/off, not track on/off. */
};
#define NextTrack(a) ((struct Tracks *)((a)->l.next))
#define MAXTRACKVOL 1000
#define MAXTRACKPAN 1000
/*********************************************************************
area.h
*********************************************************************/
typedef struct{
int x,x2;
}Area;
typedef struct{
int y,y2;
}YArea;
typedef struct{
int width;
int x,x2;
}WArea;
/*********************************************************************
trackreallines.h
*********************************************************************/
#define NUM_PEAKS_PER_LINE 8
struct APoint{
float x,y;
};
#define TRE_Max INT16_MAX
struct TrackReallineElements{
struct TrackReallineElements *next;
struct Notes *note;
int type;
int subtype;
float y1,y2;
float x1,x2;
void *pointer;
struct APoint *velocity_polygon;
int num_peaks;
struct APoint *peaks[2];
};
/************* Types: */
#define TRE_THISNOTELINES 0
#define TRE_VELLINECENTS 0x5
#define TRE_VELLINENODE 0x10
#define TRE_VELLINE 0x20
#define TRE_VELLINESTART 0x30
#define TRE_VELLINEEND 0x40
#define TRE_STOPLINE 0x90
#define TRE_REALSTARTSTOP 0xa0
/* Subtype for 0-0x40 is
the same as subtrack for the note.
*/
struct TrackRealline{
int note; /* Is 0 if no note. */
struct TrackReallineElements *trackreallineelements;
};
#define NOTE_MUL 128
#define NOTE_STP 129
#define NOTE_MUR 130
/*********************************************************************
wfxnodes.h
*********************************************************************/
typedef struct TrackReallineElements WFXNodes;
/*
struct WFXNodes{
struct WFXNodes *next;
SDB
unsigned char type;
unsigned char subtype; // not used.
unsigned char y1,y2;
unsigned short x1,x2;
void *pointer; // Only referenced.
};
*/
/************* Types: */
#define TRE_FXNODE 0x50
#define TRE_FXLINE 0x60
/*********************************************************************
tbox.h
*********************************************************************/
struct TBoxstruct{
int x1,y1,x2,y2;
};
typedef struct TBoxstruct TBox;
/*********************************************************************
wtracks.h
*********************************************************************/
struct WTracks{
struct ListHeader1 l;
// l.num=wtracknum;
int x,y,x2,y2; /* GFX area. */
int notesonoff; /* notearea and placementarea on/off. */
int notelength; /* Number of characters the notes is. Usually 2 or 3. */
int notewidth;
Area notearea; /* These are all parts of the GFX area. */
int fxonoff; /* FX area on/off */
int fxwidth; /* is fxarea.x2-fxarea.x */
Area fxarea;
int num_vel; /* Max number of velocity lines showed simultaniously. (I.e the number of subtracks)*/
struct Tracks *track; /* Only referenced. wtracknum=track->tracknum */
struct TrackRealline *trackreallines;
WFXNodes **wfxnodes;
TBox pan;
TBox volume;
TBox panonoff;
TBox volumeonoff;
int noteshowtype;
};
#define NextWTrack(a) ((struct WTracks *)((a)->l.next))
#define TEXTTYPE 0
#define GFXTYPE1 1
#define MAXTYPE 1
/*********************************************************************
lpb.h
*********************************************************************/
struct LPBs{
struct ListHeader3 l;
int lpb;
};
#define NextLPB(a) (struct LPBs *)((a)->l.next)
struct WLPBs{
int lpb;
int type; /* 0=normal, 1=below positioned, 2=mul. */
struct LPBs *LPB; /* Only referenced. */
};
#define LPB_NORMAL 0
#define LPB_BELOW 1
#define LPB_MUL 2
/*********************************************************************
tempos.h
*********************************************************************/
struct Tempos{
struct ListHeader3 l;
int tempo;
};
#define NextTempo(a) (struct Tempos *)((a)->l.next)
struct WTempos{
int tempo;
int type; /* 0=normal, 1=below positioned, 2=mul. */
SDB
struct Tempos *Tempo; /* Only referenced. */
};
/* Types */
#define TEMPO_NORMAL 0
#define TEMPO_BELOW 1
#define TEMPO_MUL 2
/*********************************************************************
temponodes.h
*********************************************************************/
struct TempoNodes{
struct ListHeader3 l;
float reltempo;
};
#define NextTempoNode(a) ((struct TempoNodes *)((a)->l.next))
typedef struct TrackReallineElements WTempoNodes;
/*
struct WTempoNodes{
struct WTempoNodes *next;
unsigned char type;
unsigned char subtype; // Currently not used.
unsigned char y1,y2;
unsigned short x1,x2;
void *temponode; // Only referenced.
};
*/
/* Types */
#define TEMPONODE_NODE 0
#define TEMPONODE_LINE 1
/*********************************************************************
time.h
*********************************************************************/
struct STimeChanges{
struct ListHeader3 l;
STime time;
float tempo1; // tempo (tempo*lpb) at this->l.p
float rel; // reltempo for this->l.p
float deltarel; // rel+deltarel is reltempo for this->l.next->l.p
};
#define NextSTimeChange(a) (struct STimeChanges *)((a)->l.next)
struct STimes{ /* One element for each line. */
STime time; /* Start-time for the line. */
SDB
struct STimeChanges *timechanges;
};
/*********************************************************************
blocks.h
*********************************************************************/
struct Blocks{
struct ListHeader1 l;
char *name;
NInt num_tracks;
int num_lines;
struct Tracks *tracks;
struct LPBs *lpbs;
struct Tempos *tempos;
struct TempoNodes *temponodes;
struct TempoNodes *lasttemponode;
struct STimes *times; /* Pointer to array. Last element (times[num_lines]) is the playtime of the block. */
float reltempo; /* factor that the tempo is multiplied with when playing this block. */
// This variable is checked after each keyboard or menu event. If true, trackreallines, wtracks, etc. will be updated.
bool is_dirty;
};
#define NextBlock(a) (struct Blocks *)((a)->l.next)
/*********************************************************************
localzooms.h
*********************************************************************/
struct LocalZooms{
struct ListHeader3 l;
// struct LocalZooms *next; /* Next on the same level. */
// int line; /* The same type of line that note has. */
// uint_32 counter; /* Same type of counter that line has. */
// uint_32 dividor; /* Same type of dividor that line has. */
int zoomline; /* The linetype that is showed in the editor. */
int level;
int realline;
struct LocalZooms *uplevel; /* Contains 'num_newlines' # of elements. */
};
#define NextLocalZoom(a) ((struct LocalZooms *)((a)->l.next))
/*********************************************************************
wblocks.h
*********************************************************************/
struct WBlocks{
struct ListHeader1 l;
int tempotrackonoff; /* 1=on, 0=off */
int temponodetrackonoff; /* 1=on, 0=off */
TBox a; // everything
// int x,y,x2,y2; /* GFX area. */
TBox t;
// int tx,ty,tx2,ty2; /* lines, nodes, etc. GFX area. */
//WArea zoomlevelarea;
WArea linenumarea;
WArea zoomlinearea;
WArea tempocolorarea;
WArea lpbTypearea;
WArea lpbarea;
WArea tempoTypearea; // When one character signals whether the tempo is down "d", or multi "m"
WArea tempoarea;
WArea temponodearea;
YArea linearea;
int maxwtracksize; /* The size of the widest wtrack. */
int num_visiblelines;
int top_realline;
int curr_realline;
int till_curr_realline; /* The player-routine sets this on. */
int bot_realline;
int mouse_track; // The track the mouse is currently above. -1 if not on a track.
struct Notes *mouse_note; // The note the mouse is currently above. NULL if mouse is not above a note.
struct Blocks *block; /* Only referenced. wblocknum=block->blocknum */
struct LocalZooms *localzooms;
struct LocalZooms **reallines;
int num_reallines;
int num_reallines_last;
struct WTracks *wtracks;
struct WTracks *wtrack; /* Current track. Only referenced. */
char *title; /* Window title. */
NInt left_track; /* The leftmost visible track. */
int left_subtrack;
NInt right_track; /* The rightmost visible track. */
int right_subtrack;
struct WTempos *wtempos;
WTempoNodes **wtemponodes;
struct WLPBs *wlpbs;
float reltempomax;
bool isranged;
NInt rangex1;
NInt rangex2;
NInt rangey1;
NInt rangey2;
bool isgfxdatahere;
TBox reltempo;
//tempocolor stuff
bool tc_onoff;
int tc_numcolors;
int tc_maxtime;
int tc_mintime;
int tc_type;
};
#define NextWBlock(a) (struct WBlocks *)((a)->l.next)
/*********************************************************************
slider.h
*********************************************************************/
struct Slider{
int show;
int width;
int x,x2;
int lx,lx2;
};
/*********************************************************************
blts.h
********************************************************************/
typedef struct{
/* Used by Blt_blt Blt_mark */
bool blt_do;
int x1;int x2;
int startrealline;
int endrealline;
/* Used by Blt_blt and Blt_marktrackheader */
bool blt_doheader;
NInt starttrack;
NInt endtrack;
/* Used by Blt_clearNotUsedVisible and Blt_markVisible */
bool clear_do;
int v_x1;int v_x2;
int v_y1;int v_y2;
}Blt;
/*********************************************************************
windows.h
*********************************************************************/
#include "mouse.h"
struct Tracker_Windows{
struct ListHeader1 l;
struct OS_visual os_visual;
int x,y; /* Where window is placed. (for amiga: screen-pos)*/
int width,height; /* Size of area to use. */
char *fontname;
int fontID; /* System spesific. For amiga: fontsize. */
int fontTags; /* System spesific. For amiga: nothing. */
int fontwidth,fontheight; /* Proportional fonts not so very allowed. */
NInt curr_track;
int curr_track_sub; /* -1=note, 0,1,2,...,n=vel */
NInt curr_block;
int maxwtracksize; /* The size of the widest wtrack for all wblocks. */
struct Slider bottomslider;
struct Slider leftslider;
struct Slider rightslider;
bool playalong; /* If true, this window allso shows whats being played
if any other window is playing. default=true. */
struct WBlocks *wblock; /* Current wblock. Only referenced. */
struct WBlocks *wblocks;
struct TEventFIFO *TELroot;
struct TEventFIFO *TELlast;
uint32_t event_treat; /* Chooses which event type(s) to treat. (0=all)*/
int dontbuffer;
struct MouseAction curraction;
struct MouseAction prevaction;
int org_fontheight;
#ifdef _AMIGA
char *h_fontname;
int h_fontID; /* System spesific. For amiga: fontsize. */
int h_fontTags; /* System spesific. For amiga: nothing. */
int h_fontwidth;
#endif
int num_pixmapdefs;
int *pixmapdefs;
int *pixmapdefs_calc;
Blt blt;
#ifdef USE_GFX_OP_QUEUE
void *op_queue;
#endif
bool must_redraw;
};
#define NextWindow(a) (struct Tracker_Windows *)((a)->l.next)
/* curr_track types */
#define TEMPONODETRACK -1
#define TEMPOTRACK -2
#define LPBTRACK -3
#define LINENUMBTRACK -4
#define TEMPOCOLORTRACK -5
#define NOTRACK -10000
/*********************************************************************
song.h
*********************************************************************/
struct Song{
struct Tracker_Windows *tracker_windows;
struct Blocks *blocks;
struct Blocks **playlist; /* This variable is just temporarily. Later, the playlist will be much more advanced. */
NInt num_blocks;
int length; /* Playlist length. */
char *songname;
NInt maxtracks; /* The highest number of tracks in a block. (changed when exceeding) */
hash_t *mixerwidget_state; // Only used during loading.
hash_t *instrument_widget_order_state; // Only used during loading.
};
/*********************************************************************
root.h
*********************************************************************/
struct Root{
struct Song *song;
int curr_playlist;
NInt curr_block;
bool setfirstpos;
int tempo; /* Standard tempo. */
int lpb; /* Standard lpb. */
float quantitize;
int keyoct;
int min_standardvel;
int standardvel;
bool editonoff;
bool scrollplayonoff;
};
/*************************************************
Structures for the advanced functions.
(especially made for extension language support.)
*************************************************/
struct NoteAdds_track{
float place; // A placement type represented as float
int notenum;
float volume; // 0.0 is off, 1.0 is max, -0.0 - -2.0 is default
float endplace; // The end place. A value -0.0 - -2.0 means no spesified end-place (end-place is set to the same as the start-place of the next note in the array).
};
struct NoteAdds_track_do{
NInt tracknum;
int num_nats;
struct NoteAdds_track *nats;
float startplace;
int sort;
};
struct NoteAdds_block{
NInt blocknum;
int num_nats_do;
struct NoteAdds_track_do **nats_do;
};
#endif
|