Add fullscan events, make configurator display fullscan items.

This commit is contained in:
Ron Pedde 2006-05-06 07:22:51 +00:00
parent 2350b5a6f5
commit cfaceb8d94
8 changed files with 280 additions and 116 deletions

View File

@ -396,9 +396,11 @@ int main(int argc, char *argv[]) {
if((!skip_initial) || (reload)) {
DPRINTF(E_LOG,L_MAIN|L_SCAN,"Starting mp3 scan\n");
plugin_event_dispatch(PLUGIN_EVENT_FULLSCAN_START,0,NULL,0);
if(scan_init(mp3_dir_array)) {
DPRINTF(E_LOG,L_MAIN|L_SCAN,"Error scanning MP3 files: %s\n",strerror(errno));
}
plugin_event_dispatch(PLUGIN_EVENT_FULLSCAN_END,0,NULL,0);
}
conf_dispose_array(mp3_dir_array);
}

View File

@ -2,9 +2,9 @@
* $Id: $
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
//#ifdef HAVE_CONFIG_H
//#include "config.h"
//#endif
#include "compat.h"
#include "mtd-plugins.h"
@ -45,6 +45,9 @@ PLUGIN_INFO *plugin_info(void) {
void plugin_handler(int event_id, int intval, void *vp, int len) {
int total_len = 3 * sizeof(int) + len + 1;
PLUGIN_MSG *pmsg;
int port = 9999;
SOCKET sock;
struct sockaddr_in servaddr;
pmsg = (PLUGIN_MSG*)malloc(total_len);
if(!pmsg) {
@ -58,8 +61,17 @@ void plugin_handler(int event_id, int intval, void *vp, int len) {
pmsg->intval = intval;
memcpy(&pmsg->vp,vp,len);
CallNamedPipe("\\\\.\\pipe\\firefly",NULL,0,pmsg,total_len,NULL,NMPWAIT_NOWAIT);
sock = socket(AF_INET,SOCK_DGRAM,0);
if(sock == INVALID_SOCKET)
return;
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
servaddr.sin_port = htons(port);
sendto(sock,(char*)pmsg,total_len,0,(struct sockaddr *)&servaddr,sizeof(servaddr));
closesocket(sock);
free(pmsg);
return;
}

View File

@ -9,6 +9,8 @@ using System.Data;
using System.ServiceProcess;
using System.Runtime.InteropServices;
using System.Text;
using System.Net;
using System.Net.Sockets;
using JCMLib;
namespace FireflyConfig
@ -29,27 +31,7 @@ namespace FireflyConfig
public class FireflyConfig : System.Windows.Forms.Form
{
[DllImport("Kernel32.dll")]
static extern IntPtr CreateFile(
string filename,
[MarshalAs(UnmanagedType.U4)]FileAccess fileaccess,
[MarshalAs(UnmanagedType.U4)]FileShare fileshare,
int securityattributes,
[MarshalAs(UnmanagedType.U4)]FileMode creationdisposition,
int flags,
IntPtr template);
[DllImport("Kernel32.dll")]
static extern IntPtr CreateNamedPipe(
string filename,
int openmode,
int pipemode,
int maxinstances,
int outbuffersize,
int inbuffersize,
uint defaulttimeout,
int securityattributes);
private System.Threading.Thread PipeThread;
private System.Threading.Thread UDPThread;
private System.Drawing.Icon icnRunning;
private System.Drawing.Icon icnStopped;
@ -67,10 +49,6 @@ namespace FireflyConfig
private bool ForceExit = false;
private System.IntPtr PipeHandle;
private System.IO.FileStream mPipeStream;
private byte[] PipeBuffer;
private System.Windows.Forms.Label label1;
private System.Windows.Forms.Label label2;
private System.Windows.Forms.Label label3;
@ -92,6 +70,10 @@ namespace FireflyConfig
private System.Windows.Forms.Button buttonCancel;
private System.Windows.Forms.TextBox textBoxPassword;
private System.Windows.Forms.CheckBox checkBoxPassword;
private System.Windows.Forms.TabControl tabControl1;
private System.Windows.Forms.TabPage ConfigPage;
private System.Windows.Forms.TabPage LogPage;
private System.Windows.Forms.TextBox logBox;
private System.ComponentModel.IContainer components;
protected override void WndProc(ref Message msg)
@ -100,7 +82,16 @@ namespace FireflyConfig
{
ForceExit = true;
}
base.WndProc(ref msg);
else if (msg.Msg == 0x400) // WM_USER
{
ForceExit = true;
Close();
}
else if(msg.Msg == 0x0401) // WM_USER + 1 (show config page)
{
Show();
}
base.WndProc(ref msg);
}
public void ServiceStatusUpdate()
@ -183,38 +174,82 @@ namespace FireflyConfig
this.Visible=false;
/* start chewing on the pipe */
/*
PipeHandle = NamedPipeNative.CreateFile(
@"\\." + @"\pipe\" + "firefly",
NamedPipeNative.GENERIC_READ | NamedPipeNative.GENERIC_WRITE,
0,
null,
NamedPipeNative.CREATE_ALWAYS,
0x40000000,
0);
*/
/*
PipeHandle = CreateFile("\\\\.\\pipe\\firefly",
FileAccess.ReadWrite, FileShare.ReadWrite,
0, FileMode.Create,0x40000000,IntPtr.Zero);
*/
PipeHandle = CreateNamedPipe("\\\\.\\pipe\\firefly",
3,0,10,4096,4096,0xffffffff,0);
mPipeStream = new System.IO.FileStream(PipeHandle, System.IO.FileAccess.ReadWrite);
PipeBuffer = new byte[4096];
logBox.AppendText("Configurator Started\r\n");
PipeThread = new Thread(new ThreadStart(PipeThreadFunction));
PipeThread.Start();
UDPThread = new Thread(new ThreadStart(UDPThreadFunction));
UDPThread.IsBackground=true;
UDPThread.Start();
}
public void PipeThreadFunction()
public void UDPThreadFunction()
{
int bytesRead;
while((bytesRead = mPipeStream.Read(PipeBuffer,0,4096)) > 0)
Socket sockUDP;
System.Text.ASCIIEncoding encoding=new System.Text.ASCIIEncoding();
try
{
MessageBox.Show("woot");
sockUDP = new Socket(AddressFamily.InterNetwork, SocketType.Dgram,ProtocolType.Udp);
IPAddress local = IPAddress.Parse("127.0.0.1");
IPEndPoint localIpEndPoint = new IPEndPoint(local,9999);
sockUDP.Bind(localIpEndPoint);
while(true)
{
Byte[] received = new Byte[4096];
IPEndPoint tmpIpEndPoint = new IPEndPoint(local,9999);
EndPoint remoteEP = (tmpIpEndPoint);
int bytesReceived = sockUDP.ReceiveFrom(received,ref remoteEP);
if(bytesReceived != 0)
{
int size;
int id;
int intval;
size = received[0] |
(received[1] << 8) |
(received[2] << 16) |
(received[3] << 24);
id = received[4] |
(received[5] << 8) |
(received[6] << 16) |
(received[7] << 24);
intval = received[8] |
(received[9] << 8) |
(received[10] << 16) |
(received[11] << 24);
string strval = encoding.GetString(received,12,bytesReceived < size ? bytesReceived - 12 : size - 12).Replace("\n","\r\n");
if(id == 0)
{
/* log message */
logBox.AppendText(String.Format("{0}{1}",intval == 0 ? "FATAL: " : "",strval));
if(intval == 0)
{ /* fatal error */
notifyIcon.ShowBalloon("Fatal Error",strval,JCMLib.NotifyIconEx.NotifyInfoFlags.Error,5000);
}
}
else if(id == 1)
{
notifyIcon.ShowBalloon("Firefly Server","Starting music scan...\r\nThis may take some time.",JCMLib.NotifyIconEx.NotifyInfoFlags.Info,5000);
}
else if (id == 2)
{
notifyIcon.ShowBalloon("Firefly Server","Music scan complete",JCMLib.NotifyIconEx.NotifyInfoFlags.Info,5000);
}
}
}
}
catch(ThreadAbortException)
{
/* should clean up gracefully here */
return;
}
finally
{
MessageBox.Show("Socket Error. Ignoring server events");
}
}
@ -295,12 +330,19 @@ namespace FireflyConfig
this.menuItemExit = new System.Windows.Forms.MenuItem();
this.notifyIcon = new JCMLib.NotifyIconEx();
this.folderBrowserDialog = new System.Windows.Forms.FolderBrowserDialog();
this.tabControl1 = new System.Windows.Forms.TabControl();
this.ConfigPage = new System.Windows.Forms.TabPage();
this.LogPage = new System.Windows.Forms.TabPage();
this.logBox = new System.Windows.Forms.TextBox();
this.groupBox1.SuspendLayout();
this.tabControl1.SuspendLayout();
this.ConfigPage.SuspendLayout();
this.LogPage.SuspendLayout();
this.SuspendLayout();
//
// label1
//
this.label1.Location = new System.Drawing.Point(8, 18);
this.label1.Location = new System.Drawing.Point(8, 12);
this.label1.Name = "label1";
this.label1.Size = new System.Drawing.Size(80, 16);
this.label1.TabIndex = 0;
@ -308,7 +350,7 @@ namespace FireflyConfig
//
// label2
//
this.label2.Location = new System.Drawing.Point(8, 79);
this.label2.Location = new System.Drawing.Point(8, 76);
this.label2.Name = "label2";
this.label2.Size = new System.Drawing.Size(88, 23);
this.label2.TabIndex = 4;
@ -316,7 +358,7 @@ namespace FireflyConfig
//
// label3
//
this.label3.Location = new System.Drawing.Point(8, 47);
this.label3.Location = new System.Drawing.Point(8, 44);
this.label3.Name = "label3";
this.label3.Size = new System.Drawing.Size(80, 23);
this.label3.TabIndex = 2;
@ -344,9 +386,9 @@ namespace FireflyConfig
this.groupBox1.Controls.Add(this.textBoxPassword);
this.groupBox1.Controls.Add(this.checkBoxPassword);
this.groupBox1.Controls.Add(this.label4);
this.groupBox1.Location = new System.Drawing.Point(8, 112);
this.groupBox1.Location = new System.Drawing.Point(9, 104);
this.groupBox1.Name = "groupBox1";
this.groupBox1.Size = new System.Drawing.Size(240, 80);
this.groupBox1.Size = new System.Drawing.Size(247, 80);
this.groupBox1.TabIndex = 7;
this.groupBox1.TabStop = false;
this.groupBox1.Text = "Passsword";
@ -355,13 +397,13 @@ namespace FireflyConfig
//
this.textBoxPassword.Location = new System.Drawing.Point(80, 48);
this.textBoxPassword.Name = "textBoxPassword";
this.textBoxPassword.Size = new System.Drawing.Size(144, 20);
this.textBoxPassword.Size = new System.Drawing.Size(160, 20);
this.textBoxPassword.TabIndex = 2;
this.textBoxPassword.Text = "";
//
// textBoxPort
//
this.textBoxPort.Location = new System.Drawing.Point(96, 16);
this.textBoxPort.Location = new System.Drawing.Point(104, 8);
this.textBoxPort.Name = "textBoxPort";
this.textBoxPort.Size = new System.Drawing.Size(48, 20);
this.textBoxPort.TabIndex = 1;
@ -369,7 +411,7 @@ namespace FireflyConfig
//
// textBoxServerName
//
this.textBoxServerName.Location = new System.Drawing.Point(96, 48);
this.textBoxServerName.Location = new System.Drawing.Point(104, 40);
this.textBoxServerName.Name = "textBoxServerName";
this.textBoxServerName.Size = new System.Drawing.Size(152, 20);
this.textBoxServerName.TabIndex = 3;
@ -377,7 +419,7 @@ namespace FireflyConfig
//
// textBoxMusicDir
//
this.textBoxMusicDir.Location = new System.Drawing.Point(96, 80);
this.textBoxMusicDir.Location = new System.Drawing.Point(104, 72);
this.textBoxMusicDir.Name = "textBoxMusicDir";
this.textBoxMusicDir.Size = new System.Drawing.Size(120, 20);
this.textBoxMusicDir.TabIndex = 5;
@ -385,7 +427,7 @@ namespace FireflyConfig
//
// buttonBrowseDir
//
this.buttonBrowseDir.Location = new System.Drawing.Point(224, 80);
this.buttonBrowseDir.Location = new System.Drawing.Point(232, 72);
this.buttonBrowseDir.Name = "buttonBrowseDir";
this.buttonBrowseDir.Size = new System.Drawing.Size(24, 20);
this.buttonBrowseDir.TabIndex = 6;
@ -395,7 +437,7 @@ namespace FireflyConfig
// buttonOK
//
this.buttonOK.DialogResult = System.Windows.Forms.DialogResult.OK;
this.buttonOK.Location = new System.Drawing.Point(8, 216);
this.buttonOK.Location = new System.Drawing.Point(8, 240);
this.buttonOK.Name = "buttonOK";
this.buttonOK.Size = new System.Drawing.Size(80, 24);
this.buttonOK.TabIndex = 8;
@ -405,7 +447,7 @@ namespace FireflyConfig
// buttonCancel
//
this.buttonCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel;
this.buttonCancel.Location = new System.Drawing.Point(168, 216);
this.buttonCancel.Location = new System.Drawing.Point(200, 240);
this.buttonCancel.Name = "buttonCancel";
this.buttonCancel.Size = new System.Drawing.Size(80, 24);
this.buttonCancel.TabIndex = 9;
@ -455,32 +497,75 @@ namespace FireflyConfig
this.notifyIcon.Visible = true;
this.notifyIcon.DoubleClick += new System.EventHandler(this.notifyIcon_DoubleClick);
//
// tabControl1
//
this.tabControl1.Controls.Add(this.ConfigPage);
this.tabControl1.Controls.Add(this.LogPage);
this.tabControl1.ItemSize = new System.Drawing.Size(74, 18);
this.tabControl1.Location = new System.Drawing.Point(8, 8);
this.tabControl1.Name = "tabControl1";
this.tabControl1.SelectedIndex = 0;
this.tabControl1.Size = new System.Drawing.Size(272, 224);
this.tabControl1.TabIndex = 10;
//
// ConfigPage
//
this.ConfigPage.Controls.Add(this.label1);
this.ConfigPage.Controls.Add(this.label2);
this.ConfigPage.Controls.Add(this.label3);
this.ConfigPage.Controls.Add(this.groupBox1);
this.ConfigPage.Controls.Add(this.textBoxPort);
this.ConfigPage.Controls.Add(this.textBoxServerName);
this.ConfigPage.Controls.Add(this.textBoxMusicDir);
this.ConfigPage.Controls.Add(this.buttonBrowseDir);
this.ConfigPage.Location = new System.Drawing.Point(4, 22);
this.ConfigPage.Name = "ConfigPage";
this.ConfigPage.Size = new System.Drawing.Size(264, 198);
this.ConfigPage.TabIndex = 0;
this.ConfigPage.Text = "Configuration";
//
// LogPage
//
this.LogPage.Controls.Add(this.logBox);
this.LogPage.Location = new System.Drawing.Point(4, 22);
this.LogPage.Name = "LogPage";
this.LogPage.Size = new System.Drawing.Size(264, 198);
this.LogPage.TabIndex = 1;
this.LogPage.Text = "Log";
//
// logBox
//
this.logBox.Location = new System.Drawing.Point(0, 0);
this.logBox.Multiline = true;
this.logBox.Name = "logBox";
this.logBox.ReadOnly = true;
this.logBox.ScrollBars = System.Windows.Forms.ScrollBars.Both;
this.logBox.Size = new System.Drawing.Size(264, 200);
this.logBox.TabIndex = 0;
this.logBox.Text = "";
//
// FireflyConfig
//
this.AutoScaleBaseSize = new System.Drawing.Size(5, 13);
this.ClientSize = new System.Drawing.Size(256, 246);
this.ClientSize = new System.Drawing.Size(288, 270);
this.ControlBox = false;
this.Controls.Add(this.buttonCancel);
this.Controls.Add(this.buttonOK);
this.Controls.Add(this.buttonBrowseDir);
this.Controls.Add(this.textBoxMusicDir);
this.Controls.Add(this.textBoxServerName);
this.Controls.Add(this.textBoxPort);
this.Controls.Add(this.groupBox1);
this.Controls.Add(this.label3);
this.Controls.Add(this.label2);
this.Controls.Add(this.label1);
this.Controls.Add(this.tabControl1);
this.Icon = ((System.Drawing.Icon)(resources.GetObject("$this.Icon")));
this.MaximizeBox = false;
this.Name = "FireflyConfig";
this.ShowInTaskbar = false;
this.SizeGripStyle = System.Windows.Forms.SizeGripStyle.Hide;
this.Text = "Configuration";
this.Text = "Firefly Config";
this.WindowState = System.Windows.Forms.FormWindowState.Minimized;
this.Resize += new System.EventHandler(this.FireflyConfig_Resize);
this.Closing += new System.ComponentModel.CancelEventHandler(this.FireflyConfig_Closing);
this.Load += new System.EventHandler(this.FireflyConfig_Load);
this.groupBox1.ResumeLayout(false);
this.tabControl1.ResumeLayout(false);
this.ConfigPage.ResumeLayout(false);
this.LogPage.ResumeLayout(false);
this.ResumeLayout(false);
}
@ -626,36 +711,19 @@ namespace FireflyConfig
private void FireflyConfig_Closing(object sender, System.ComponentModel.CancelEventArgs e)
{
if(!ForceExit)
{
e.Cancel = true;
}
else
{
e.Cancel=false;
UDPThread.Abort();
Application.Exit();
}
}
}
[StructLayout(LayoutKind.Sequential)]
public class SecurityAttributes
{
}
public class NamedPipeNative
{
[DllImport("kernel32.dll", SetLastError=true)]
public static extern IntPtr CreateFile(
String lpFileName, // file name
uint dwDesiredAccess, // access mode
uint dwShareMode, // share mode
SecurityAttributes attr, // SD
uint dwCreationDisposition, // how to create
uint dwFlagsAndAttributes, // file attributes
uint hTemplateFile); // handle to template file
public const uint GENERIC_READ = (0x80000000);
public const uint GENERIC_WRITE = (0x40000000);
public const uint CREATE_NEW = 1;
public const uint CREATE_ALWAYS = 2;
public const uint OPEN_EXISTING = 3;
}
public class IniFile
{

View File

@ -24,7 +24,7 @@
>
<Config
Name = "Debug"
AllowUnsafeBlocks = "false"
AllowUnsafeBlocks = "true"
BaseAddress = "285212672"
CheckForOverflowUnderflow = "false"
ConfigurationOverrideFile = ""
@ -44,7 +44,7 @@
/>
<Config
Name = "Release"
AllowUnsafeBlocks = "false"
AllowUnsafeBlocks = "true"
BaseAddress = "285212672"
CheckForOverflowUnderflow = "false"
ConfigurationOverrideFile = ""

View File

@ -298,6 +298,69 @@
<data name="folderBrowserDialog.Modifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="tabControl1.SnapToGrid" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>True</value>
</data>
<data name="tabControl1.Locked" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>False</value>
</data>
<data name="tabControl1.DrawGrid" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>True</value>
</data>
<data name="tabControl1.Modifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="tabControl1.DefaultModifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="tabControl1.GridSize" type="System.Drawing.Size, System.Drawing, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
<value>8, 8</value>
</data>
<data name="ConfigPage.Locked" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>False</value>
</data>
<data name="ConfigPage.SnapToGrid" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>True</value>
</data>
<data name="ConfigPage.DrawGrid" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>True</value>
</data>
<data name="ConfigPage.DefaultModifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="ConfigPage.Modifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="ConfigPage.GridSize" type="System.Drawing.Size, System.Drawing, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
<value>8, 8</value>
</data>
<data name="LogPage.Locked" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>False</value>
</data>
<data name="LogPage.SnapToGrid" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>True</value>
</data>
<data name="LogPage.DrawGrid" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>True</value>
</data>
<data name="LogPage.DefaultModifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="LogPage.Modifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="LogPage.GridSize" type="System.Drawing.Size, System.Drawing, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
<value>8, 8</value>
</data>
<data name="logBox.DefaultModifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="logBox.Locked" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>False</value>
</data>
<data name="logBox.Modifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>
<data name="$this.Locked" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>False</value>
</data>
@ -307,9 +370,6 @@
<data name="$this.TrayLargeIcon" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>False</value>
</data>
<data name="$this.Name">
<value>FireflyConfig</value>
</data>
<data name="$this.Localizable" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>False</value>
</data>
@ -325,6 +385,9 @@
<data name="$this.SnapToGrid" type="System.Boolean, mscorlib, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>True</value>
</data>
<data name="$this.Name">
<value>FireflyConfig</value>
</data>
<data name="$this.DefaultModifiers" type="System.CodeDom.MemberAttributes, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<value>Private</value>
</data>

View File

@ -202,7 +202,7 @@ extensions=.mp3,.m4a,.m4p
#
# rescan_interval
#
# How often to check the file system to see if any mp3 files
# How often to check the file system (in sec) to see if any mp3 files
# have been added or removed.
#
# if not specified, the default is 0, which disables background scanning.
@ -216,7 +216,7 @@ extensions=.mp3,.m4a,.m4p
#
#
#rescan_interval = 300
rescan_interval = 600
# always_scan
#
@ -227,7 +227,7 @@ extensions=.mp3,.m4a,.m4p
# 24x7. Forcing a scan through the web interface will always work
# though, even if no users are connected.
# always_scan = 0
always_scan = 1
#
# process_m3u

View File

@ -74,14 +74,26 @@ Section -Pre
lbl_stop_service:
DetailPrint "Stopping Service..."
nsSCM::Stop "${PRODUCT_NAME}"
Sleep 3000
lbl_wait_stop:
Sleep 200
nsSCM::QueryStatus "${PRODUCT_NAME}"
Pop $0
Pop $1
StrCmp $0 "success" lbl_check_status
goto lbl_continue
lbl_check_status:
IntCmp $1 1 lbl_continue lbl_wait_stop lbl_wait_stop
lbl_continue:
; should really loop until service stops...
DetailPrint "Service is stopped..."
!include WinMessages.nsh
FindWindow $0 "" "Configuration"
SendMessage $0 ${WM_CLOSE} 0 0
FindWindow $0 "" "Firefly Config"
SendMessage $0 ${WM_USER} 0 0
nsSCM::QueryStatus "Bonjour Service"
Pop $0
Pop $1
@ -159,6 +171,11 @@ Section "MainSection" SEC01
HasConf:
WriteINIStr "$2\mt-daapd.conf" "plugins" "plugin_dir" "plugins"
WriteINIStr "$2\mt-daapd.conf" "plugins" "plugins" "rsp.dll,w32-event.dll"
ReadINIStr $0 "$2\mt-daapd.conf" "general" "rescan_interval"
StrCmp $0 "" rescan_set rescan_skip
rescan_set:
WriteINIStr "$2\mt-daapd.conf" "general" "rescan_interval" "600"
rescan_skip:
SetAutoClose False
SectionEnd

View File

@ -33,6 +33,7 @@
Name="VCCustomBuildTool"/>
<Tool
Name="VCLinkerTool"
AdditionalDependencies="wsock32.lib"
OutputFile="$(OutDir)/w32-event.dll"
LinkIncremental="2"
ModuleDefinitionFile="w32-event.def"
@ -81,6 +82,7 @@
Name="VCCustomBuildTool"/>
<Tool
Name="VCLinkerTool"
AdditionalDependencies="wsock32.lib"
OutputFile="$(OutDir)/w32-event.dll"
LinkIncremental="1"
ModuleDefinitionFile="w32-event.def"