1. Си / Говнокод #2320

    +102.8

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    int parse_path(const char *path,char ***names,int *size)
    {
    		
    	int ch=0; ch='/';
    	*size=0;
    	char *q; q=path+1;
    	char *s=0;
    	
    		
    	while(1)
    	{
    		s=strchr(q,ch);
    		if(s!=NULL)
    		{
    			(*size)++;
    			if(*size==1)
    			{
    				(*names)=malloc(sizeof(char*)*(*size));
    				if(!(*names)) return -1;
    			}
    			else
    			{
    				(*names)=realloc(*names,(*size)*sizeof(char*));
    				if(!(*names)) return -1;
    			}
    			*(*names+(*size)-1)=malloc((s-q+1)*sizeof(char));
    			if(!(*(*names+(*size)-1))) return -1;
    			memset(*(*names+(*size)-1),0,(s-q+1)*sizeof(char));			
    			strncpy(*(*names+(*size)-1),q,s-q);
    			q=s+1;
    		}
    		else
    		{
    			if(*q!='\0')
    			{
    				ch='\0';
    				s=strchr(q,ch);
    				(*size)++;
    				(*names)=realloc(*names,(*size)*sizeof(char*));
    				if(!(*names)) return -1;
    				*(*names+(*size)-1)=malloc((s-q+1)*sizeof(char));
    				if(!(*(*names+(*size)-1))) return -1;
    				memset(*(*names+(*size)-1),0,(s-q+1)*sizeof(char));			
    				strncpy(*(*names+(*size)-1),q,s-q);
    			}
    			break;
    		}
    	}
    	
    	
    	return 0;
    }

    Парсим путь...Это ужасно!!!

    Запостил: KoirN, 23 Декабря 2009

    Комментарии (18) RSS

    • Никогда ещё не видел такого длиного парсинга пути со множественными копированниями и аллокациями памяти...
      Ответить
    • ЭТО СПАРТА!!!!!!!!!11111адин

      P.S. Наличие realloc в цикле + установка терминатора строки с помощью memset уже кое о чем говорит
      Ответить
      • ... это если не обращать внимание на общую угрюмость реализации "в лоб".
        Ответить
    • char ***names
      я не знаю си, но я думал, что 2 звездочки там максимум может быть. Это что получается, что names - это указатель указателя на указатель?
      Ответить
      • Без ограничения на кол-во звездочек. Но, как правило, если их больше 2х, это повод поразмыслить.
        Ответить
        • Это всего лишь массив строк, переданный по ссылке. Первая звёздочказа строку, вторая - за массив, третья - за ссылку.
          Ответить
      • Да хоть 20 звёздочек. У меня нередко бывало по 3 звёздочки, когда я реализовывал простенькую модульную поддержку в программах.
        Ответить
    • Дичь
      Ответить
    • жесть... просто жесть
      Ответить
    • Глубоко потрясен. Сделать сложным и кривым такой распространенный алгоритм, при этом замаскировать его под совершенно нечитаемым кодом... Автор гений, если его до сих пор не выгнали с работы.
      Ответить
      • Да и просто гений, даже если и выгнали. Такое наворотить не каждому под силу. Как ему вообще такая реализацию в голову пришла?
        Ответить
        • Само написалось. Видно сказываются ночные бдения.
          Ответить
      • Не выгнали, т.к как пока и не взяли ))
        Код из лаь\бораторной работы.
        Ответить
        • А ведь даже и не догадаешься, что это код из лабораторной работы... Бывает же такое?..
          Ответить
    • В данном коде сказывается ночные воскурения кальяна KoirNa =)))
      Ответить

    Добавить комментарий