- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 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
private void SetValue(UserStructure item, int id, int tabKey, int elementKey, string newValue)
{
if (!item.Chats.ContainsKey(id))
throw new KeyNotFoundException(String.Format(
"Чат с id = '{0}' недоступен с этой учётной записи", id));
if (item.UserName != item.Chats[id].Own)
{
switch (item.Chats[id].UserPremission)
{
case UserPremission.AccountLocked:
throw new AccessViolationException(String.Format(
"Чат с id = '{0}' заблокирован", id));
}
}
int assemblyNumber = item.Chats[id].AssemplyNumber;
if (!_contentManager.AssembplyContent.ContainsKey(assemblyNumber))
throw new NotImplementedException(String.Format(
"Для сборки = '{0}' контент не реализован", assemblyNumber));
Dictionary<int, TabItem> tabs = _contentManager.AssembplyContent[assemblyNumber];
if (!tabs.ContainsKey(tabKey))
throw new NotImplementedException(String.Format(
"Вкладка с ключём = '{0}' в сборке = '{1}' не существует", tabKey, assemblyNumber));
if (!tabs[tabKey].Elements.ContainsKey(elementKey))
throw new NotImplementedException(String.Format(
"Элемент с ключём = '{0}' во вкладке = '{1}' и сборке = '{2}' не существует",
elementKey, tabKey, assemblyNumber));
ElementItem element = tabs[tabKey].Elements[elementKey];
GetSetParametrs getSetParametrs = new GetSetParametrs(item.Chats[id]);
switch (element.ContentType)
{
case ContentType.text_box:
switch (element.Resource)
{
case ResourceType.file:
getSetParametrs.SetValueToFile(element.Value, newValue);
break;
...............................................
case ResourceType.change_login:
getSetParametrs.SetValueToChangeLogin(item.UserName, newValue);
break;
case ResourceType.change_password:
getSetParametrs.SetValueToChangePassword(newValue);
break;
}
break;
case ContentType.payment_button:
switch (element.Resource)
{
case ResourceType.extend_chat:
getSetParametrs.PayForChat();
break;
case ResourceType.clear_credentials:
getSetParametrs.SetValueToClearCredentials(element.Price);
break;
case ResourceType.clear_users:
getSetParametrs.SetValueToClearUsers(element.Price);
break;
}
break;
case ContentType.money_transfer:
switch (element.Resource)
{
case ResourceType.money_to_chat:
getSetParametrs.SetValueToMoneyTransfer(item.MainChat, newValue);
break;
}
break;
default:
throw new FieldAccessException(String.Format(
"Ресурс '{0}' с ключём = '{1}' во вкладке = '{2}' и сборке = '{3}' недоступен для редакирования",
element.Resource, elementKey, tabKey, assemblyNumber));
}
}
Altravert 22.08.2010 07:52 # +3
Lure Of Chaos 22.08.2010 10:32 # −2
а не
а?
и вообще, слишком много свитчей
Nigma143 22.08.2010 10:49 # +1
absolut 22.08.2010 12:16 # +3
getSetParametrs - просто замечательно :)
Анонимус 23.08.2010 15:25 # 0
есть такой рефаторинг: "замена условной логики состоянием/стратегией"
xXx_totalwar 23.08.2010 15:32 # +3
Анонимус 23.08.2010 15:52 # 0
Я каждое утро забываю, что было вчера.
Извините
Lure Of Chaos 23.08.2010 16:31 # −2
Lure Of Chaos 22.08.2010 10:36 # −2
Nigma143 22.08.2010 10:51 # 0
Altravert 23.08.2010 05:11 # +4
int x;int y=x=0;for(int z=0,y=5;x<y;x++)x*=100500;
так и ось можно 2мя функциями написать))
Надо, кстати, спиздить как-нить у его кусок, выложить. Хотя банально, но плотностью говнокода на 10 символов должен доставить.
Lure Of Chaos 23.08.2010 10:19 # −4
Altravert 23.08.2010 15:02 # 0
ЗЫ: тя кто-то минусит упорно день второй наверно.
Lure Of Chaos 23.08.2010 15:11 # 0
Altravert 23.08.2010 17:09 # +2
Не знаю, слишком спорный вопрос, чтобы ставить рамки. Хотя для шарпа их ставить проще, чем для плюсов и тем более сей.
Да и все равно писать будет каждый подсознательно под свой экран. Если это вообще его колышит. Всё же это меньше всего влияет на читабельность.
Lure Of Chaos 23.08.2010 17:47 # +1
Lure Of Chaos 23.08.2010 15:12 # +4
Анонимус 23.08.2010 14:56 # 0
Если не помещается -- с помощью рефаторинга "extract method" дробим его на более мплкие
Altravert 23.08.2010 15:04 # 0
А серьезно -- у меня экран 11", на работе 22", а у друга что-то за 30. Даже с 9 высотой шрифта я на 11" мало что-тто таких методов вижу, чтоб помещались.
Анонимус 23.08.2010 15:11 # +2
и вообще -- метод можно разнести как минимум на 4 аккуратненьких метода.
"Любой кусок кода, которому ты можешь дать название -- выноси в метод" (с) Фаулер
Altravert 23.08.2010 17:13 # 0
Этот конкретный метод -- согласен, я бы разнес, но больше так -- в целях самоорганизации.
Анонимус 24.08.2010 00:21 # +1
Смысл всего лишь в том, что лучше вынести кусочек кода и дать ему понятное название, чем городить к нему комментарии например.
Ну если конечно Вы пишете драйвер, и для Вас каждый вызов функции на счету -- то конечно не надо так делать
Lure Of Chaos 23.08.2010 15:15 # +1
Анонимус 23.08.2010 15:17 # 0
Nigma143 23.08.2010 16:30 # −2
Думаю можно было сделать так:
Свитчи по контенту оставить а ресурс уже вынести в отдельный метод
Анонимус 24.08.2010 00:23 # +3
Я бы сказал, как это лечится, но прийдет xXx_totalwar и скажет что я уже это говорил)))