⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 subrepl.h

📁 神龙卡开发原代码
💻 H
字号:
// these 4 inlines are here to get the code clearer (it was unreadable due do the parenthesis)static inline T8p sd(T8p d1, int s1, T8p d2, int s2) // sd stands for shift data{ return((d1<<s1)|(d2>>s2)); }static inline T8p sdm(T8p d1, int s1, T8p d2, int s2, T8p m) // sdm stands for shift data mask{ return(((d1<<s1)|(d2>>s2))&m); }static inline T8p sdml(T8p d, int s, T8p m) // sdml stands for shift data left mask{ return(m&(d<<s)); }static inline T8p sdmr(T8p d, int s, T8p m) // sdmr stands for shift data right mask{ return(m&(d>>s)); }// for all the functions bellow// the shift state is after in the function name.// w? stands for the number of full words-1 to copy.// as all these functions are based on the same principles,// the comments are located in the most complex of them: Blt_Shift_Positif// s and d are the source and destination pointers.// ss and ds are the skip source and skip destination values (ie: the number to add to source and// destination pointer at the end of each line to go to the next line).// S, M1 and M2 are the shift, start and end masks.// w is the number of full words to write per line// h is the number of line to work on.static inline void Blt_Shift_Positif_w0(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  M1= M2&~M1;  do  {     *d= (*d&~M1) | sdml(*s, S, M1);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Positif_w1(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  int S2= 32-S;  M1= ~M1;  do  {    T8p d1= *s++;    *d++= (*d&~M1)|sdml(d1, S, M1);    *d= (*d&~M2)| sdm(*s, S, d1, S2, M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Positif_w2(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  int S2= 32- S;  M1= ~M1;  do  {    T8p d2, d1= *s++; *d++= (*d&~M1)|sdml(d1, S, M1);    d2= *s++; *d++= sd(d2, S, d1, S2);    *d= (*d&~M2)|sdm(*s, S, d2, S2, M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Positif(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  int S2= 32- S;  M1= ~M1;  // for each line to copy (there is at least one)  do  {    int i;    // get the first set of pixels from the source    T8p d1= *s++;    // combine the shifted source pixels with the destination pixels (use of mask1)    *d++= (*d&~M1)|sdml(d1, S, M1);    // for every other set of pixel    i= w;    // directly write the shifted set of pixels to the dest (see how 2 set of pixels are shifted and combined together like a sliding window)    do { T8p d2= *s++; *d++= sd(d2, S, d1, S2); d1= d2; } while (--i!=0);    // combine the final shifted source pixels with the destination pixels (use of mask2)    *d= (*d&~M2)|sdm(*s, S, d1, S2, M2);    // skip what is left of the curent lines in sources and dest.    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Null_w0(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  M1|= ~M2;  do  {     *d= (*d&M1) | (*s&~M1);    d+= ds; s+= ss;  } while (--h!=0);}static inline void Blt_Shift_Null_w1(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  do  {    *d++= (*d&M1)|(*s++&~M1);    *d= (*d&~M2)|(*s&M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Null_w2(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  do  {    *d++= (*d&M1)|(*s++&~M1);    *d++= *s++;    *d= (*d&~M2)|(*s&M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Null_w3(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  do  {    *d++= (*d&M1)|(*s++&~M1);    *d++= *s++;    *d++= *s++;    *d= (*d&~M2)|(*s&M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Null(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  do  {    int i;    *d++= (*d&M1)|(*s++&~M1);    switch (w&7)    {      case 7: *d++= *s++; case 6: *d++= *s++; case 5: *d++= *s++; case 4: *d++= *s++;      case 3: *d++= *s++; case 2: *d++= *s++; case 1: *d++= *s++; case 0: default:;     }    for (i= w>>3; i!=0; i--)                   {      *d++= *s++; *d++= *s++; *d++= *s++; *d++= *s++;      *d++= *s++; *d++= *s++; *d++= *s++; *d++= *s++;     }    *d= (*d&~M2)|(*s&M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Negatif_w0(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  int S2= 32+ S;  S= -S;  M1= M2&~M1;  do  {     *d= (*d&~M1) | sdm(*(s+1), S2, *s, S, M1);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Negatif_w1(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){   int S2= 32+ S;  M1= ~M1;  S= -S;  do  {    T8p d1= *s++; T8p d2= *s;    *d++= (*d&~M1)|sdm(d2, S2, d1, S, M1);    *d= (*d&~M2)|sdm(*(s+1), S2, *s, S, M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Negatif_w2(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  int S2= 32+S;  M1= ~M1;  ss--;   S= -S;  do  {    T8p d1= *s++; T8p d2= *s++;    *d++= (*d&~M1)|sdm(d2, S2, d1, S, M1);    d1= *s++; *d++= sd(d1, S2, d2, S);    *d= (*d&~M2)|sdm(*s, S2, d1, S, M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}static inline void Blt_Shift_Negatif(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h){  int S2= 32+S;  M1= ~M1;  ss--;   S= -S;  do  {    int i;    T8p d1= *s++; T8p d2= *s++;    *d++= (*d&~M1)|sdm(d2, S2, d1, S, M1);    i= w;    do { d1= d2; d2= *s++; *d++= sd(d2, S2, d1, S); } while (--i!=0);    *d= (*d&~M2)|sdm(*s, S2, d2, S, M2);    d+= ds; s+= ss;  } while (--h!=0);  return;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -