Имя пользователя:
Пароль:  
Помощь | Регистрация | Забыли пароль?  | Правила  

Компьютерный форум OSzone.net » Автоматическая установка Windows » Автоматическая установка приложений » Скрипты Inno Setup. Помощь и советы [часть 7]

Закрытая тема
Настройки темы
Скрипты Inno Setup. Помощь и советы [часть 7]

Аватара для El Sanchez

Ветеран


Contributor


Сообщения: 1264
Благодарности: 1024


Конфигурация

Профиль | Отправить PM | Цитировать


Изменения
Автор: El Sanchez
Дата: 16-02-2015
Внимание! Данная тема предназначена только для обсуждения написания скриптов !
Остальные вопросы, а также последние версии компилятора в теме
Inno Setup. Прочие вопросы.


Показать/скрыть: Справка, руководство, примеры:

Показать/скрыть: Ссылки на примеры скриптов:

Показать/скрыть: Дополнительные программы для Inno Setup:
  • ISTool - неплохой редактор скриптов Inno Setup.
    Последняя версия: 5.3.0.1 [29.09.2009] - Скачать | зеркало;

  • Inno Script Generator - генератор скриптов Inno Setup. Обладает некоторыми полезными функциями, которых нет ни у самого Inno Setup, ни у ISTool.
    Последняя версия: 1.0.3.1 [23.03.2008] - Скачать | зеркало на русифицированную программу;
    Примечание: Родной сайт www.hisoft2000.de более недоступен, поэтому здесь расположены сторонние ссылки.

  • Inno Setup Form Designer - редактор страниц Inno Setup, можно создавать свои страницы.
    Последняя версия: 2.0.8 [12.11.2006] - Скачать;
    Примечание: Родной сайт http://isfd.kaju74.de/index.php?isfd более недоступен, поэтому здесь расположены сторонние ссылки.

  • Inno Setup GameScript Generator - программа генерирует скрипты для Inno Setup . С помощью GameScript Generator и Inno Setup вы сможете быстро создать простенький инсталляционный пакет для любой игры. В инсталлятор можно встроить музыку, слайдшоу и фоновый рисунок. Для специалистов созданный скрипт, возможно, будет неплохой заготовкой для дальнейшей модернизации;

  • ISSkin - Программа для создания и добавления в инсталлятор скинов. Инструкция.
    Последняя версия: 3.0.0.0 [19.01.2010] - Скачать;

  • ISSJoiner - Программа для объединения нескольких скриптов InnoSetup в один.
    Последняя версия: 3.0 [23.07.2009]

  • Converter - Программа конвертирует reg-файлы в формат *.iss (формат скриптов Inno Setup).
    Последняя версия: 0.1.4 [13.03.2010] - Скачать;

  • RegExporter - Фриварная утилита для экспорта реестра и конвертации файлов *.reg и *.ini в инсталляционные скрипты Inno Setup и NSIS.
    Последняя версия: 1.2.0 [23.09.2014] - Скачать;



Предыдущие ветки обсуждения по ссылкам ниже и в прикреплённых архивах:

Скрипты Inno Setup. Помощь и советы [часть 6]

Отправлено: 11:48, 10-03-2014

 

Ветеран


Сообщения: 517
Благодарности: 314

Профиль | Отправить PM | Цитировать


Irenis, компилятор дает описание ошибки, его нужно прикрепить к сообщению, а еще лучше, как сказали выше, прикрепить к сообщению скрипт с минимальным набором файлов. Ибо гадать на пальцах, почему в вашем скрипте происходит ошибка в обратном вызове можно до бесконечности.
Это сообщение посчитали полезным следующие участники:

Отправлено: 15:35, 20-05-2014 | #701



Для отключения данного рекламного блока вам необходимо зарегистрироваться или войти с учетной записью социальной сети.

Если же вы забыли свой пароль на форуме, то воспользуйтесь данной ссылкой для восстановления пароля.


Пользователь


Сообщения: 87
Благодарности: 1

Профиль | Отправить PM | Цитировать


Цитата Shift85:
Скрипт покажите »
Скрипт.
Залила. А какие еще файлы нужно выложить? Всю игру?
Я делаю игру Panzar. Сделала из нее .arc архив. И пытаюсь как то совместить этот архив и установщик.

Отправлено: 17:39, 20-05-2014 | #702


Ветеран


Сообщения: 517
Благодарности: 314

Профиль | Отправить PM | Цитировать


Irenis, найдите в коде секцию типов type и замените первую строку в ней на вот эту:

Код: Выделить весь код
TCallback = function ( Pct: integer; CurrentFile: AnsiString ): longword;
Цитата Irenis:
А какие еще файлы нужно выложить? Всю игру? »
Нет) Только файлы необходимые для работы установщика, как, то - библиотеки, изображения и т.д.
Это сообщение посчитали полезным следующие участники:

Отправлено: 17:48, 20-05-2014 | #703


Старожил


Сообщения: 242
Благодарности: 128

Профиль | Отправить PM | Цитировать


Irenis лутше используй версию ISDone0.6final потому как есть SrepInside и PrecompInside а не ISDone 4 она очень старая там этого нету
вот сылка http://rghost.ru/55431699
Вот для сжатия Precomp+Srep+Arc и Srep+Arc и так далее все в архиве для сжатия
http://rghost.ru/55431917
Это сообщение посчитали полезным следующие участники:

Отправлено: 17:55, 20-05-2014 | #704


Аватара для Shift85

Старожил


Сообщения: 398
Благодарности: 82

Профиль | Отправить PM | Цитировать


Вложения
Тип файла: 7z skript panzar.7z
(3.0 Kb, 12 просмотров)

Irenis,
Это сообщение посчитали полезным следующие участники:

Отправлено: 17:56, 20-05-2014 | #705


Пользователь


Сообщения: 87
Благодарности: 1

Профиль | Отправить PM | Цитировать


Цитата saurn:
Irenis, найдите в коде секцию типов type и замените первую строку в ней на вот эту: »
Спасибо, действительно помогло
Компиляция прошла успешно!

Цитата Shift85:
Irenis,
Вложения
skript panzar.7z
(3.0 Kb, 0 просмотров) »
Тут, я так понимаю, тоже заменили строку или еще что то? Вам тоже большое спасибо

Единственное, все вроде хорошо, все скомпилировалось и игра даже установилась и запустилась , только при распаковке не отображается, что именно распаковывается. То есть идет строка распаковки, а ниже написано "Распаковка файлов:????????????????"
В общем много знаков вопросов. В принципе, это не столь важно, но все равно лучше было бы, если бы там отображалось то, что должно.

Цитата vint56:
лутше используй версию ISDone0.6final »
Спасибо за ссылочки Посмотрю.

Кстати, меня вот еще что интересует. Как сделать так, чтобы по завершению установки игры, автоматически открывалась страница в браузере по той ссылке, которую я укажу? Это, я так понимаю, нужен какой то скрипт или код? Может кто подскажет, где взять такое? Пока нашла только код, в котором можно прописать необходимую ссылку и в процессе установки в нижней части установщика будет отображаться кликабельная ссылка. Но хотелось бы именно, чтоб эта ссылка открывалась автоматически по завершению установки

Отправлено: 18:48, 20-05-2014 | #706


Ветеран


Сообщения: 517
Благодарности: 314

Профиль | Отправить PM | Цитировать


Цитата Irenis:
То есть идет строка распаковки, а ниже написано "Распаковка файлов:????????????????" »
Пробуйте
читать дальше »
Код: Выделить весь код
[Code]
var
  LabelPct,LabelCurrFileName: TLabel;
  ISDoneProgressBar: TNewProgressBar;
  MyCancelButton: TButton;
  OveralPct,Cancel:integer;
  CallBack:longword;
  MyError:boolean;

  type
  TCallback = function (Pct: integer;CurrentFile:string): longword;
  TMessage = record hWnd: HWND; msg, wParam: Word; lParam: LongWord; Time: TFileTime; pt: TPoint; end;

function PeekMessage(var lpMsg: TMessage; hWnd: HWND; wMsgFilterMin, wMsgFilterMax, wRemoveMsg: UINT): BOOL; external 'PeekMessageA@user32.dll stdcall';
function TranslateMessage(const lpMsg: TMessage): BOOL; external 'TranslateMessage@user32.dll stdcall';
function DispatchMessage(const lpMsg: TMessage): Longint; external 'DispatchMessageA@user32.dll stdcall';

function WrapMyCallback(callback:TCallback; paramcount:integer):longword;external 'wrapcallback@files:innocallback.dll stdcall';

function ISArcExtract(CurComponent:longword; var OveralPct:integer; PctOfTotal:double; InName, OutPath: AnsiString; DeleteInFile:boolean; callback: longword; Password, CfgFile, WorkPath: AnsiString):BOOL; external 'ISArcExtract@files:ISDone.dll stdcall';
function IS7ZipExtract(CurComponent:longword; var OveralPct:integer; PctOfTotal:double; InName, OutPath: AnsiString; DeleteInFile:boolean; callback: longword; Password: AnsiString):BOOL; external 'IS7zipExtract@files:ISDone.dll stdcall';
function ISRarExtract(CurComponent:longword; var OveralPct:integer; PctOfTotal:double; InName, OutPath: AnsiString; DeleteInFile:boolean; callback: longword; Password: AnsiString):BOOL; external 'ISRarExtract@files:ISDone.dll stdcall';
function ISPrecompExtract(CurComponent:longword; var OveralPct:integer; PctOfTotal:double; InName, OutFile: AnsiString; DeleteInFile:boolean; callback: longword):BOOL; external 'ISPrecompExtract@files:ISDone.dll stdcall';
function ISSRepExtract(CurComponent:longword; var OveralPct:integer; PctOfTotal:double; InName, OutFile, IdxFile: AnsiString; DeleteInFile:boolean; callback: longword):BOOL; external 'ISSrepExtract@files:ISDone.dll stdcall';
function ShowChangeDiskWindow(Text, DefaultPath, SearchFile:AnsiString):BOOL; external 'ShowChangeDiskWindow@files:ISDone.dll stdcall';
function StartRecord(RecordFileName:AnsiString; AllComponents:longword):BOOL; external 'StartRecord@files:ISDone.dll stdcall';
function CheckPoint(CurComponent:Integer):BOOL; external 'CheckPoint@files:ISDone.dll stdcall';
function StopRecord:BOOL; external 'StopRecord@files:ISDone.dll stdcall';

function ProgressCallback(Pct: integer; CurrentFile:String): longword;
var  Msg: TMessage;
begin
   if Pct<=ISDoneProgressBar.Max then
      ISDoneProgressBar.Position := Pct;
   LabelPct.Caption := IntToStr(Pct div 10)+'.'+chr(48 + Pct mod 10)+'%';
   LabelCurrFileName.Caption :=ExpandConstant('{cm:ExtractedFile} ')+CurrentFile;
   while PeekMessage(Msg, 0, 0, 0, 1) do begin
      TranslateMessage(Msg);
      DispatchMessage(Msg);
   end;
   Result := Cancel;
end;

procedure CancelButtonOnClick(Sender: TObject);
begin
   if MsgBox(SetupMessage(msgExitSetupMessage), mbConfirmation, MB_YESNO) = IDYES then Cancel:=1;
end;

procedure InitializeWizard();
begin
   ISDoneProgressBar := TNewProgressBar.Create(WizardForm);
   with ISDoneProgressBar do begin
      Left      := ScaleX(0);
      Top       := ScaleY(40);
      Width     := ScaleX(417);
      Max       := 1000;
      Height    := WizardForm.ProgressGauge.Height;
      Parent    := WizardForm.InstallingPage;
   end;
   LabelPct := TLabel.Create(WizardForm);
   with LabelPct do begin
     Parent    := WizardForm.InstallingPage;
     AutoSize  := False;
     Width     := WizardForm.ProgressGauge.Width;
     Top       := WizardForm.ProgressGauge.Top + ScaleY(40);
     Alignment := taCenter;
     Caption   := '';
   end;
   LabelCurrFileName := TLabel.Create(WizardForm);
   with LabelCurrFileName do begin
      Parent    := WizardForm.InstallingPage;
      AutoSize  := False;
      Width     := WizardForm.ProgressGauge.Width;
      Left      := ScaleX(0);
      Top       :=  WizardForm.ProgressGauge.Top + ScaleY(25);
      Caption   := '';
   end;
end;

Procedure CurPageChanged(CurPageID: Integer);
Begin
   if (CurPageID = wpFinished) and MyError then
   begin
      WizardForm.Caption:= ExpandConstant('{cm:Error}');
      WizardForm.FinishedLabel.Font.Color:= clRed;
      WizardForm.FinishedLabel.Caption:= SetupMessage(msgSetupAborted) ;
   end;
end;

procedure CurStepChanged(CurStep: TSetupStep);
var ChComp, TmpValue:longword;
    n:integer;
begin
   if CurStep = ssInstall then begin  //Если необходимо, можно переделать на ssPostInstall
      WizardForm.ProgressGauge.Hide;
      WizardForm.CancelButton.Visible:=false;
      MyCancelButton:=TButton.Create(WizardForm);
      with MyCancelButton do begin
         Parent:=WizardForm;
         Width:=ScaleX(135);
         Caption:=ExpandConstant('{cm:CancelButton}');
         Left:=ScaleX(360);
         Top:=WizardForm.cancelbutton.top;
         OnClick:=@CancelButtonOnClick;
      end;
      CallBack:=WrapMyCallback(@ProgressCallback,2);
      Cancel:=0;
      OveralPct:=0;

// Распаковка всех необходимых файлов в папку {tmp}. Это необходимо для того, чтобы
//выполнять установку в момент ssInstall, и секция [Run] выполнялась после установки.
#ifdef records
      ExtractTemporaryFile('records.inf');
#endif
#ifdef precomp04
      ExtractTemporaryFile('packjpg_dll.dll');
      ExtractTemporaryFile('RTconsole.exe');
      ExtractTemporaryFile('precomp04.exe');
#endif
#ifdef precomp038
      ExtractTemporaryFile('packjpg_dll.dll');
      ExtractTemporaryFile('RTconsole.exe');
      ExtractTemporaryFile('precomp038.exe');
      ExtractTemporaryFile('zlib1.dll');
#endif
#ifdef unrar
      ExtractTemporaryFile('Unrar.dll');
#endif

// Подготавливаем переменную, содержащую всю информацию о выделенных компонентах для ISDone.dll
      ChComp:=0;
#ifdef Components
      TmpValue:=1;
      if IsComponentSelected('text\rus') then ChComp:=ChComp+TmpValue;     //компонент 1
      TmpValue:=TmpValue*2;
      if IsComponentSelected('text\eng') then ChComp:=ChComp+TmpValue;     //компонент 2
      TmpValue:=TmpValue*2;
      if IsComponentSelected('voice\rus') then ChComp:=ChComp+TmpValue;    //компонент 3
      TmpValue:=TmpValue*2;
      if IsComponentSelected('voice\eng') then ChComp:=ChComp+TmpValue;    //компонент 4
#endif

      StartRecord(ExpandConstant('{src}\records.inf'),ChComp);
      repeat
         MyError:=true;
         //if not ISRarExtract    ( 0, OveralPct, 0, ExpandConstant('{src}\aaa.rar'), ExpandConstant('{app}'),            false,CallBack, ''              ) then break;
         if not ISArcExtract    ( 0, OveralPct, 0, ExpandConstant('{src}\Panzar.arc'),  ExpandConstant('{app}\'),                false,CallBack, '',    '',    '') then break;
         //if not ISSRepExtract   ( 0, OveralPct, 0, ExpandConstant('{app}\data1\CODMW2.srep'), ExpandConstant('{app}\data1\CODMW2.pcf'), '', true, CallBack                  ) then break;
         //if not ISPrecompExtract( 0, OveralPct, 0, ExpandConstant('{app}\data1\CODMW2.pcf'),  ExpandConstant('{app}\data1\CODMW2.7z'),      true, CallBack                  ) then break;
         //if not IS7ZipExtract   ( 0, OveralPct, 0, ExpandConstant('{app}\data1\CODMW2.7z'),   ExpandConstant('{app}\data1'),                true, CallBack, ''              ) then break;
         //if not ShowChangeDiskWindow('Пожалуйста, вставьте диск 2 и дождитесь его инициализации.', ExpandConstant('{src}'),'CODMW2_Disk2.arc'                 ) then break;
         //if not ISArcExtract    ( 1, OveralPct, 0, ExpandConstant('{src}\rustext.arc'), ExpandConstant('{app}'),                false,CallBack, '',    '',    '') then break;
         //if not ISArcExtract    ( 2, OveralPct, 0, ExpandConstant('{src}\engtext.arc'), ExpandConstant('{app}'),                false,CallBack, '',    '',    '') then break;
         //if not ISArcExtract    ( 3, OveralPct, 0, ExpandConstant('{src}\rusvoice.arc'),ExpandConstant('{app}'),                false,CallBack, '',    '',    '') then break;
         //if not ISArcExtract    ( 4, OveralPct, 0, ExpandConstant('{src}\engvoice.arc'),ExpandConstant('{app}'),                false,CallBack, '',    '',    '') then break;
         MyError:=false;
      until true;
      StopRecord;
    
      MyCancelButton.Visible:=false;
      WizardForm.CancelButton.Visible:=true;
   end;
   if (CurStep=ssPostInstall) and MyError then
      Exec(ExpandConstant('{uninstallexe}'), '/SILENT','', sw_Hide, ewWaitUntilTerminated, n);
end;
Это сообщение посчитали полезным следующие участники:

Отправлено: 19:12, 20-05-2014 | #707


Аватара для Dodakaedr

Ветеран


Сообщения: 857
Благодарности: 256

Профиль | Отправить PM | Цитировать


Цитата Irenis:
автоматически открывалась страница в браузере по той ссылке, которую я укажу? »
Код: Выделить весь код
[Run]
Filename: "http://forum.oszone.net"; Flags: shellexec

-------
Inno Setup 5 Ultra Unicode

Это сообщение посчитали полезным следующие участники:

Отправлено: 19:20, 20-05-2014 | #708


Пользователь


Сообщения: 119
Благодарности: 0

Профиль | Отправить PM | Цитировать


Всем доброго времени суток!
На картинке видно, что когда наводишь на компонент то появляется картинка и описание к ней в окошках.

Как реализовать данное чудо? И можно будет как-то расширить эти окошки?
Заранее спасибо!

Отправлено: 19:23, 20-05-2014 | #709


Аватара для Dodakaedr

Ветеран


Сообщения: 857
Благодарности: 256

Профиль | Отправить PM | Цитировать


Цитата Kashtan007:
Как реализовать данное чудо? »
читать дальше »
Код: Выделить весь код
[Setup]
AppName=Моя программа
AppVersion=1.5
DefaultDirName={pf}\Моя программа

[Languages]
Name: "RU"; MessagesFile: "compiler:Languages\Russian.isl"

[CustomMessages]
RU.CompName1=Компонент 1
RU.CompName2=Компонент 2
RU.ComponentsInfo=Наведите курсор мыши на компонент, чтобы прочитать его описание.
RU.ComponentsImgInfo=Наведите курсор мыши на компонент, чтобы посмотреть его превью.
RU.CompDesc1=Описание первого компонента
RU.CompDesc2=Описание второго компонента

[Files]
Source: "compiler:WizModernImage.bmp"; DestName: "CompDescImg1.bmp"; Flags: dontcopy
Source: "compiler:WizModernImage-IS.bmp"; DestName: "CompDescImg2.bmp"; Flags: dontcopy

[Types]
Name: full; Description: Full installation; Flags: iscustom

[Components]
Name: comp1; Description: "{cm:CompName1}"; Types: full
Name: comp2; Description: "{cm:CompName2}"; Types: full

[ Code]
type
  TComponentDesc = record
    Description: String;
    ImageName: String;
    Index: Integer;
  end;

var
  CompDescs: array of TComponentDesc;
  CompDescPanel, CompDescImgPanel: TPanel;
  CompDescText: array[1..2] of TLabel;
  CompIndex, LastIndex: Integer;
  CompDescImg: TBitmapImage;

procedure ShowCompDescription(Sender: TObject; X, Y, Index: Integer; Area: TItemArea);
var
  i: Integer;
begin
  if Index = LastIndex then Exit;
  CompIndex := -1;
  for i := 0 to GetArrayLength(CompDescs) -1 do
  begin
    if (CompDescs[i].Index = Index) then
    begin
      CompIndex := i;
      Break;
    end;
  end;
  if (CompIndex >= 0) and (Area = iaItem) then
  begin
    if not FileExists(ExpandConstant('{tmp}\') + CompDescs[CompIndex].ImageName) then
      ExtractTemporaryFile(CompDescs[CompIndex].ImageName);
    CompDescImg.Bitmap.LoadFromFile(ExpandConstant('{tmp}\') + CompDescs[CompIndex].ImageName);
    CompDescImg.Show;

    CompDescText[2].Caption := CompDescs[CompIndex].Description;
    CompDescText[2].Enabled := True;
  end else
  begin
    CompDescText[2].Caption := CustomMessage('ComponentsInfo');
    CompDescText[2].Enabled := False;
    CompDescImg.Hide;
  end;
  LastIndex := Index;
end;

procedure CompListMouseLeave(Sender: TObject);
begin
  CompDescImg.Hide;
  CompDescText[2].Caption := CustomMessage('ComponentsInfo');
  CompDescText[2].Enabled := False;
  LastIndex := -1;
end;

procedure AddCompDescription(AIndex: Integer; ADescription: String; AImageName: String);
var
  i: Integer;
begin
  i := GetArrayLength(CompDescs);
  SetArrayLength(CompDescs, i + 1);
  CompDescs[i].Description := ADescription;
  CompDescs[i].ImageName := AImageName;
  CompDescs[i].Index := AIndex - 1
end;

procedure InitializeWizard();
begin
  WizardForm.SelectComponentsLabel.Hide;
  WizardForm.TypesCombo.Hide;
  WizardForm.ComponentsList.SetBounds(ScaleX(0), ScaleY(0), ScaleX(184), ScaleY(205));
  WizardForm.ComponentsList.OnItemMouseMove:= @ShowCompDescription;
  WizardForm.ComponentsList.OnMouseLeave := @CompListMouseLeave;

  CompDescImgPanel := TPanel.Create(WizardForm);
  with CompDescImgPanel do
  begin
    Parent := WizardForm.SelectComponentsPage;
    SetBounds(ScaleX(192), ScaleY(0), ScaleX(225), ScaleY(120));
    BevelInner := bvLowered;
  end;

  CompDescText[1] := TLabel.Create(WizardForm);
  with CompDescText[1] do
  begin
    Parent := CompDescImgPanel;
    SetBounds(ScaleX(5), ScaleY(5), CompDescImgPanel.Width - ScaleX(10), CompDescImgPanel.Height - ScaleY(10));
    AutoSize := False;
    WordWrap := True;
    Enabled := False;
    Caption := CustomMessage('ComponentsImgInfo');
  end;

  CompDescImg := TBitmapImage.Create(WizardForm);
  with CompDescImg do
  begin
    Parent := CompDescImgPanel;
    SetBounds(ScaleX(5), ScaleY(5), CompDescImgPanel.Width - ScaleX(10), CompDescImgPanel.Height - ScaleY(10));
    Stretch := True;
    Hide;
  end;

  CompDescPanel := TPanel.Create(WizardForm);
  with CompDescPanel do
  begin
    Parent := WizardForm.SelectComponentsPage;
    SetBounds(ScaleX(192), ScaleY(125), ScaleX(225), ScaleY(80));
    BevelInner := bvLowered;
  end;

  CompDescText[2] := TLabel.Create(WizardForm);
  with CompDescText[2] do
  begin
    Parent := CompDescPanel;
    SetBounds(ScaleX(5), ScaleY(5), CompDescPanel.Width - ScaleX(10), CompDescPanel.Height - ScaleY(10));
    AutoSize := False;
    WordWrap := True;
    Enabled := False;
    Caption := CustomMessage('ComponentsInfo');
  end;

  AddCompDescription(1, CustomMessage('CompDesc1'), 'CompDescImg1.bmp');
  AddCompDescription(2, CustomMessage('CompDesc2'), 'CompDescImg2.bmp');
end;

-------
Inno Setup 5 Ultra Unicode


Последний раз редактировалось Dodakaedr, 20-05-2014 в 19:33.

Это сообщение посчитали полезным следующие участники:

Отправлено: 19:28, 20-05-2014 | #710



Компьютерный форум OSzone.net » Автоматическая установка Windows » Автоматическая установка приложений » Скрипты Inno Setup. Помощь и советы [часть 7]

Участник сейчас на форуме Участник сейчас на форуме Участник вне форума Участник вне форума Автор темы Автор темы Шапка темы Сообщение прикреплено

Похожие темы
Название темы Автор Информация о форуме Ответов Последнее сообщение
Скрипты Inno Setup. Помощь и советы [часть 6] El Sanchez Автоматическая установка приложений 2494 10-03-2014 11:51
Скрипты Inno Setup. Помощь и советы [часть 5] El Sanchez Автоматическая установка приложений 1999 28-03-2013 19:09
Скрипты Inno Setup. Помощь и советы [часть 4] El Sanchez Автоматическая установка приложений 2099 22-05-2012 23:16
Скрипты Inno Setup. Помощь и советы [часть 3] Serega Автоматическая установка приложений 3755 26-10-2011 17:58
[архив] Скрипты Inno Setup. Помощь и советы [часть 2] Serega Автоматическая установка приложений 2651 08-11-2010 18:34




 
Переход