Updated application.
This commit is contained in:
parent
cd34405d7e
commit
a7b9b3a979
File diff suppressed because it is too large
Load diff
2350
DocService/CanvasService.ashx.cs
Normal file
2350
DocService/CanvasService.ashx.cs
Normal file
File diff suppressed because it is too large
Load diff
|
@ -1,4 +1,4 @@
|
||||||
<%@ WebHandler Language="C#" Class="ConvertService2" %>
|
<%@ WebHandler Language="C#" CodeBehind="ConvertService.ashx.cs" Class="DocService.ConvertService" %>
|
||||||
/*
|
/*
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
*
|
*
|
||||||
|
@ -32,329 +32,3 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Net;
|
|
||||||
using System.Configuration;
|
|
||||||
using System.Web;
|
|
||||||
using System.IO;
|
|
||||||
using System.Text;
|
|
||||||
using System.Xml;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading;
|
|
||||||
|
|
||||||
using FileConverterUtils2;
|
|
||||||
|
|
||||||
using log4net;
|
|
||||||
|
|
||||||
public class ConvertService2 : IHttpAsyncHandler
|
|
||||||
{
|
|
||||||
private readonly ILog _log = LogManager.GetLogger(typeof(ConvertService2));
|
|
||||||
|
|
||||||
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
|
||||||
{
|
|
||||||
TransportClassMainAshx oTransportClassMainAshx = new TransportClassMainAshx(context, cb);
|
|
||||||
ErrorTypes eError = ErrorTypes.NoError;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
_log.Info("Starting process request...");
|
|
||||||
_log.Info(context.Request.QueryString.ToString());
|
|
||||||
|
|
||||||
InputParams oInputParams = new InputParams();
|
|
||||||
oInputParams.m_sKey = context.Request.QueryString["key"];
|
|
||||||
oInputParams.m_svKey = context.Request.QueryString["vkey"];
|
|
||||||
oInputParams.m_sUrl = context.Request.QueryString["url"];
|
|
||||||
oInputParams.m_sEmbeddedfonts = context.Request.QueryString["embeddedfonts"];
|
|
||||||
|
|
||||||
int nIndexSep = oInputParams.m_sUrl.IndexOf(',');
|
|
||||||
if (-1 != nIndexSep)
|
|
||||||
oInputParams.m_sUrl = oInputParams.m_sUrl.Substring(0, nIndexSep);
|
|
||||||
oInputParams.m_sTitle = context.Request.QueryString["title"];
|
|
||||||
if (string.IsNullOrEmpty(oInputParams.m_sTitle))
|
|
||||||
oInputParams.m_sTitle = "convert";
|
|
||||||
oInputParams.m_sFiletype = context.Request.QueryString["filetype"];
|
|
||||||
oInputParams.m_nOutputtype = FileFormats.FromString(context.Request.QueryString["outputtype"]);
|
|
||||||
oInputParams.m_bAsyncConvert = Convert.ToBoolean(context.Request.QueryString["async"]);
|
|
||||||
oInputParams.m_sCodepage = context.Request.QueryString["codePage"];
|
|
||||||
oInputParams.m_sDelimiter = context.Request.QueryString["delimiter"];
|
|
||||||
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
ITaskResultInterface oTaskResult = TaskResult.NewTaskResult();
|
|
||||||
TaskResultData oToAdd = new TaskResultData();
|
|
||||||
|
|
||||||
oInputParams.m_sKey = "conv_" + oInputParams.m_sKey;
|
|
||||||
oToAdd.sKey = oInputParams.m_sKey;
|
|
||||||
oToAdd.sFormat = oInputParams.m_sFiletype;
|
|
||||||
oToAdd.eStatus = FileStatus.WaitQueue;
|
|
||||||
oToAdd.sTitle = oInputParams.m_sTitle;
|
|
||||||
TransportClass1 oTransportClass1 = new TransportClass1(oTransportClassMainAshx, oTaskResult, new CTaskQueue(), oInputParams);
|
|
||||||
oTaskResult.GetOrCreateBegin(oInputParams.m_sKey, oToAdd, GetOrCreateCallback, oTransportClass1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
eError = ErrorTypes.Unknown;
|
|
||||||
|
|
||||||
_log.Error(context.Request.QueryString.ToString());
|
|
||||||
_log.Error("Exeption: ", e);
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
if( ErrorTypes.NoError != eError )
|
|
||||||
WriteOutputCommand(oTransportClassMainAshx, new OutputCommand(null, null, null, eError));
|
|
||||||
}
|
|
||||||
return new AsyncOperationData(extraData);
|
|
||||||
}
|
|
||||||
public void EndProcessRequest(IAsyncResult result)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
public void ProcessRequest(HttpContext context)
|
|
||||||
{
|
|
||||||
throw new InvalidOperationException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool IsReusable
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void WriteOutputCommand(TransportClassMainAshx oTransportClassMainAshx, OutputCommand oOutputCommand)
|
|
||||||
{
|
|
||||||
HttpContext oHttpContext = oTransportClassMainAshx.m_oHttpContext;
|
|
||||||
AsyncCallback fAsyncCallback = oTransportClassMainAshx.m_oAsyncCallback;
|
|
||||||
oHttpContext.Response.ContentType = "text/xml";
|
|
||||||
oHttpContext.Response.Charset = "UTF-8";
|
|
||||||
|
|
||||||
string sXml = "<?xml version=\"1.0\" encoding=\"utf-8\"?><FileResult>";
|
|
||||||
if (null != oOutputCommand.m_sFileUrl)
|
|
||||||
sXml += string.Format("<FileUrl>{0}</FileUrl>", HttpUtility.HtmlEncode(oOutputCommand.m_sFileUrl));
|
|
||||||
if (null != oOutputCommand.m_sPercent)
|
|
||||||
sXml += string.Format("<Percent>{0}</Percent>", oOutputCommand.m_sPercent);
|
|
||||||
if (true == oOutputCommand.m_bIsEndConvert.HasValue)
|
|
||||||
sXml += string.Format("<EndConvert>{0}</EndConvert>", oOutputCommand.m_bIsEndConvert.Value.ToString());
|
|
||||||
if (ErrorTypes.NoError != oOutputCommand.m_eError)
|
|
||||||
sXml += string.Format("<Error>{0}</Error>", Utils.mapAscServerErrorToOldError(oOutputCommand.m_eError).ToString());
|
|
||||||
sXml += "</FileResult>";
|
|
||||||
|
|
||||||
oHttpContext.Response.Write(sXml);
|
|
||||||
|
|
||||||
fAsyncCallback.Invoke(new AsyncOperationData(null));
|
|
||||||
}
|
|
||||||
private void GetOrCreateCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
TaskResultData oTaskResultData;
|
|
||||||
bool bCreate;
|
|
||||||
ErrorTypes eError = oTransportClass1.m_oTaskResult.GetOrCreateEnd(ar, out oTaskResultData, out bCreate);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
if(bCreate)
|
|
||||||
{
|
|
||||||
InputParams oInputParams = oTransportClass1.m_oInputParams;
|
|
||||||
TaskQueueData oTaskQueueData = new TaskQueueData(oInputParams.m_sKey, oInputParams.m_nOutputtype, "output." + FileFormats.ToString(oInputParams.m_nOutputtype));
|
|
||||||
oTaskQueueData.m_sFromUrl = oInputParams.m_sUrl;
|
|
||||||
oTaskQueueData.m_sFromFormat = oInputParams.m_sFiletype;
|
|
||||||
if (null != oInputParams.m_sDelimiter && string.Empty != oInputParams.m_sDelimiter)
|
|
||||||
oTaskQueueData.m_nCsvDelimiter = int.Parse(oInputParams.m_sDelimiter);
|
|
||||||
else
|
|
||||||
oTaskQueueData.m_nCsvDelimiter = (int)CsvDelimiter.Comma;
|
|
||||||
if (null != oInputParams.m_sCodepage && string.Empty != oInputParams.m_sCodepage)
|
|
||||||
oTaskQueueData.m_nCsvTxtEncoding = int.Parse(oInputParams.m_sCodepage);
|
|
||||||
else
|
|
||||||
oTaskQueueData.m_nCsvTxtEncoding = Encoding.UTF8.CodePage;
|
|
||||||
if ("true" == oInputParams.m_sEmbeddedfonts)
|
|
||||||
oTaskQueueData.m_bEmbeddedFonts = true;
|
|
||||||
oTransportClass1.m_oTaskQueue.AddTaskBegin(oTaskQueueData, Priority.Low, AddTaskCallback, oTransportClass1);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
CheckStatus(oTransportClass1, oTaskResultData);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, eError));
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void AddTaskCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ErrorTypes eError = oTransportClass1.m_oTaskQueue.AddTaskEnd(ar);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
if (true == oTransportClass1.m_oInputParams.m_bAsyncConvert)
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand("", "0", false, ErrorTypes.NoError));
|
|
||||||
else
|
|
||||||
WaitEnd(oTransportClass1);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, eError));
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void CheckStatus(TransportClass1 oTransportClass1, TaskResultData oTaskResultData)
|
|
||||||
{
|
|
||||||
|
|
||||||
switch (oTaskResultData.eStatus)
|
|
||||||
{
|
|
||||||
case FileStatus.Ok:
|
|
||||||
string sFilename = HttpUtility.UrlEncode("output." + FileFormats.ToString(oTransportClass1.m_oInputParams.m_nOutputtype));
|
|
||||||
string sPath = HttpUtility.UrlEncode(Path.GetFileNameWithoutExtension(oTransportClass1.m_oInputParams.m_sKey) + "/output." + FileFormats.ToString(oTransportClass1.m_oInputParams.m_nOutputtype));
|
|
||||||
string sDeletePath = HttpUtility.UrlEncode(Path.GetFileNameWithoutExtension(oTransportClass1.m_oInputParams.m_sKey));
|
|
||||||
|
|
||||||
string sSiteUrl = UrlBuilder.UrlWithoutPath(oTransportClass1.m_oHttpContext.Request);
|
|
||||||
|
|
||||||
string strFileUrl = sSiteUrl + Constants.mc_sResourceServiceUrlRel + sPath + "&nocache=true" +"&deletepath=" + sDeletePath + "&filename=" + sFilename;
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(strFileUrl, "100", true, ErrorTypes.NoError));
|
|
||||||
break;
|
|
||||||
case FileStatus.WaitQueue:
|
|
||||||
if (oTransportClass1.m_oInputParams.m_bAsyncConvert)
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand("", "0", false, ErrorTypes.NoError));
|
|
||||||
else
|
|
||||||
WaitEnd(oTransportClass1);
|
|
||||||
break;
|
|
||||||
case FileStatus.Convert:
|
|
||||||
if (oTransportClass1.m_oInputParams.m_bAsyncConvert)
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand("", oTaskResultData.nStatusInfo.ToString(), false, ErrorTypes.NoError));
|
|
||||||
else
|
|
||||||
WaitEnd(oTransportClass1);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case FileStatus.Err:
|
|
||||||
case FileStatus.ErrToReload:
|
|
||||||
AsyncClearCacheOperation oAsyncClearCacheOperation = new AsyncClearCacheOperation();
|
|
||||||
TransportClass2 oTransportClass2 = new TransportClass2(oTransportClass1, oAsyncClearCacheOperation, (ErrorTypes)oTaskResultData.nStatusInfo);
|
|
||||||
oAsyncClearCacheOperation.ClearCacheBegin(oTransportClass1.m_oInputParams.m_sKey, ClearCacheCallback, oTransportClass2);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void WaitEnd(TransportClass1 oTransportClass1)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Timer oTimer = new Timer(WaitEndTimerCallback, oTransportClass1, TimeSpan.FromMilliseconds(-1), TimeSpan.FromMilliseconds(-1));
|
|
||||||
oTransportClass1.m_oTimer = oTimer;
|
|
||||||
oTimer.Change(TimeSpan.FromMilliseconds(1000), TimeSpan.FromMilliseconds(-1));
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void WaitEndTimerCallback(Object stateInfo)
|
|
||||||
{
|
|
||||||
TransportClass1 oTransportClass1 = stateInfo as TransportClass1;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (null != oTransportClass1.m_oTimer)
|
|
||||||
oTransportClass1.m_oTimer.Dispose();
|
|
||||||
oTransportClass1.m_oTaskResult.GetBegin(oTransportClass1.m_oInputParams.m_sKey, WaitEndCallback, oTransportClass1);
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void WaitEndCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
TaskResultData oTaskResultData;
|
|
||||||
ErrorTypes eError = oTransportClass1.m_oTaskResult.GetEnd(ar, out oTaskResultData);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
CheckStatus(oTransportClass1, oTaskResultData);
|
|
||||||
else
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, eError));
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void ClearCacheCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass2 oTransportClass2 = ar.AsyncState as TransportClass2;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ErrorTypes eError = oTransportClass2.m_oAsyncClearCacheOperation.ClearCacheEnd(ar);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
WriteOutputCommand(oTransportClass2, new OutputCommand(null, null, null, oTransportClass2.m_eError));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
WriteOutputCommand(oTransportClass2, new OutputCommand(null, null, null, eError));
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
WriteOutputCommand(oTransportClass2, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private class TransportClass1 : TransportClassMainAshx
|
|
||||||
{
|
|
||||||
public ITaskResultInterface m_oTaskResult;
|
|
||||||
public CTaskQueue m_oTaskQueue;
|
|
||||||
public InputParams m_oInputParams;
|
|
||||||
public Timer m_oTimer;
|
|
||||||
public TransportClass1(TransportClassMainAshx oTransportClassMainAshx, ITaskResultInterface oTaskResult, CTaskQueue oTaskQueue, InputParams oInputParams)
|
|
||||||
: base(oTransportClassMainAshx.m_oHttpContext, oTransportClassMainAshx.m_oAsyncCallback)
|
|
||||||
{
|
|
||||||
m_oTaskResult = oTaskResult;
|
|
||||||
m_oInputParams = oInputParams;
|
|
||||||
m_oTaskQueue = oTaskQueue;
|
|
||||||
m_oTimer = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private class TransportClass2 : TransportClassMainAshx
|
|
||||||
{
|
|
||||||
public AsyncClearCacheOperation m_oAsyncClearCacheOperation;
|
|
||||||
public ErrorTypes m_eError;
|
|
||||||
public TransportClass2(TransportClassMainAshx oTransportClassMainAshx, AsyncClearCacheOperation oAsyncClearCacheOperation, ErrorTypes eError)
|
|
||||||
: base(oTransportClassMainAshx.m_oHttpContext, oTransportClassMainAshx.m_oAsyncCallback)
|
|
||||||
{
|
|
||||||
m_oAsyncClearCacheOperation = oAsyncClearCacheOperation;
|
|
||||||
m_eError = eError;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private class InputParams
|
|
||||||
{
|
|
||||||
public string m_sKey;
|
|
||||||
public string m_svKey;
|
|
||||||
public string m_sUrl;
|
|
||||||
public string m_sTitle;
|
|
||||||
public string m_sFiletype;
|
|
||||||
public int m_nOutputtype;
|
|
||||||
public bool m_bAsyncConvert;
|
|
||||||
public string m_sEmbeddedfonts;
|
|
||||||
public string m_sCodepage;
|
|
||||||
public string m_sDelimiter;
|
|
||||||
}
|
|
||||||
private class OutputCommand
|
|
||||||
{
|
|
||||||
public string m_sFileUrl;
|
|
||||||
public string m_sPercent;
|
|
||||||
public bool? m_bIsEndConvert;
|
|
||||||
public ErrorTypes m_eError;
|
|
||||||
public OutputCommand(string strFileUrl, string strPercent, bool? bIsEndConvert, ErrorTypes eError)
|
|
||||||
{
|
|
||||||
m_sFileUrl = strFileUrl;
|
|
||||||
m_sPercent = strPercent;
|
|
||||||
m_bIsEndConvert = bIsEndConvert;
|
|
||||||
m_eError = eError;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
360
DocService/ConvertService.ashx.cs
Normal file
360
DocService/ConvertService.ashx.cs
Normal file
|
@ -0,0 +1,360 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Net;
|
||||||
|
using System.Configuration;
|
||||||
|
using System.Web;
|
||||||
|
using System.IO;
|
||||||
|
using System.Text;
|
||||||
|
using System.Xml;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading;
|
||||||
|
|
||||||
|
using FileConverterUtils2;
|
||||||
|
|
||||||
|
using log4net;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
|
public class ConvertService : IHttpAsyncHandler
|
||||||
|
{
|
||||||
|
private readonly ILog _log = LogManager.GetLogger(typeof(ConvertService));
|
||||||
|
|
||||||
|
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
||||||
|
{
|
||||||
|
TransportClassMainAshx oTransportClassMainAshx = new TransportClassMainAshx(context, cb);
|
||||||
|
ErrorTypes eError = ErrorTypes.NoError;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_log.Info("Starting process request...");
|
||||||
|
_log.Info(context.Request.QueryString.ToString());
|
||||||
|
|
||||||
|
InputParams oInputParams = new InputParams();
|
||||||
|
oInputParams.m_sKey = context.Request.QueryString["key"];
|
||||||
|
oInputParams.m_svKey = context.Request.QueryString["vkey"];
|
||||||
|
oInputParams.m_sUrl = context.Request.QueryString["url"];
|
||||||
|
oInputParams.m_sEmbeddedfonts = context.Request.QueryString["embeddedfonts"];
|
||||||
|
|
||||||
|
int nIndexSep = oInputParams.m_sUrl.IndexOf(',');
|
||||||
|
if (-1 != nIndexSep)
|
||||||
|
oInputParams.m_sUrl = oInputParams.m_sUrl.Substring(0, nIndexSep);
|
||||||
|
oInputParams.m_sTitle = context.Request.QueryString["title"];
|
||||||
|
if (string.IsNullOrEmpty(oInputParams.m_sTitle))
|
||||||
|
oInputParams.m_sTitle = "convert";
|
||||||
|
oInputParams.m_sFiletype = context.Request.QueryString["filetype"];
|
||||||
|
oInputParams.m_nOutputtype = FileFormats.FromString(context.Request.QueryString["outputtype"]);
|
||||||
|
oInputParams.m_bAsyncConvert = Convert.ToBoolean(context.Request.QueryString["async"]);
|
||||||
|
oInputParams.m_sCodepage = context.Request.QueryString["codePage"];
|
||||||
|
oInputParams.m_sDelimiter = context.Request.QueryString["delimiter"];
|
||||||
|
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
ITaskResultInterface oTaskResult = TaskResult.NewTaskResult();
|
||||||
|
TaskResultData oToAdd = new TaskResultData();
|
||||||
|
|
||||||
|
oInputParams.m_sKey = "conv_" + oInputParams.m_sKey;
|
||||||
|
oToAdd.sKey = oInputParams.m_sKey;
|
||||||
|
oToAdd.sFormat = oInputParams.m_sFiletype;
|
||||||
|
oToAdd.eStatus = FileStatus.WaitQueue;
|
||||||
|
oToAdd.sTitle = oInputParams.m_sTitle;
|
||||||
|
TransportClass1 oTransportClass1 = new TransportClass1(oTransportClassMainAshx, oTaskResult, new CTaskQueue(), oInputParams);
|
||||||
|
oTaskResult.GetOrCreateBegin(oInputParams.m_sKey, oToAdd, GetOrCreateCallback, oTransportClass1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
eError = ErrorTypes.Unknown;
|
||||||
|
|
||||||
|
_log.Error(context.Request.QueryString.ToString());
|
||||||
|
_log.Error("Exeption: ", e);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if( ErrorTypes.NoError != eError )
|
||||||
|
WriteOutputCommand(oTransportClassMainAshx, new OutputCommand(null, null, null, eError));
|
||||||
|
}
|
||||||
|
return new AsyncOperationData(extraData);
|
||||||
|
}
|
||||||
|
public void EndProcessRequest(IAsyncResult result)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
public void ProcessRequest(HttpContext context)
|
||||||
|
{
|
||||||
|
throw new InvalidOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsReusable
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void WriteOutputCommand(TransportClassMainAshx oTransportClassMainAshx, OutputCommand oOutputCommand)
|
||||||
|
{
|
||||||
|
HttpContext oHttpContext = oTransportClassMainAshx.m_oHttpContext;
|
||||||
|
AsyncCallback fAsyncCallback = oTransportClassMainAshx.m_oAsyncCallback;
|
||||||
|
oHttpContext.Response.ContentType = "text/xml";
|
||||||
|
oHttpContext.Response.Charset = "UTF-8";
|
||||||
|
|
||||||
|
string sXml = "<?xml version=\"1.0\" encoding=\"utf-8\"?><FileResult>";
|
||||||
|
if (null != oOutputCommand.m_sFileUrl)
|
||||||
|
sXml += string.Format("<FileUrl>{0}</FileUrl>", HttpUtility.HtmlEncode(oOutputCommand.m_sFileUrl));
|
||||||
|
if (null != oOutputCommand.m_sPercent)
|
||||||
|
sXml += string.Format("<Percent>{0}</Percent>", oOutputCommand.m_sPercent);
|
||||||
|
if (true == oOutputCommand.m_bIsEndConvert.HasValue)
|
||||||
|
sXml += string.Format("<EndConvert>{0}</EndConvert>", oOutputCommand.m_bIsEndConvert.Value.ToString());
|
||||||
|
if (ErrorTypes.NoError != oOutputCommand.m_eError)
|
||||||
|
sXml += string.Format("<Error>{0}</Error>", Utils.mapAscServerErrorToOldError(oOutputCommand.m_eError).ToString());
|
||||||
|
sXml += "</FileResult>";
|
||||||
|
|
||||||
|
oHttpContext.Response.Write(sXml);
|
||||||
|
|
||||||
|
fAsyncCallback.Invoke(new AsyncOperationData(null));
|
||||||
|
}
|
||||||
|
private void GetOrCreateCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
TaskResultData oTaskResultData;
|
||||||
|
bool bCreate;
|
||||||
|
ErrorTypes eError = oTransportClass1.m_oTaskResult.GetOrCreateEnd(ar, out oTaskResultData, out bCreate);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
if(bCreate)
|
||||||
|
{
|
||||||
|
InputParams oInputParams = oTransportClass1.m_oInputParams;
|
||||||
|
TaskQueueData oTaskQueueData = new TaskQueueData(oInputParams.m_sKey, oInputParams.m_nOutputtype, "output." + FileFormats.ToString(oInputParams.m_nOutputtype));
|
||||||
|
oTaskQueueData.m_sFromUrl = oInputParams.m_sUrl;
|
||||||
|
oTaskQueueData.m_sFromFormat = oInputParams.m_sFiletype;
|
||||||
|
if (null != oInputParams.m_sDelimiter && string.Empty != oInputParams.m_sDelimiter)
|
||||||
|
oTaskQueueData.m_nCsvDelimiter = int.Parse(oInputParams.m_sDelimiter);
|
||||||
|
else
|
||||||
|
oTaskQueueData.m_nCsvDelimiter = (int)CsvDelimiter.Comma;
|
||||||
|
if (null != oInputParams.m_sCodepage && string.Empty != oInputParams.m_sCodepage)
|
||||||
|
oTaskQueueData.m_nCsvTxtEncoding = int.Parse(oInputParams.m_sCodepage);
|
||||||
|
else
|
||||||
|
oTaskQueueData.m_nCsvTxtEncoding = Encoding.UTF8.CodePage;
|
||||||
|
if ("true" == oInputParams.m_sEmbeddedfonts)
|
||||||
|
oTaskQueueData.m_bEmbeddedFonts = true;
|
||||||
|
oTransportClass1.m_oTaskQueue.AddTaskBegin(oTaskQueueData, Priority.Low, AddTaskCallback, oTransportClass1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
CheckStatus(oTransportClass1, oTaskResultData);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, eError));
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void AddTaskCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
ErrorTypes eError = oTransportClass1.m_oTaskQueue.AddTaskEnd(ar);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
if (true == oTransportClass1.m_oInputParams.m_bAsyncConvert)
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand("", "0", false, ErrorTypes.NoError));
|
||||||
|
else
|
||||||
|
WaitEnd(oTransportClass1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, eError));
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void CheckStatus(TransportClass1 oTransportClass1, TaskResultData oTaskResultData)
|
||||||
|
{
|
||||||
|
|
||||||
|
switch (oTaskResultData.eStatus)
|
||||||
|
{
|
||||||
|
case FileStatus.Ok:
|
||||||
|
string sFilename = HttpUtility.UrlEncode("output." + FileFormats.ToString(oTransportClass1.m_oInputParams.m_nOutputtype));
|
||||||
|
string sPath = HttpUtility.UrlEncode(Path.GetFileNameWithoutExtension(oTransportClass1.m_oInputParams.m_sKey) + "/output." + FileFormats.ToString(oTransportClass1.m_oInputParams.m_nOutputtype));
|
||||||
|
string sDeletePath = HttpUtility.UrlEncode(Path.GetFileNameWithoutExtension(oTransportClass1.m_oInputParams.m_sKey));
|
||||||
|
|
||||||
|
string sSiteUrl = UrlBuilder.UrlWithoutPath(oTransportClass1.m_oHttpContext.Request);
|
||||||
|
|
||||||
|
string strFileUrl = sSiteUrl + Constants.mc_sResourceServiceUrlRel + sPath + "&nocache=true" +"&deletepath=" + sDeletePath + "&filename=" + sFilename;
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(strFileUrl, "100", true, ErrorTypes.NoError));
|
||||||
|
break;
|
||||||
|
case FileStatus.WaitQueue:
|
||||||
|
if (oTransportClass1.m_oInputParams.m_bAsyncConvert)
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand("", "0", false, ErrorTypes.NoError));
|
||||||
|
else
|
||||||
|
WaitEnd(oTransportClass1);
|
||||||
|
break;
|
||||||
|
case FileStatus.Convert:
|
||||||
|
if (oTransportClass1.m_oInputParams.m_bAsyncConvert)
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand("", oTaskResultData.nStatusInfo.ToString(), false, ErrorTypes.NoError));
|
||||||
|
else
|
||||||
|
WaitEnd(oTransportClass1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FileStatus.Err:
|
||||||
|
case FileStatus.ErrToReload:
|
||||||
|
AsyncClearCacheOperation oAsyncClearCacheOperation = new AsyncClearCacheOperation();
|
||||||
|
TransportClass2 oTransportClass2 = new TransportClass2(oTransportClass1, oAsyncClearCacheOperation, (ErrorTypes)oTaskResultData.nStatusInfo);
|
||||||
|
oAsyncClearCacheOperation.ClearCacheBegin(oTransportClass1.m_oInputParams.m_sKey, ClearCacheCallback, oTransportClass2);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void WaitEnd(TransportClass1 oTransportClass1)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
Timer oTimer = new Timer(WaitEndTimerCallback, oTransportClass1, TimeSpan.FromMilliseconds(-1), TimeSpan.FromMilliseconds(-1));
|
||||||
|
oTransportClass1.m_oTimer = oTimer;
|
||||||
|
oTimer.Change(TimeSpan.FromMilliseconds(1000), TimeSpan.FromMilliseconds(-1));
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void WaitEndTimerCallback(Object stateInfo)
|
||||||
|
{
|
||||||
|
TransportClass1 oTransportClass1 = stateInfo as TransportClass1;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (null != oTransportClass1.m_oTimer)
|
||||||
|
oTransportClass1.m_oTimer.Dispose();
|
||||||
|
oTransportClass1.m_oTaskResult.GetBegin(oTransportClass1.m_oInputParams.m_sKey, WaitEndCallback, oTransportClass1);
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void WaitEndCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
TaskResultData oTaskResultData;
|
||||||
|
ErrorTypes eError = oTransportClass1.m_oTaskResult.GetEnd(ar, out oTaskResultData);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
CheckStatus(oTransportClass1, oTaskResultData);
|
||||||
|
else
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, eError));
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
WriteOutputCommand(oTransportClass1, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void ClearCacheCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass2 oTransportClass2 = ar.AsyncState as TransportClass2;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
ErrorTypes eError = oTransportClass2.m_oAsyncClearCacheOperation.ClearCacheEnd(ar);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
WriteOutputCommand(oTransportClass2, new OutputCommand(null, null, null, oTransportClass2.m_eError));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
WriteOutputCommand(oTransportClass2, new OutputCommand(null, null, null, eError));
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
WriteOutputCommand(oTransportClass2, new OutputCommand(null, null, null, ErrorTypes.Unknown));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private class TransportClass1 : TransportClassMainAshx
|
||||||
|
{
|
||||||
|
public ITaskResultInterface m_oTaskResult;
|
||||||
|
public CTaskQueue m_oTaskQueue;
|
||||||
|
public InputParams m_oInputParams;
|
||||||
|
public Timer m_oTimer;
|
||||||
|
public TransportClass1(TransportClassMainAshx oTransportClassMainAshx, ITaskResultInterface oTaskResult, CTaskQueue oTaskQueue, InputParams oInputParams)
|
||||||
|
: base(oTransportClassMainAshx.m_oHttpContext, oTransportClassMainAshx.m_oAsyncCallback)
|
||||||
|
{
|
||||||
|
m_oTaskResult = oTaskResult;
|
||||||
|
m_oInputParams = oInputParams;
|
||||||
|
m_oTaskQueue = oTaskQueue;
|
||||||
|
m_oTimer = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private class TransportClass2 : TransportClassMainAshx
|
||||||
|
{
|
||||||
|
public AsyncClearCacheOperation m_oAsyncClearCacheOperation;
|
||||||
|
public ErrorTypes m_eError;
|
||||||
|
public TransportClass2(TransportClassMainAshx oTransportClassMainAshx, AsyncClearCacheOperation oAsyncClearCacheOperation, ErrorTypes eError)
|
||||||
|
: base(oTransportClassMainAshx.m_oHttpContext, oTransportClassMainAshx.m_oAsyncCallback)
|
||||||
|
{
|
||||||
|
m_oAsyncClearCacheOperation = oAsyncClearCacheOperation;
|
||||||
|
m_eError = eError;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private class InputParams
|
||||||
|
{
|
||||||
|
public string m_sKey;
|
||||||
|
public string m_svKey;
|
||||||
|
public string m_sUrl;
|
||||||
|
public string m_sTitle;
|
||||||
|
public string m_sFiletype;
|
||||||
|
public int m_nOutputtype;
|
||||||
|
public bool m_bAsyncConvert;
|
||||||
|
public string m_sEmbeddedfonts;
|
||||||
|
public string m_sCodepage;
|
||||||
|
public string m_sDelimiter;
|
||||||
|
}
|
||||||
|
private class OutputCommand
|
||||||
|
{
|
||||||
|
public string m_sFileUrl;
|
||||||
|
public string m_sPercent;
|
||||||
|
public bool? m_bIsEndConvert;
|
||||||
|
public ErrorTypes m_eError;
|
||||||
|
public OutputCommand(string strFileUrl, string strPercent, bool? bIsEndConvert, ErrorTypes eError)
|
||||||
|
{
|
||||||
|
m_sFileUrl = strFileUrl;
|
||||||
|
m_sPercent = strPercent;
|
||||||
|
m_bIsEndConvert = bIsEndConvert;
|
||||||
|
m_eError = eError;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
174
DocService/DocService.csproj
Normal file
174
DocService/DocService.csproj
Normal file
|
@ -0,0 +1,174 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="12.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
|
||||||
|
<PropertyGroup>
|
||||||
|
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
|
||||||
|
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
|
||||||
|
<ProductVersion>
|
||||||
|
</ProductVersion>
|
||||||
|
<SchemaVersion>2.0</SchemaVersion>
|
||||||
|
<ProjectGuid>{6060D154-28A8-4E13-88A8-B82B02FDCA44}</ProjectGuid>
|
||||||
|
<ProjectTypeGuids>{349c5851-65df-11da-9384-00065b846f21};{fae04ec0-301f-11d3-bf4b-00c04f79efbc}</ProjectTypeGuids>
|
||||||
|
<OutputType>Library</OutputType>
|
||||||
|
<AppDesignerFolder>Properties</AppDesignerFolder>
|
||||||
|
<RootNamespace>DocService</RootNamespace>
|
||||||
|
<AssemblyName>DocService</AssemblyName>
|
||||||
|
<TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
|
||||||
|
<UseIISExpress>true</UseIISExpress>
|
||||||
|
<IISExpressSSLPort />
|
||||||
|
<IISExpressAnonymousAuthentication />
|
||||||
|
<IISExpressWindowsAuthentication />
|
||||||
|
<IISExpressUseClassicPipelineMode />
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||||
|
<DebugSymbols>true</DebugSymbols>
|
||||||
|
<DebugType>full</DebugType>
|
||||||
|
<Optimize>false</Optimize>
|
||||||
|
<OutputPath>Bin\</OutputPath>
|
||||||
|
<DefineConstants>DEBUG;TRACE</DefineConstants>
|
||||||
|
<ErrorReport>prompt</ErrorReport>
|
||||||
|
<WarningLevel>4</WarningLevel>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
|
||||||
|
<DebugType>none</DebugType>
|
||||||
|
<Optimize>true</Optimize>
|
||||||
|
<OutputPath>Bin\</OutputPath>
|
||||||
|
<DefineConstants>TRACE</DefineConstants>
|
||||||
|
<ErrorReport>prompt</ErrorReport>
|
||||||
|
<WarningLevel>4</WarningLevel>
|
||||||
|
</PropertyGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Reference Include="ASC.Core.Common, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>Bin\ASC.Core.Common.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="AWSSDK, Version=1.5.2.2, Culture=neutral, PublicKeyToken=cd2d24cd2bace800, processorArchitecture=MSIL">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>Bin\AWSSDK.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="Enyim.Caching, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>Bin\Enyim.Caching.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="FileConverterUtils2, Version=1.0.0.131, Culture=neutral, processorArchitecture=MSIL">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>Bin\FileConverterUtils2.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="Ionic.Zip.Reduced, Version=1.9.1.5, Culture=neutral, PublicKeyToken=edbe51ad942a3f5c, processorArchitecture=MSIL">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>Bin\Ionic.Zip.Reduced.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="log4net, Version=1.2.10.0, Culture=neutral, PublicKeyToken=1b44e1d426115821, processorArchitecture=MSIL">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>Bin\log4net.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="Microsoft.CSharp" />
|
||||||
|
<Reference Include="OpenMcdf, Version=1.5.4.22637, Culture=neutral, processorArchitecture=MSIL">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>Bin\OpenMcdf.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="System.Runtime.Serialization" />
|
||||||
|
<Reference Include="System.Web.DynamicData" />
|
||||||
|
<Reference Include="System.Web.Entity" />
|
||||||
|
<Reference Include="System.Web.ApplicationServices" />
|
||||||
|
<Reference Include="System.ComponentModel.DataAnnotations" />
|
||||||
|
<Reference Include="System" />
|
||||||
|
<Reference Include="System.Data" />
|
||||||
|
<Reference Include="System.Core" />
|
||||||
|
<Reference Include="System.Data.DataSetExtensions" />
|
||||||
|
<Reference Include="System.Web.Extensions" />
|
||||||
|
<Reference Include="System.Xml.Linq" />
|
||||||
|
<Reference Include="System.Drawing" />
|
||||||
|
<Reference Include="System.Web" />
|
||||||
|
<Reference Include="System.Xml" />
|
||||||
|
<Reference Include="System.Configuration" />
|
||||||
|
<Reference Include="System.Web.Services" />
|
||||||
|
<Reference Include="System.EnterpriseServices" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Content Include="Default.aspx" />
|
||||||
|
<Content Include="Global.asax" />
|
||||||
|
<None Include="Properties\PublishProfiles\Deploy.pubxml" />
|
||||||
|
<Content Include="Web.config" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Compile Include="App_Code\DocServiceUtils.cs" />
|
||||||
|
<Compile Include="App_Code\ZBase32Encoder.cs" />
|
||||||
|
<Compile Include="CanvasService.ashx.cs">
|
||||||
|
<DependentUpon>CanvasService.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="ConvertService.ashx.cs">
|
||||||
|
<DependentUpon>ConvertService.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="fileDownloader.ashx.cs">
|
||||||
|
<DependentUpon>fileDownloader.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="FileUploader.ashx.cs">
|
||||||
|
<DependentUpon>FileUploader.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="FontService.ashx.cs">
|
||||||
|
<DependentUpon>FontService.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Global.asax.cs">
|
||||||
|
<DependentUpon>Global.asax</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
|
<Compile Include="ResourceService.ashx.cs">
|
||||||
|
<DependentUpon>ResourceService.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="TrackingService.ashx.cs">
|
||||||
|
<DependentUpon>TrackingService.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="UploadService.ashx.cs">
|
||||||
|
<DependentUpon>UploadService.ashx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Content Include="CanvasService.ashx" />
|
||||||
|
<Content Include="ConvertService.ashx" />
|
||||||
|
<Content Include="fileDownloader.ashx" />
|
||||||
|
<Content Include="FileUploader.ashx" />
|
||||||
|
<Content Include="FontService.ashx" />
|
||||||
|
<Content Include="ResourceService.ashx" />
|
||||||
|
<Content Include="TrackingService.ashx" />
|
||||||
|
<Content Include="UploadService.ashx" />
|
||||||
|
<None Include="Web.Debug.config">
|
||||||
|
<DependentUpon>Web.config</DependentUpon>
|
||||||
|
</None>
|
||||||
|
<None Include="Web.Release.config">
|
||||||
|
<DependentUpon>Web.config</DependentUpon>
|
||||||
|
</None>
|
||||||
|
</ItemGroup>
|
||||||
|
<PropertyGroup>
|
||||||
|
<VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">10.0</VisualStudioVersion>
|
||||||
|
<VSToolsPath Condition="'$(VSToolsPath)' == ''">$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)</VSToolsPath>
|
||||||
|
</PropertyGroup>
|
||||||
|
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
|
||||||
|
<Import Project="$(VSToolsPath)\WebApplications\Microsoft.WebApplication.targets" Condition="'$(VSToolsPath)' != ''" />
|
||||||
|
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v10.0\WebApplications\Microsoft.WebApplication.targets" Condition="false" />
|
||||||
|
<ProjectExtensions>
|
||||||
|
<VisualStudio>
|
||||||
|
<FlavorProperties GUID="{349c5851-65df-11da-9384-00065b846f21}">
|
||||||
|
<WebProjectProperties>
|
||||||
|
<UseIIS>True</UseIIS>
|
||||||
|
<AutoAssignPort>True</AutoAssignPort>
|
||||||
|
<DevelopmentServerPort>54956</DevelopmentServerPort>
|
||||||
|
<DevelopmentServerVPath>/</DevelopmentServerVPath>
|
||||||
|
<IISUrl>http://localhost:54956/</IISUrl>
|
||||||
|
<NTLMAuthentication>False</NTLMAuthentication>
|
||||||
|
<UseCustomServer>False</UseCustomServer>
|
||||||
|
<CustomServerUrl>
|
||||||
|
</CustomServerUrl>
|
||||||
|
<SaveServerSettingsInUserFile>False</SaveServerSettingsInUserFile>
|
||||||
|
</WebProjectProperties>
|
||||||
|
</FlavorProperties>
|
||||||
|
</VisualStudio>
|
||||||
|
</ProjectExtensions>
|
||||||
|
<!-- To modify your build process, add your task inside one of the targets below and uncomment it.
|
||||||
|
Other similar extension points exist, see Microsoft.Common.targets.
|
||||||
|
<Target Name="BeforeBuild">
|
||||||
|
</Target>
|
||||||
|
<Target Name="AfterBuild">
|
||||||
|
</Target>
|
||||||
|
-->
|
||||||
|
</Project>
|
|
@ -1,4 +1,4 @@
|
||||||
<%@ WebHandler Language="C#" Class="FileUploader" %>
|
<%@ WebHandler Language="C#" CodeBehind="FileUploader.ashx.cs" Class="DocService.FileUploader" %>
|
||||||
/*
|
/*
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
*
|
*
|
||||||
|
@ -32,174 +32,3 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Net;
|
|
||||||
using System.Configuration;
|
|
||||||
using System.Web;
|
|
||||||
using System.IO;
|
|
||||||
using System.Xml;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Web.Script.Serialization;
|
|
||||||
using System.Collections.Specialized;
|
|
||||||
|
|
||||||
using FileConverterUtils2;
|
|
||||||
|
|
||||||
using log4net;
|
|
||||||
|
|
||||||
public class FileUploader : IHttpAsyncHandler
|
|
||||||
{
|
|
||||||
private readonly ILog _log = LogManager.GetLogger(typeof(FileUploader));
|
|
||||||
|
|
||||||
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
|
||||||
{
|
|
||||||
bool bStartAsync = false;
|
|
||||||
ErrorTypes eError = ErrorTypes.Unknown;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
_log.Info("Starting process request...");
|
|
||||||
_log.Info(context.Request.QueryString.ToString());
|
|
||||||
|
|
||||||
string vKey = context.Request.QueryString["vkey"];
|
|
||||||
string sKey = context.Request.QueryString["key"];
|
|
||||||
|
|
||||||
if (null != sKey && false == string.IsNullOrEmpty(sKey))
|
|
||||||
{
|
|
||||||
eError = ErrorTypes.NoError;
|
|
||||||
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
bStartAsync = true;
|
|
||||||
Storage oStorage = new Storage();
|
|
||||||
string sTempKey = "temp_" + sKey;
|
|
||||||
string sFilename = sKey + ".tmp";
|
|
||||||
string sPath = sTempKey + "/" + sFilename;
|
|
||||||
AsyncContextReadOperation asynch = new AsyncContextReadOperation();
|
|
||||||
TransportClass oTransportClass = new TransportClass(context, cb, oStorage, asynch, sPath, sTempKey, sFilename);
|
|
||||||
asynch.ReadContextBegin(context.Request.InputStream, ReadContextCallback, oTransportClass);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
eError = ErrorTypes.Unknown;
|
|
||||||
|
|
||||||
_log.Error(context.Request.QueryString.ToString());
|
|
||||||
_log.Error("Exeption: ", e);
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
if (ErrorTypes.NoError != eError)
|
|
||||||
writeXml(context, null, null, null, eError);
|
|
||||||
}
|
|
||||||
|
|
||||||
TransportClass oTempTransportClass = new TransportClass(context, cb, null, null, null, null, null);
|
|
||||||
if (false == bStartAsync)
|
|
||||||
cb(new AsyncOperationData(oTempTransportClass));
|
|
||||||
return new AsyncOperationData(oTempTransportClass);
|
|
||||||
}
|
|
||||||
public void EndProcessRequest(IAsyncResult result)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
public void ProcessRequest(HttpContext context)
|
|
||||||
{
|
|
||||||
throw new InvalidOperationException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool IsReusable {
|
|
||||||
get {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void ReadContextCallback(IAsyncResult result)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
oTransportClass.m_oAsyncContextRead.ReadContextEnd(result);
|
|
||||||
oTransportClass.m_oAsyncContextRead.m_aOutput.Position = 0;
|
|
||||||
oTransportClass.m_oStorage.WriteFileBegin(oTransportClass.m_sPath, oTransportClass.m_oAsyncContextRead.m_aOutput, WriteFileCallback, oTransportClass);
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
writeXml(oTransportClass.m_oContext, null, null, null, ErrorTypes.StorageWrite);
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void WriteFileCallback(IAsyncResult result)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
int nWriteBytes;
|
|
||||||
ErrorTypes eError = oTransportClass.m_oStorage.WriteFileEnd(result, out nWriteBytes);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
string sSiteUrl = UrlBuilder.UrlWithoutPath(oTransportClass.m_oContext.Request);
|
|
||||||
string sFileUrl = sSiteUrl + Constants.mc_sResourceServiceUrlRel + HttpUtility.UrlEncode(oTransportClass.m_sPath) + "&nocache=true" + "&deletepath=" + HttpUtility.UrlEncode(oTransportClass.m_sDeletePath) + "&filename=" + HttpUtility.UrlEncode(oTransportClass.m_sFilename);
|
|
||||||
writeXml(oTransportClass.m_oContext, sFileUrl, "100", true, null);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
writeXml(oTransportClass.m_oContext, null, null, null, eError);
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
writeXml(oTransportClass.m_oContext, null, null, null, ErrorTypes.StorageWrite);
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void writeXml(HttpContext context, string strFileUrl, string strPercent, bool? bIsEndConvert, ErrorTypes? eError)
|
|
||||||
{
|
|
||||||
XmlDocument oDoc = new XmlDocument();
|
|
||||||
XmlElement oRootElem = oDoc.CreateElement("FileResult");
|
|
||||||
oDoc.AppendChild(oRootElem);
|
|
||||||
if (null != strFileUrl)
|
|
||||||
{
|
|
||||||
XmlElement oFileUrl = oDoc.CreateElement("FileUrl");
|
|
||||||
|
|
||||||
oFileUrl.InnerText = strFileUrl;
|
|
||||||
oRootElem.AppendChild(oFileUrl);
|
|
||||||
}
|
|
||||||
if (null != strPercent)
|
|
||||||
{
|
|
||||||
XmlElement oPercent = oDoc.CreateElement("Percent");
|
|
||||||
oPercent.InnerText = strPercent;
|
|
||||||
oRootElem.AppendChild(oPercent);
|
|
||||||
}
|
|
||||||
if (bIsEndConvert.HasValue)
|
|
||||||
{
|
|
||||||
XmlElement oEndConvert = oDoc.CreateElement("EndConvert");
|
|
||||||
oEndConvert.InnerText = bIsEndConvert.Value.ToString();
|
|
||||||
oRootElem.AppendChild(oEndConvert);
|
|
||||||
}
|
|
||||||
if (eError.HasValue)
|
|
||||||
{
|
|
||||||
XmlElement oError = oDoc.CreateElement("Error");
|
|
||||||
oError.InnerText = Utils.mapAscServerErrorToOldError(eError.Value).ToString();
|
|
||||||
oRootElem.AppendChild(oError);
|
|
||||||
}
|
|
||||||
oDoc.Save(context.Response.Output);
|
|
||||||
context.Response.ContentType = "text/xml";
|
|
||||||
}
|
|
||||||
private class TransportClass
|
|
||||||
{
|
|
||||||
public HttpContext m_oContext;
|
|
||||||
public AsyncCallback m_oCallback;
|
|
||||||
public Storage m_oStorage;
|
|
||||||
public AsyncContextReadOperation m_oAsyncContextRead;
|
|
||||||
public string m_sPath;
|
|
||||||
public string m_sDeletePath;
|
|
||||||
public string m_sFilename;
|
|
||||||
public TransportClass(HttpContext oContext, AsyncCallback oCallback, Storage oStorage, AsyncContextReadOperation oAsyncContextRead, string sPath, string sDeletePath, string sFilename)
|
|
||||||
{
|
|
||||||
m_oContext = oContext;
|
|
||||||
m_oCallback = oCallback;
|
|
||||||
m_oStorage = oStorage;
|
|
||||||
m_oAsyncContextRead = oAsyncContextRead;
|
|
||||||
m_sPath = sPath;
|
|
||||||
m_sDeletePath = sDeletePath;
|
|
||||||
m_sFilename = sFilename;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
205
DocService/FileUploader.ashx.cs
Normal file
205
DocService/FileUploader.ashx.cs
Normal file
|
@ -0,0 +1,205 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Net;
|
||||||
|
using System.Configuration;
|
||||||
|
using System.Web;
|
||||||
|
using System.IO;
|
||||||
|
using System.Xml;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Web.Script.Serialization;
|
||||||
|
using System.Collections.Specialized;
|
||||||
|
|
||||||
|
using FileConverterUtils2;
|
||||||
|
|
||||||
|
using log4net;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
|
public class FileUploader : IHttpAsyncHandler
|
||||||
|
{
|
||||||
|
private readonly ILog _log = LogManager.GetLogger(typeof(FileUploader));
|
||||||
|
|
||||||
|
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
||||||
|
{
|
||||||
|
bool bStartAsync = false;
|
||||||
|
ErrorTypes eError = ErrorTypes.Unknown;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_log.Info("Starting process request...");
|
||||||
|
_log.Info(context.Request.QueryString.ToString());
|
||||||
|
|
||||||
|
string vKey = context.Request.QueryString["vkey"];
|
||||||
|
string sKey = context.Request.QueryString["key"];
|
||||||
|
|
||||||
|
if (null != sKey && false == string.IsNullOrEmpty(sKey))
|
||||||
|
{
|
||||||
|
eError = ErrorTypes.NoError;
|
||||||
|
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
bStartAsync = true;
|
||||||
|
Storage oStorage = new Storage();
|
||||||
|
string sTempKey = "temp_" + sKey;
|
||||||
|
string sFilename = sKey + ".tmp";
|
||||||
|
string sPath = sTempKey + "/" + sFilename;
|
||||||
|
AsyncContextReadOperation asynch = new AsyncContextReadOperation();
|
||||||
|
TransportClass oTransportClass = new TransportClass(context, cb, oStorage, asynch, sPath, sTempKey, sFilename);
|
||||||
|
asynch.ReadContextBegin(context.Request.InputStream, ReadContextCallback, oTransportClass);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
eError = ErrorTypes.Unknown;
|
||||||
|
|
||||||
|
_log.Error(context.Request.QueryString.ToString());
|
||||||
|
_log.Error("Exeption: ", e);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
if (ErrorTypes.NoError != eError)
|
||||||
|
writeXml(context, null, null, null, eError);
|
||||||
|
}
|
||||||
|
|
||||||
|
TransportClass oTempTransportClass = new TransportClass(context, cb, null, null, null, null, null);
|
||||||
|
if (false == bStartAsync)
|
||||||
|
cb(new AsyncOperationData(oTempTransportClass));
|
||||||
|
return new AsyncOperationData(oTempTransportClass);
|
||||||
|
}
|
||||||
|
public void EndProcessRequest(IAsyncResult result)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
public void ProcessRequest(HttpContext context)
|
||||||
|
{
|
||||||
|
throw new InvalidOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsReusable {
|
||||||
|
get {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void ReadContextCallback(IAsyncResult result)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
oTransportClass.m_oAsyncContextRead.ReadContextEnd(result);
|
||||||
|
oTransportClass.m_oAsyncContextRead.m_aOutput.Position = 0;
|
||||||
|
oTransportClass.m_oStorage.WriteFileBegin(oTransportClass.m_sPath, oTransportClass.m_oAsyncContextRead.m_aOutput, WriteFileCallback, oTransportClass);
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
writeXml(oTransportClass.m_oContext, null, null, null, ErrorTypes.StorageWrite);
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void WriteFileCallback(IAsyncResult result)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
int nWriteBytes;
|
||||||
|
ErrorTypes eError = oTransportClass.m_oStorage.WriteFileEnd(result, out nWriteBytes);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
string sSiteUrl = UrlBuilder.UrlWithoutPath(oTransportClass.m_oContext.Request);
|
||||||
|
string sFileUrl = sSiteUrl + Constants.mc_sResourceServiceUrlRel + HttpUtility.UrlEncode(oTransportClass.m_sPath) + "&nocache=true" + "&deletepath=" + HttpUtility.UrlEncode(oTransportClass.m_sDeletePath) + "&filename=" + HttpUtility.UrlEncode(oTransportClass.m_sFilename);
|
||||||
|
writeXml(oTransportClass.m_oContext, sFileUrl, "100", true, null);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
writeXml(oTransportClass.m_oContext, null, null, null, eError);
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
writeXml(oTransportClass.m_oContext, null, null, null, ErrorTypes.StorageWrite);
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void writeXml(HttpContext context, string strFileUrl, string strPercent, bool? bIsEndConvert, ErrorTypes? eError)
|
||||||
|
{
|
||||||
|
XmlDocument oDoc = new XmlDocument();
|
||||||
|
XmlElement oRootElem = oDoc.CreateElement("FileResult");
|
||||||
|
oDoc.AppendChild(oRootElem);
|
||||||
|
if (null != strFileUrl)
|
||||||
|
{
|
||||||
|
XmlElement oFileUrl = oDoc.CreateElement("FileUrl");
|
||||||
|
|
||||||
|
oFileUrl.InnerText = strFileUrl;
|
||||||
|
oRootElem.AppendChild(oFileUrl);
|
||||||
|
}
|
||||||
|
if (null != strPercent)
|
||||||
|
{
|
||||||
|
XmlElement oPercent = oDoc.CreateElement("Percent");
|
||||||
|
oPercent.InnerText = strPercent;
|
||||||
|
oRootElem.AppendChild(oPercent);
|
||||||
|
}
|
||||||
|
if (bIsEndConvert.HasValue)
|
||||||
|
{
|
||||||
|
XmlElement oEndConvert = oDoc.CreateElement("EndConvert");
|
||||||
|
oEndConvert.InnerText = bIsEndConvert.Value.ToString();
|
||||||
|
oRootElem.AppendChild(oEndConvert);
|
||||||
|
}
|
||||||
|
if (eError.HasValue)
|
||||||
|
{
|
||||||
|
XmlElement oError = oDoc.CreateElement("Error");
|
||||||
|
oError.InnerText = Utils.mapAscServerErrorToOldError(eError.Value).ToString();
|
||||||
|
oRootElem.AppendChild(oError);
|
||||||
|
}
|
||||||
|
oDoc.Save(context.Response.Output);
|
||||||
|
context.Response.ContentType = "text/xml";
|
||||||
|
}
|
||||||
|
private class TransportClass
|
||||||
|
{
|
||||||
|
public HttpContext m_oContext;
|
||||||
|
public AsyncCallback m_oCallback;
|
||||||
|
public Storage m_oStorage;
|
||||||
|
public AsyncContextReadOperation m_oAsyncContextRead;
|
||||||
|
public string m_sPath;
|
||||||
|
public string m_sDeletePath;
|
||||||
|
public string m_sFilename;
|
||||||
|
public TransportClass(HttpContext oContext, AsyncCallback oCallback, Storage oStorage, AsyncContextReadOperation oAsyncContextRead, string sPath, string sDeletePath, string sFilename)
|
||||||
|
{
|
||||||
|
m_oContext = oContext;
|
||||||
|
m_oCallback = oCallback;
|
||||||
|
m_oStorage = oStorage;
|
||||||
|
m_oAsyncContextRead = oAsyncContextRead;
|
||||||
|
m_sPath = sPath;
|
||||||
|
m_sDeletePath = sDeletePath;
|
||||||
|
m_sFilename = sFilename;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
<%@ WebHandler Language="C#" CodeBehind="App_Code/FontService.ashx.cs" Class="FontService" %>
|
<%@ WebHandler Language="C#" CodeBehind="FontService.ashx.cs" Class="DocService.FontService" %>
|
||||||
/*
|
/*
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
*
|
*
|
||||||
|
@ -31,3 +31,4 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -45,6 +45,8 @@ using FileConverterUtils2;
|
||||||
|
|
||||||
using log4net;
|
using log4net;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
public class FontServiceRoute : IRouteHandler
|
public class FontServiceRoute : IRouteHandler
|
||||||
{
|
{
|
||||||
public IHttpHandler GetHttpHandler(RequestContext requestContext)
|
public IHttpHandler GetHttpHandler(RequestContext requestContext)
|
||||||
|
@ -358,4 +360,5 @@ public class FontService : IHttpAsyncHandler
|
||||||
m_sFontNameDecoded = sFontNameDecoded;
|
m_sFontNameDecoded = sFontNameDecoded;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -1,101 +1 @@
|
||||||
<%@ Application Language="C#" %>
|
<%@ Application Codebehind="Global.asax.cs" Inherits="DocService.Global" Language="C#" %>
|
||||||
<%@ Assembly Name="System.Configuration, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" %>
|
|
||||||
<%@ Import Namespace="System" %>
|
|
||||||
<%@ Import Namespace="System.IO" %>
|
|
||||||
<%@ Import Namespace="System.Threading"%>
|
|
||||||
<%@ Import Namespace="System.Collections.Generic" %>
|
|
||||||
<%@ Import Namespace="System.Web.Routing" %>
|
|
||||||
<%@ Import Namespace="log4net.Config" %>
|
|
||||||
<%@ Import Namespace="FileConverterUtils2" %>
|
|
||||||
|
|
||||||
<script runat="server">
|
|
||||||
/*
|
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
|
||||||
*
|
|
||||||
* This program is a free software product. You can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
|
||||||
* version 3 as published by the Free Software Foundation. In accordance with
|
|
||||||
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
|
||||||
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
|
||||||
* of any third-party rights.
|
|
||||||
*
|
|
||||||
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
|
||||||
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
|
||||||
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
|
||||||
*
|
|
||||||
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
|
||||||
* EU, LV-1021.
|
|
||||||
*
|
|
||||||
* The interactive user interfaces in modified source and object code versions
|
|
||||||
* of the Program must display Appropriate Legal Notices, as required under
|
|
||||||
* Section 5 of the GNU AGPL version 3.
|
|
||||||
*
|
|
||||||
* Pursuant to Section 7(b) of the License you must retain the original Product
|
|
||||||
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
|
||||||
* grant you any rights under trademark law for use of our trademarks.
|
|
||||||
*
|
|
||||||
* All the Product's GUI elements, including illustrations and icon sets, as
|
|
||||||
* well as technical writing content are licensed under the terms of the
|
|
||||||
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
|
||||||
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
static public Object lockThis = new Object();
|
|
||||||
|
|
||||||
public static void RegisterRoutes(RouteCollection routes)
|
|
||||||
{
|
|
||||||
string sRoute = ConfigurationSettings.AppSettings["fonts.route"] ?? "fonts/";
|
|
||||||
routes.Add(new Route(sRoute + "native/{fontname}", new FontServiceRoute()));
|
|
||||||
routes.Add(new Route(sRoute + "js/{fontname}", new FontServiceRoute()));
|
|
||||||
routes.Add(new Route(sRoute + "odttf/{fontname}", new FontServiceRoute()));
|
|
||||||
}
|
|
||||||
|
|
||||||
void Application_Start(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
|
|
||||||
System.Diagnostics.Debug.Print("Application_Start() fired!" + sender.ToString());
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
XmlConfigurator.Configure();
|
|
||||||
}
|
|
||||||
catch(Exception ex)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
RegisterRoutes(RouteTable.Routes);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void Application_End(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
System.Diagnostics.Debug.Print("Application_End() fired!" + sender.ToString());
|
|
||||||
}
|
|
||||||
|
|
||||||
void Application_Error(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void Session_Start(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void Session_End(object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CurrentDomain_AssemblyLoad(object sender, AssemblyLoadEventArgs args)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void Application_BeginRequest(Object sender, EventArgs e)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
103
DocService/Global.asax.cs
Normal file
103
DocService/Global.asax.cs
Normal file
|
@ -0,0 +1,103 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Threading;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Web.Routing;
|
||||||
|
using log4net.Config;
|
||||||
|
using FileConverterUtils2;
|
||||||
|
using System.Configuration;
|
||||||
|
using System.Web;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
|
public class Global : System.Web.HttpApplication
|
||||||
|
{
|
||||||
|
static public Object lockThis = new Object();
|
||||||
|
|
||||||
|
public static void RegisterRoutes(RouteCollection routes)
|
||||||
|
{
|
||||||
|
string sRoute = ConfigurationSettings.AppSettings["fonts.route"] ?? "fonts/";
|
||||||
|
routes.Add(new Route(sRoute + "native/{fontname}", new FontServiceRoute()));
|
||||||
|
routes.Add(new Route(sRoute + "js/{fontname}", new FontServiceRoute()));
|
||||||
|
routes.Add(new Route(sRoute + "odttf/{fontname}", new FontServiceRoute()));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application_Start(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
|
||||||
|
System.Diagnostics.Debug.Print("Application_Start() fired!" + sender.ToString());
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
XmlConfigurator.Configure();
|
||||||
|
}
|
||||||
|
catch(Exception ex)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
RegisterRoutes(RouteTable.Routes);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application_End(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
System.Diagnostics.Debug.Print("Application_End() fired!" + sender.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application_Error(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Session_Start(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Session_End(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void CurrentDomain_AssemblyLoad(object sender, AssemblyLoadEventArgs args)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Application_BeginRequest(Object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
50
DocService/Properties/AssemblyInfo.cs
Normal file
50
DocService/Properties/AssemblyInfo.cs
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
using System.Reflection;
|
||||||
|
using System.Runtime.CompilerServices;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
|
[assembly: AssemblyTitle("DocService")]
|
||||||
|
[assembly: AssemblyDescription("")]
|
||||||
|
[assembly: AssemblyConfiguration("")]
|
||||||
|
[assembly: AssemblyCompany("")]
|
||||||
|
[assembly: AssemblyProduct("DocService")]
|
||||||
|
[assembly: AssemblyCopyright("Copyright © 2015")]
|
||||||
|
[assembly: AssemblyTrademark("")]
|
||||||
|
[assembly: AssemblyCulture("")]
|
||||||
|
|
||||||
|
[assembly: ComVisible(false)]
|
||||||
|
|
||||||
|
[assembly: Guid("868e7a06-b2c6-4e64-b900-b63bc55098ba")]
|
||||||
|
|
||||||
|
[assembly: AssemblyVersion("1.0.0.2")]
|
||||||
|
[assembly: AssemblyFileVersion("1.0.0.2")]
|
|
@ -1,4 +1,4 @@
|
||||||
<%@ WebHandler Language="C#" Class="ResourceService" %>
|
<%@ WebHandler Language="C#" CodeBehind="ResourceService.ashx.cs" Class="DocService.ResourceService" %>
|
||||||
/*
|
/*
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
*
|
*
|
||||||
|
@ -32,325 +32,3 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Net;
|
|
||||||
using System.Configuration;
|
|
||||||
using System.Web;
|
|
||||||
using System.IO;
|
|
||||||
using System.Text;
|
|
||||||
|
|
||||||
using FileConverterUtils2;
|
|
||||||
|
|
||||||
using log4net;
|
|
||||||
|
|
||||||
public class ResourceService : IHttpAsyncHandler
|
|
||||||
{
|
|
||||||
private readonly ILog _log = LogManager.GetLogger(typeof(ResourceService));
|
|
||||||
|
|
||||||
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
|
||||||
{
|
|
||||||
bool bStartAsync = false;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
_log.Info("Starting process request...");
|
|
||||||
_log.Info(context.Request.QueryString.ToString());
|
|
||||||
|
|
||||||
Storage oStorage = new Storage();
|
|
||||||
ITaskResultInterface oTaskResult = TaskResult.NewTaskResult();
|
|
||||||
string sPathOriginal = context.Request.QueryString["path"];
|
|
||||||
string sPath = null;
|
|
||||||
if (null != sPathOriginal)
|
|
||||||
{
|
|
||||||
sPath = sPathOriginal.Replace("../", "").Replace("..\\", "");
|
|
||||||
if (sPathOriginal != sPath)
|
|
||||||
{
|
|
||||||
_log.Error("Possible XSS attack:" + sPathOriginal);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
string sOutputFilename = context.Request.QueryString["filename"];
|
|
||||||
|
|
||||||
string sDeletePathOriginal = context.Request.QueryString["deletepath"];
|
|
||||||
string sDeletePath = null;
|
|
||||||
if (null != sDeletePathOriginal)
|
|
||||||
{
|
|
||||||
sDeletePath = sDeletePathOriginal.Replace("../", "").Replace("..\\", "");
|
|
||||||
if (sDeletePathOriginal != sDeletePath)
|
|
||||||
{
|
|
||||||
_log.Error("Possible XSS attack:" + sDeletePathOriginal);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
string sNoCache = context.Request.QueryString["nocache"];
|
|
||||||
if (string.IsNullOrEmpty(sOutputFilename))
|
|
||||||
{
|
|
||||||
if (null != sPath)
|
|
||||||
{
|
|
||||||
int nIndex1 = sPath.LastIndexOf('/');
|
|
||||||
int nIndex2 = sPath.LastIndexOf('\\');
|
|
||||||
if (-1 != nIndex1 || -1 != nIndex2)
|
|
||||||
{
|
|
||||||
int nIndex = Math.Max(nIndex1, nIndex2);
|
|
||||||
sOutputFilename = sPath.Substring(nIndex + 1);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
sOutputFilename = "resource";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
context.Response.Clear();
|
|
||||||
|
|
||||||
context.Response.Cache.SetCacheability(HttpCacheability.Public);
|
|
||||||
context.Response.ContentType = Utils.GetMimeType(sOutputFilename);
|
|
||||||
string contentDisposition = Utils.GetContentDisposition(context.Request.UserAgent, context.Request.Browser.Browser, context.Request.Browser.Version, sOutputFilename);
|
|
||||||
context.Response.AppendHeader("Content-Disposition", contentDisposition);
|
|
||||||
if (null != sPath)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = new TransportClass(context, cb, oStorage, oTaskResult, sPath, sDeletePath);
|
|
||||||
oStorage.GetFileInfoBegin(sPath, GetFileInfoCallback, oTransportClass);
|
|
||||||
bStartAsync = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
context.Response.StatusCode = (int)HttpStatusCode.NotFound;
|
|
||||||
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
|
|
||||||
|
|
||||||
_log.Error(context.Request.QueryString.ToString());
|
|
||||||
_log.Error("Exeption catched in BeginProcessRequest:", e);
|
|
||||||
}
|
|
||||||
TransportClass oTempTransportClass = new TransportClass(context, cb, null, null, null, null);
|
|
||||||
if (false == bStartAsync)
|
|
||||||
cb(new AsyncOperationData(oTempTransportClass));
|
|
||||||
return new AsyncOperationData(oTempTransportClass);
|
|
||||||
}
|
|
||||||
public void EndProcessRequest(IAsyncResult result)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
private void GetFileInfoCallback(IAsyncResult result)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
|
||||||
HttpContext context = oTransportClass.m_oContext;
|
|
||||||
bool bStartAsync = false;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
string sPath = oTransportClass.m_sPath;
|
|
||||||
Storage oStorage = oTransportClass.m_oStorage;
|
|
||||||
StorageFileInfo oStorageFileInfo;
|
|
||||||
if (ErrorTypes.NoError == oStorage.GetFileInfoEnd(result, out oStorageFileInfo) && null != oStorageFileInfo)
|
|
||||||
{
|
|
||||||
string sETag = oStorageFileInfo.m_oLastModify.Ticks.ToString("x");
|
|
||||||
DateTime oLastModified = oStorageFileInfo.m_oLastModify;
|
|
||||||
|
|
||||||
DateTime oDateTimeUtcNow = DateTime.UtcNow;
|
|
||||||
_log.InfoFormat("oLastModified = {0}", oLastModified);
|
|
||||||
_log.InfoFormat("oDateTimeUtcNow = {0}", oDateTimeUtcNow);
|
|
||||||
|
|
||||||
if (oLastModified.CompareTo(oDateTimeUtcNow) > 0)
|
|
||||||
{
|
|
||||||
_log.DebugFormat("LastModifiedTimeStamp changed from {0} to {1}", oLastModified, oDateTimeUtcNow);
|
|
||||||
oLastModified = oDateTimeUtcNow;
|
|
||||||
}
|
|
||||||
|
|
||||||
string sRequestIfModifiedSince = context.Request.Headers["If-Modified-Since"];
|
|
||||||
string sRequestETag = context.Request.Headers["If-None-Match"];
|
|
||||||
bool bNoModify = false;
|
|
||||||
if (false == string.IsNullOrEmpty(sRequestETag) || false == string.IsNullOrEmpty(sRequestIfModifiedSince))
|
|
||||||
{
|
|
||||||
bool bRequestETag = true;
|
|
||||||
if (false == string.IsNullOrEmpty(sRequestETag) && sRequestETag != sETag)
|
|
||||||
bRequestETag = false;
|
|
||||||
bool bRequestIfModifiedSince = true;
|
|
||||||
if (false == string.IsNullOrEmpty(sRequestIfModifiedSince))
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
DateTime oRequestIfModifiedSince = DateTime.ParseExact(sRequestIfModifiedSince, "R", System.Globalization.CultureInfo.InvariantCulture);
|
|
||||||
if ((oRequestIfModifiedSince - oLastModified).TotalSeconds > 1)
|
|
||||||
bRequestIfModifiedSince = false;
|
|
||||||
}
|
|
||||||
catch
|
|
||||||
{
|
|
||||||
bRequestIfModifiedSince = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (bRequestETag && bRequestIfModifiedSince)
|
|
||||||
{
|
|
||||||
context.Response.StatusCode = (int)HttpStatusCode.NotModified;
|
|
||||||
bNoModify = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (false == bNoModify)
|
|
||||||
{
|
|
||||||
context.Response.Cache.SetETag(sETag);
|
|
||||||
|
|
||||||
context.Response.Cache.SetLastModified(oLastModified.ToLocalTime());
|
|
||||||
|
|
||||||
oStorage.ReadFileBegin(sPath, context.Response.OutputStream, ReadFileCallback, oTransportClass);
|
|
||||||
bStartAsync = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
context.Response.StatusCode = (int)HttpStatusCode.NotFound;
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exception catched in GetFileInfoCallback:", e);
|
|
||||||
|
|
||||||
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
|
|
||||||
}
|
|
||||||
if (!bStartAsync)
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
private void ReadFileCallback(IAsyncResult result)
|
|
||||||
{
|
|
||||||
SendResponse(result);
|
|
||||||
DeletePath(result);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void DeletePath(IAsyncResult result)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (null != oTransportClass.m_sDeletePath && false == string.IsNullOrEmpty(oTransportClass.m_sDeletePath))
|
|
||||||
{
|
|
||||||
ITaskResultInterface oTaskResult = oTransportClass.m_oTaskResult;
|
|
||||||
|
|
||||||
string sKey = oTransportClass.m_sDeletePath;
|
|
||||||
|
|
||||||
oTaskResult.RemoveBegin(sKey, RemoveTaskCallback, oTransportClass);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exception catched in DeletePath:", e);
|
|
||||||
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SendResponse(IAsyncResult result)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
|
||||||
HttpContext context = oTransportClass.m_oContext;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
|
|
||||||
Storage oStorage = oTransportClass.m_oStorage;
|
|
||||||
if (null == oStorage)
|
|
||||||
{
|
|
||||||
throw new NullReferenceException();
|
|
||||||
}
|
|
||||||
|
|
||||||
int nReadWriteBytes = 0;
|
|
||||||
ErrorTypes eResult = oStorage.ReadFileEnd(result, out nReadWriteBytes);
|
|
||||||
if (ErrorTypes.NoError == eResult)
|
|
||||||
{
|
|
||||||
context.Response.AppendHeader("Content-Length", nReadWriteBytes.ToString());
|
|
||||||
context.Response.StatusCode = (int)HttpStatusCode.OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
catch (HttpException httpEx)
|
|
||||||
{
|
|
||||||
_log.Error("HttpException catched in SendResponse:", httpEx);
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exception catched in SendResponse:", e);
|
|
||||||
|
|
||||||
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
|
|
||||||
}
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (context.Response.IsClientConnected)
|
|
||||||
{
|
|
||||||
context.Response.Flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exception catched in SendResponse, while response end:", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void RemoveTaskCallback(IAsyncResult result)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ITaskResultInterface oTaskResult = oTransportClass.m_oTaskResult;
|
|
||||||
|
|
||||||
if (null != oTaskResult)
|
|
||||||
oTaskResult.RemoveEnd(result);
|
|
||||||
|
|
||||||
Storage oStorage = oTransportClass.m_oStorage;
|
|
||||||
|
|
||||||
if (null != oStorage)
|
|
||||||
oStorage.RemovePathBegin(oTransportClass.m_sDeletePath, RemoveFileCallback, oTransportClass);
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exception catched in RemoveTaskCallback:", e);
|
|
||||||
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void RemoveFileCallback(IAsyncResult result)
|
|
||||||
{
|
|
||||||
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
|
||||||
HttpContext context = oTransportClass.m_oContext;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Storage oStorage = oTransportClass.m_oStorage;
|
|
||||||
if (null != oStorage)
|
|
||||||
oStorage.RemovePathEnd(result);
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exception catched in RemoveFileCallback:", e);
|
|
||||||
|
|
||||||
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
public void ProcessRequest(HttpContext context)
|
|
||||||
{
|
|
||||||
throw new InvalidOperationException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool IsReusable
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private class TransportClass
|
|
||||||
{
|
|
||||||
public HttpContext m_oContext;
|
|
||||||
public AsyncCallback m_oCallback;
|
|
||||||
public Storage m_oStorage;
|
|
||||||
public ITaskResultInterface m_oTaskResult;
|
|
||||||
public string m_sPath;
|
|
||||||
public string m_sDeletePath;
|
|
||||||
public TransportClass(HttpContext oContext, AsyncCallback oCallback, Storage oStorage, ITaskResultInterface oTaskResult, string sPath, string sDeletePath)
|
|
||||||
{
|
|
||||||
m_oContext = oContext;
|
|
||||||
m_oCallback = oCallback;
|
|
||||||
m_oStorage = oStorage;
|
|
||||||
m_oTaskResult = oTaskResult;
|
|
||||||
m_sPath = sPath;
|
|
||||||
m_sDeletePath = sDeletePath;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
355
DocService/ResourceService.ashx.cs
Normal file
355
DocService/ResourceService.ashx.cs
Normal file
|
@ -0,0 +1,355 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
using System;
|
||||||
|
using System.Net;
|
||||||
|
using System.Configuration;
|
||||||
|
using System.Web;
|
||||||
|
using System.IO;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
using FileConverterUtils2;
|
||||||
|
|
||||||
|
using log4net;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
|
public class ResourceService : IHttpAsyncHandler
|
||||||
|
{
|
||||||
|
private readonly ILog _log = LogManager.GetLogger(typeof(ResourceService));
|
||||||
|
|
||||||
|
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
||||||
|
{
|
||||||
|
bool bStartAsync = false;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_log.Info("Starting process request...");
|
||||||
|
_log.Info(context.Request.QueryString.ToString());
|
||||||
|
|
||||||
|
Storage oStorage = new Storage();
|
||||||
|
ITaskResultInterface oTaskResult = TaskResult.NewTaskResult();
|
||||||
|
string sPathOriginal = context.Request.QueryString["path"];
|
||||||
|
string sPath = null;
|
||||||
|
if (null != sPathOriginal)
|
||||||
|
{
|
||||||
|
sPath = sPathOriginal.Replace("../", "").Replace("..\\", "");
|
||||||
|
if (sPathOriginal != sPath)
|
||||||
|
{
|
||||||
|
_log.Error("Possible XSS attack:" + sPathOriginal);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
string sOutputFilename = context.Request.QueryString["filename"];
|
||||||
|
|
||||||
|
string sDeletePathOriginal = context.Request.QueryString["deletepath"];
|
||||||
|
string sDeletePath = null;
|
||||||
|
if (null != sDeletePathOriginal)
|
||||||
|
{
|
||||||
|
sDeletePath = sDeletePathOriginal.Replace("../", "").Replace("..\\", "");
|
||||||
|
if (sDeletePathOriginal != sDeletePath)
|
||||||
|
{
|
||||||
|
_log.Error("Possible XSS attack:" + sDeletePathOriginal);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
string sNoCache = context.Request.QueryString["nocache"];
|
||||||
|
if (string.IsNullOrEmpty(sOutputFilename))
|
||||||
|
{
|
||||||
|
if (null != sPath)
|
||||||
|
{
|
||||||
|
int nIndex1 = sPath.LastIndexOf('/');
|
||||||
|
int nIndex2 = sPath.LastIndexOf('\\');
|
||||||
|
if (-1 != nIndex1 || -1 != nIndex2)
|
||||||
|
{
|
||||||
|
int nIndex = Math.Max(nIndex1, nIndex2);
|
||||||
|
sOutputFilename = sPath.Substring(nIndex + 1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
sOutputFilename = "resource";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
context.Response.Clear();
|
||||||
|
|
||||||
|
context.Response.Cache.SetCacheability(HttpCacheability.Public);
|
||||||
|
context.Response.ContentType = Utils.GetMimeType(sOutputFilename);
|
||||||
|
string contentDisposition = Utils.GetContentDisposition(context.Request.UserAgent, context.Request.Browser.Browser, context.Request.Browser.Version, sOutputFilename);
|
||||||
|
context.Response.AppendHeader("Content-Disposition", contentDisposition);
|
||||||
|
if (null != sPath)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = new TransportClass(context, cb, oStorage, oTaskResult, sPath, sDeletePath);
|
||||||
|
oStorage.GetFileInfoBegin(sPath, GetFileInfoCallback, oTransportClass);
|
||||||
|
bStartAsync = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
context.Response.StatusCode = (int)HttpStatusCode.NotFound;
|
||||||
|
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
|
||||||
|
|
||||||
|
_log.Error(context.Request.QueryString.ToString());
|
||||||
|
_log.Error("Exeption catched in BeginProcessRequest:", e);
|
||||||
|
}
|
||||||
|
TransportClass oTempTransportClass = new TransportClass(context, cb, null, null, null, null);
|
||||||
|
if (false == bStartAsync)
|
||||||
|
cb(new AsyncOperationData(oTempTransportClass));
|
||||||
|
return new AsyncOperationData(oTempTransportClass);
|
||||||
|
}
|
||||||
|
public void EndProcessRequest(IAsyncResult result)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
private void GetFileInfoCallback(IAsyncResult result)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
||||||
|
HttpContext context = oTransportClass.m_oContext;
|
||||||
|
bool bStartAsync = false;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
string sPath = oTransportClass.m_sPath;
|
||||||
|
Storage oStorage = oTransportClass.m_oStorage;
|
||||||
|
StorageFileInfo oStorageFileInfo;
|
||||||
|
if (ErrorTypes.NoError == oStorage.GetFileInfoEnd(result, out oStorageFileInfo) && null != oStorageFileInfo)
|
||||||
|
{
|
||||||
|
string sETag = oStorageFileInfo.m_oLastModify.Ticks.ToString("x");
|
||||||
|
DateTime oLastModified = oStorageFileInfo.m_oLastModify;
|
||||||
|
|
||||||
|
DateTime oDateTimeUtcNow = DateTime.UtcNow;
|
||||||
|
_log.InfoFormat("oLastModified = {0}", oLastModified);
|
||||||
|
_log.InfoFormat("oDateTimeUtcNow = {0}", oDateTimeUtcNow);
|
||||||
|
|
||||||
|
if (oLastModified.CompareTo(oDateTimeUtcNow) > 0)
|
||||||
|
{
|
||||||
|
_log.DebugFormat("LastModifiedTimeStamp changed from {0} to {1}", oLastModified, oDateTimeUtcNow);
|
||||||
|
oLastModified = oDateTimeUtcNow;
|
||||||
|
}
|
||||||
|
|
||||||
|
string sRequestIfModifiedSince = context.Request.Headers["If-Modified-Since"];
|
||||||
|
string sRequestETag = context.Request.Headers["If-None-Match"];
|
||||||
|
bool bNoModify = false;
|
||||||
|
if (false == string.IsNullOrEmpty(sRequestETag) || false == string.IsNullOrEmpty(sRequestIfModifiedSince))
|
||||||
|
{
|
||||||
|
bool bRequestETag = true;
|
||||||
|
if (false == string.IsNullOrEmpty(sRequestETag) && sRequestETag != sETag)
|
||||||
|
bRequestETag = false;
|
||||||
|
bool bRequestIfModifiedSince = true;
|
||||||
|
if (false == string.IsNullOrEmpty(sRequestIfModifiedSince))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
DateTime oRequestIfModifiedSince = DateTime.ParseExact(sRequestIfModifiedSince, "R", System.Globalization.CultureInfo.InvariantCulture);
|
||||||
|
if ((oRequestIfModifiedSince - oLastModified).TotalSeconds > 1)
|
||||||
|
bRequestIfModifiedSince = false;
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
bRequestIfModifiedSince = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (bRequestETag && bRequestIfModifiedSince)
|
||||||
|
{
|
||||||
|
context.Response.StatusCode = (int)HttpStatusCode.NotModified;
|
||||||
|
bNoModify = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (false == bNoModify)
|
||||||
|
{
|
||||||
|
context.Response.Cache.SetETag(sETag);
|
||||||
|
|
||||||
|
context.Response.Cache.SetLastModified(oLastModified.ToLocalTime());
|
||||||
|
|
||||||
|
oStorage.ReadFileBegin(sPath, context.Response.OutputStream, ReadFileCallback, oTransportClass);
|
||||||
|
bStartAsync = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
context.Response.StatusCode = (int)HttpStatusCode.NotFound;
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exception catched in GetFileInfoCallback:", e);
|
||||||
|
|
||||||
|
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
|
||||||
|
}
|
||||||
|
if (!bStartAsync)
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
private void ReadFileCallback(IAsyncResult result)
|
||||||
|
{
|
||||||
|
SendResponse(result);
|
||||||
|
DeletePath(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void DeletePath(IAsyncResult result)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (null != oTransportClass.m_sDeletePath && false == string.IsNullOrEmpty(oTransportClass.m_sDeletePath))
|
||||||
|
{
|
||||||
|
ITaskResultInterface oTaskResult = oTransportClass.m_oTaskResult;
|
||||||
|
|
||||||
|
string sKey = oTransportClass.m_sDeletePath;
|
||||||
|
|
||||||
|
oTaskResult.RemoveBegin(sKey, RemoveTaskCallback, oTransportClass);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exception catched in DeletePath:", e);
|
||||||
|
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SendResponse(IAsyncResult result)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
||||||
|
HttpContext context = oTransportClass.m_oContext;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
|
||||||
|
Storage oStorage = oTransportClass.m_oStorage;
|
||||||
|
if (null == oStorage)
|
||||||
|
{
|
||||||
|
throw new NullReferenceException();
|
||||||
|
}
|
||||||
|
|
||||||
|
int nReadWriteBytes = 0;
|
||||||
|
ErrorTypes eResult = oStorage.ReadFileEnd(result, out nReadWriteBytes);
|
||||||
|
if (ErrorTypes.NoError == eResult)
|
||||||
|
{
|
||||||
|
context.Response.AppendHeader("Content-Length", nReadWriteBytes.ToString());
|
||||||
|
context.Response.StatusCode = (int)HttpStatusCode.OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (HttpException httpEx)
|
||||||
|
{
|
||||||
|
_log.Error("HttpException catched in SendResponse:", httpEx);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exception catched in SendResponse:", e);
|
||||||
|
|
||||||
|
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
|
||||||
|
}
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (context.Response.IsClientConnected)
|
||||||
|
{
|
||||||
|
context.Response.Flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exception catched in SendResponse, while response end:", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void RemoveTaskCallback(IAsyncResult result)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
ITaskResultInterface oTaskResult = oTransportClass.m_oTaskResult;
|
||||||
|
|
||||||
|
if (null != oTaskResult)
|
||||||
|
oTaskResult.RemoveEnd(result);
|
||||||
|
|
||||||
|
Storage oStorage = oTransportClass.m_oStorage;
|
||||||
|
|
||||||
|
if (null != oStorage)
|
||||||
|
oStorage.RemovePathBegin(oTransportClass.m_sDeletePath, RemoveFileCallback, oTransportClass);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exception catched in RemoveTaskCallback:", e);
|
||||||
|
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void RemoveFileCallback(IAsyncResult result)
|
||||||
|
{
|
||||||
|
TransportClass oTransportClass = result.AsyncState as TransportClass;
|
||||||
|
HttpContext context = oTransportClass.m_oContext;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
Storage oStorage = oTransportClass.m_oStorage;
|
||||||
|
if (null != oStorage)
|
||||||
|
oStorage.RemovePathEnd(result);
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exception catched in RemoveFileCallback:", e);
|
||||||
|
|
||||||
|
oTransportClass.m_oCallback(new AsyncOperationData(oTransportClass));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public void ProcessRequest(HttpContext context)
|
||||||
|
{
|
||||||
|
throw new InvalidOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsReusable
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private class TransportClass
|
||||||
|
{
|
||||||
|
public HttpContext m_oContext;
|
||||||
|
public AsyncCallback m_oCallback;
|
||||||
|
public Storage m_oStorage;
|
||||||
|
public ITaskResultInterface m_oTaskResult;
|
||||||
|
public string m_sPath;
|
||||||
|
public string m_sDeletePath;
|
||||||
|
public TransportClass(HttpContext oContext, AsyncCallback oCallback, Storage oStorage, ITaskResultInterface oTaskResult, string sPath, string sDeletePath)
|
||||||
|
{
|
||||||
|
m_oContext = oContext;
|
||||||
|
m_oCallback = oCallback;
|
||||||
|
m_oStorage = oStorage;
|
||||||
|
m_oTaskResult = oTaskResult;
|
||||||
|
m_sPath = sPath;
|
||||||
|
m_sDeletePath = sDeletePath;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
<%@ WebHandler Language="C#" Class="TrackingService" %>
|
<%@ WebHandler Language="C#" CodeBehind="TrackingService.ashx.cs" Class="DocService.TrackingService" %>
|
||||||
/*
|
/*
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
*
|
*
|
||||||
|
@ -32,24 +32,3 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Web;
|
|
||||||
using System.Xml;
|
|
||||||
using System.Runtime.Serialization;
|
|
||||||
using System.Runtime.Serialization.Json;
|
|
||||||
using FileConverterUtils2;
|
|
||||||
|
|
||||||
public class TrackingService : IHttpHandler {
|
|
||||||
|
|
||||||
public void ProcessRequest (HttpContext context)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool IsReusable {
|
|
||||||
get {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
55
DocService/TrackingService.ashx.cs
Normal file
55
DocService/TrackingService.ashx.cs
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Web;
|
||||||
|
using System.Xml;
|
||||||
|
using System.Runtime.Serialization;
|
||||||
|
using System.Runtime.Serialization.Json;
|
||||||
|
using FileConverterUtils2;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
|
public class TrackingService : IHttpHandler {
|
||||||
|
|
||||||
|
public void ProcessRequest (HttpContext context)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsReusable {
|
||||||
|
get {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
<%@ WebHandler Language="C#" Class="UploadService" %>
|
<%@ WebHandler Language="C#" CodeBehind="UploadService.ashx.cs" Class="DocService.UploadService" %>
|
||||||
/*
|
/*
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
*
|
*
|
||||||
|
@ -32,332 +32,3 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Net;
|
|
||||||
using System.Configuration;
|
|
||||||
using System.Web;
|
|
||||||
using System.IO;
|
|
||||||
using System.Text;
|
|
||||||
using System.Xml;
|
|
||||||
using System.Collections;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Web.Script.Serialization;
|
|
||||||
using System.Collections.Specialized;
|
|
||||||
|
|
||||||
using FileConverterUtils2;
|
|
||||||
|
|
||||||
using log4net;
|
|
||||||
|
|
||||||
public class UploadService : IHttpAsyncHandler
|
|
||||||
{
|
|
||||||
private readonly ILog _log = LogManager.GetLogger(typeof(UploadService));
|
|
||||||
|
|
||||||
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
|
||||||
{
|
|
||||||
|
|
||||||
TransportClassMainAshx oTransportClassMainAshx = new TransportClassMainAshx(context, cb);
|
|
||||||
ErrorTypes eError = ErrorTypes.NoError;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
_log.Info("Starting process request...");
|
|
||||||
_log.Info(context.Request.QueryString.ToString());
|
|
||||||
|
|
||||||
string sGuid = context.Request.QueryString["key"];
|
|
||||||
int nMaxBytes = Convert.ToInt32(ConfigurationSettings.AppSettings["limits.image.size"] ?? "25000000");
|
|
||||||
if (context.Request.ContentLength <= nMaxBytes)
|
|
||||||
{
|
|
||||||
if (context.Request.Files.Count > 0)
|
|
||||||
{
|
|
||||||
|
|
||||||
int nParamsCount = 0;
|
|
||||||
string sInputParams = "";
|
|
||||||
for (int i = 0, length = context.Request.QueryString.Count; i < length; ++i)
|
|
||||||
{
|
|
||||||
sInputParams += context.Request.QueryString.Get(i) + ":" + context.Request.QueryString.GetKey(i);
|
|
||||||
if (nParamsCount > 0)
|
|
||||||
sInputParams += ",";
|
|
||||||
nParamsCount++;
|
|
||||||
}
|
|
||||||
AsyncMediaXmlOperation oAsyncMediaXmlOperation = new AsyncMediaXmlOperation();
|
|
||||||
List<string> aUrls = new List<string>();
|
|
||||||
TransportClass1 oTransportClass1 = new TransportClass1(oTransportClassMainAshx, oAsyncMediaXmlOperation, context.Request.QueryString, aUrls, sGuid, Path.Combine(sGuid, @"media/media.xml"), context.Request.Files, context.Request.Files.GetEnumerator());
|
|
||||||
oAsyncMediaXmlOperation.GetMediaXmlBegin(oTransportClass1.m_sMediaXml, GetMediaXmlCallback, oTransportClass1);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
eError = ErrorTypes.UploadCountFiles;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
eError = ErrorTypes.UploadContentLength;
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
eError = ErrorTypes.Upload;
|
|
||||||
|
|
||||||
_log.Error(context.Request.QueryString.ToString());
|
|
||||||
_log.Error("Exeption: ", e);
|
|
||||||
}
|
|
||||||
if (ErrorTypes.NoError != eError)
|
|
||||||
WriteToResponse(oTransportClassMainAshx, eError, null, context.Request.QueryString);
|
|
||||||
return new AsyncOperationData(extraData);
|
|
||||||
}
|
|
||||||
public void EndProcessRequest(IAsyncResult result)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
public void ProcessRequest(HttpContext context)
|
|
||||||
{
|
|
||||||
throw new InvalidOperationException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool IsReusable
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#region HelpFunctions
|
|
||||||
private void WriteToResponse(TransportClassMainAshx oTransportClassMainAshx, ErrorTypes eError, List<string> aUrls, NameValueCollection aNameValueCollection)
|
|
||||||
{
|
|
||||||
HttpContext oHttpContext = oTransportClassMainAshx.m_oHttpContext;
|
|
||||||
AsyncCallback oAsyncCallback = oTransportClassMainAshx.m_oAsyncCallback;
|
|
||||||
OutputCommand oOutputCommand = new OutputCommand();
|
|
||||||
if (null != aNameValueCollection)
|
|
||||||
{
|
|
||||||
|
|
||||||
for (int i = 0, length = aNameValueCollection.Count; i < length; ++i)
|
|
||||||
oOutputCommand.input.Add(aNameValueCollection.GetKey(i), aNameValueCollection.Get(i));
|
|
||||||
}
|
|
||||||
oOutputCommand.urls = aUrls;
|
|
||||||
oOutputCommand.error = (int)eError;
|
|
||||||
oOutputCommand.type = (int)PostMessageType.UploadImage;
|
|
||||||
|
|
||||||
JavaScriptSerializer serializer = new JavaScriptSerializer();
|
|
||||||
StringBuilder sb = new StringBuilder();
|
|
||||||
serializer.Serialize(oOutputCommand, sb);
|
|
||||||
string sJson = sb.ToString();
|
|
||||||
|
|
||||||
oHttpContext.Response.Write("<html><head><script type=\"text/javascript\">function load(){ parent.postMessage(\"" + sJson.Replace("\"", "\\\"") + "\", '*'); }</script></head><body onload='load()'></body></html>");
|
|
||||||
|
|
||||||
oAsyncCallback.Invoke(new AsyncOperationData(null));
|
|
||||||
}
|
|
||||||
#endregion
|
|
||||||
#region Callbacks
|
|
||||||
private void GetMediaXmlCallbackProcess(TransportClass1 oTransportClass1, Dictionary<string, string> aMediaXmlMapHash, Dictionary<string, string> aMediaXmlMapFilename)
|
|
||||||
{
|
|
||||||
AsyncContextReadOperation oAsyncContextReadOperation = new AsyncContextReadOperation();
|
|
||||||
TransportClass2 oTransportClass2 = new TransportClass2(oTransportClass1, aMediaXmlMapHash, aMediaXmlMapFilename, oAsyncContextReadOperation);
|
|
||||||
HttpPostedFile oCurrentFile = (HttpPostedFile)oTransportClass1.m_oFiles[(string)oTransportClass1.m_oFilesEnumerator.Current];
|
|
||||||
oCurrentFile.InputStream.Position = 0;
|
|
||||||
oAsyncContextReadOperation.ReadContextBegin(oCurrentFile.InputStream, ReadContextCallback, oTransportClass2);
|
|
||||||
}
|
|
||||||
private void GetMediaXmlCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
Dictionary<string, string> aMediaXmlMapHash;
|
|
||||||
Dictionary<string, string> aMediaXmlMapFilename;
|
|
||||||
ErrorTypes eError = oTransportClass1.m_oAsyncMediaXmlOperation.GetMediaXmlEnd(ar, out aMediaXmlMapHash, out aMediaXmlMapFilename);
|
|
||||||
if (ErrorTypes.NoError == eError && oTransportClass1.m_oFilesEnumerator.MoveNext())
|
|
||||||
{
|
|
||||||
GetMediaXmlCallbackProcess(oTransportClass1, aMediaXmlMapHash, aMediaXmlMapFilename);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
WriteToResponse(oTransportClass1, eError, null, oTransportClass1.m_aInputParams);
|
|
||||||
}
|
|
||||||
catch(Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exeption: ", e);
|
|
||||||
WriteToResponse(oTransportClass1, ErrorTypes.Upload, null, oTransportClass1.m_aInputParams);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void ReadContextCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass2 oTransportClass2 = ar.AsyncState as TransportClass2;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ErrorTypes eError = oTransportClass2.m_oAsyncContextReadOperation.ReadContextEnd(ar);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
HttpPostedFile oCurrentFile = ((HttpPostedFile)oTransportClass2.m_oFiles[(string)oTransportClass2.m_oFilesEnumerator.Current]);
|
|
||||||
oCurrentFile.InputStream.Position = 0;
|
|
||||||
Stream oImageStream = oCurrentFile.InputStream;
|
|
||||||
byte[] aBuffer = oTransportClass2.m_oAsyncContextReadOperation.m_aOutput.ToArray();
|
|
||||||
int nImageFormat = FormatChecker.GetFileFormat(aBuffer);
|
|
||||||
string sSupportedFormats = ConfigurationSettings.AppSettings["limits.image.types.upload"] ?? "jpg";
|
|
||||||
if (0 != (FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE & nImageFormat) && -1 != sSupportedFormats.IndexOf(FileFormats.ToString(nImageFormat)))
|
|
||||||
{
|
|
||||||
if (FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE_GIF == nImageFormat || FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE_ICO == nImageFormat)
|
|
||||||
{
|
|
||||||
byte[] aNewBuffer;
|
|
||||||
if (Utils.ConvertGifIcoToPng(aBuffer, nImageFormat, out aNewBuffer))
|
|
||||||
{
|
|
||||||
nImageFormat = FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE_PNG;
|
|
||||||
aBuffer = aNewBuffer;
|
|
||||||
oImageStream = new MemoryStream(aBuffer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
string sImageHash = null;
|
|
||||||
using (MemoryStream ms = new MemoryStream(aBuffer))
|
|
||||||
sImageHash = Utils.getMD5HexString(ms);
|
|
||||||
|
|
||||||
string sFileName;
|
|
||||||
if (oTransportClass2.m_oMediaXmlMapHash.TryGetValue(sImageHash, out sFileName))
|
|
||||||
{
|
|
||||||
|
|
||||||
ImageUrlProcess(oTransportClass2, Constants.mc_sResourceServiceUrlRel + Path.Combine(oTransportClass2.m_sKey, @"media\" + sFileName).Replace('\\', '/'));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
|
|
||||||
string sSearchName = "image";
|
|
||||||
List<int> aIndexes = new List<int>();
|
|
||||||
foreach (KeyValuePair<string, string> kvp in oTransportClass2.m_oMediaXmlMapFilename)
|
|
||||||
{
|
|
||||||
string sFilename = Path.GetFileNameWithoutExtension(kvp.Key);
|
|
||||||
if (0 == sFilename.IndexOf(sSearchName))
|
|
||||||
{
|
|
||||||
int nCurIndex;
|
|
||||||
if (int.TryParse(sFilename.Substring(sSearchName.Length), out nCurIndex))
|
|
||||||
aIndexes.Add(nCurIndex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
int nMaxIndex = -1;
|
|
||||||
for (int i = 0, length = aIndexes.Count; i < length; ++i)
|
|
||||||
{
|
|
||||||
int nCurIndex = aIndexes[i];
|
|
||||||
if (nMaxIndex < nCurIndex)
|
|
||||||
nMaxIndex = nCurIndex;
|
|
||||||
}
|
|
||||||
int nNewIndex = 1;
|
|
||||||
if (nMaxIndex >= nNewIndex)
|
|
||||||
nNewIndex = nMaxIndex + 1;
|
|
||||||
string sNewName = sSearchName + nNewIndex + "." + FileFormats.ToString(nImageFormat);
|
|
||||||
|
|
||||||
string sNewPath = Path.Combine(oTransportClass2.m_sKey, @"media\" + sNewName).Replace('\\', '/');
|
|
||||||
Storage oStorage = new Storage();
|
|
||||||
TransportClass3 oTransportClass3 = new TransportClass3(oTransportClass2, sNewName, sImageHash, sNewPath, oStorage);
|
|
||||||
oTransportClass3.m_oStorage.WriteFileBegin(sNewPath, oImageStream, WriteUploadedFileCallback, oTransportClass3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
WriteToResponse(oTransportClass2, ErrorTypes.UploadExtension, null, oTransportClass2.m_aInputParams);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
WriteToResponse(oTransportClass2, eError, null, oTransportClass2.m_aInputParams);
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exeption: ", e);
|
|
||||||
WriteToResponse(oTransportClass2, ErrorTypes.Upload, null, oTransportClass2.m_aInputParams);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void ImageUrlProcess(TransportClass2 oTransportClass2, string sUrl)
|
|
||||||
{
|
|
||||||
oTransportClass2.m_aUrls.Add(sUrl);
|
|
||||||
if (oTransportClass2.m_oFilesEnumerator.MoveNext())
|
|
||||||
GetMediaXmlCallbackProcess(oTransportClass2, oTransportClass2.m_oMediaXmlMapHash, oTransportClass2.m_oMediaXmlMapFilename);
|
|
||||||
else
|
|
||||||
oTransportClass2.m_oAsyncMediaXmlOperation.WriteMediaXmlBegin(oTransportClass2.m_sMediaXml, oTransportClass2.m_oMediaXmlMapHash, WriteMediaXmlCallback, oTransportClass2);
|
|
||||||
}
|
|
||||||
private void WriteUploadedFileCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass3 oTransportClass3 = ar.AsyncState as TransportClass3;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
int nReadWriteBytes;
|
|
||||||
ErrorTypes eError = oTransportClass3.m_oStorage.WriteFileEnd(ar, out nReadWriteBytes);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
{
|
|
||||||
oTransportClass3.m_oMediaXmlMapHash.Add(oTransportClass3.m_sHash, oTransportClass3.m_sFilename);
|
|
||||||
oTransportClass3.m_oMediaXmlMapFilename.Add(oTransportClass3.m_sFilename, oTransportClass3.m_sHash);
|
|
||||||
ImageUrlProcess(oTransportClass3, Constants.mc_sResourceServiceUrlRel + oTransportClass3.m_sPath.Replace('\\', '/'));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
WriteToResponse(oTransportClass3, eError, null, oTransportClass3.m_aInputParams);
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exeption: ", e);
|
|
||||||
WriteToResponse(oTransportClass3, ErrorTypes.Upload, null, oTransportClass3.m_aInputParams);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private void WriteMediaXmlCallback(IAsyncResult ar)
|
|
||||||
{
|
|
||||||
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ErrorTypes eError = oTransportClass1.m_oAsyncMediaXmlOperation.WriteMediaXmlEnd(ar);
|
|
||||||
if (ErrorTypes.NoError == eError)
|
|
||||||
WriteToResponse(oTransportClass1, ErrorTypes.NoError, oTransportClass1.m_aUrls, oTransportClass1.m_aInputParams);
|
|
||||||
else
|
|
||||||
WriteToResponse(oTransportClass1, eError, null, oTransportClass1.m_aInputParams);
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
_log.Error("Exeption: ", e);
|
|
||||||
WriteToResponse(oTransportClass1, ErrorTypes.Upload, null, oTransportClass1.m_aInputParams);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endregion
|
|
||||||
#region TransportClass
|
|
||||||
private class TransportClass1 : TransportClassMainAshx
|
|
||||||
{
|
|
||||||
public AsyncMediaXmlOperation m_oAsyncMediaXmlOperation;
|
|
||||||
public NameValueCollection m_aInputParams;
|
|
||||||
public List<string> m_aUrls = new List<string>();
|
|
||||||
public string m_sKey;
|
|
||||||
public string m_sMediaXml;
|
|
||||||
public HttpFileCollection m_oFiles;
|
|
||||||
public IEnumerator m_oFilesEnumerator;
|
|
||||||
|
|
||||||
public TransportClass1(TransportClassMainAshx oTransportClassMainAshx, AsyncMediaXmlOperation oAsyncMediaXmlOperation, NameValueCollection aInputParams, List<string> aUrls, string sKey, string sMediaXml, HttpFileCollection oFiles, IEnumerator oFilesEnumerator)
|
|
||||||
: base(oTransportClassMainAshx.m_oHttpContext, oTransportClassMainAshx.m_oAsyncCallback)
|
|
||||||
{
|
|
||||||
m_oAsyncMediaXmlOperation = oAsyncMediaXmlOperation;
|
|
||||||
m_aInputParams = aInputParams;
|
|
||||||
m_sKey = sKey;
|
|
||||||
m_oFiles = oFiles;
|
|
||||||
m_oFilesEnumerator = oFilesEnumerator;
|
|
||||||
m_sMediaXml = sMediaXml;
|
|
||||||
m_aUrls = aUrls;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private class TransportClass2 : TransportClass1
|
|
||||||
{
|
|
||||||
public Dictionary<string, string> m_oMediaXmlMapHash = new Dictionary<string, string>();
|
|
||||||
public Dictionary<string, string> m_oMediaXmlMapFilename = new Dictionary<string, string>();
|
|
||||||
public AsyncContextReadOperation m_oAsyncContextReadOperation;
|
|
||||||
public TransportClass2(TransportClass1 oTransportClass1, Dictionary<string, string> oMediaXmlMapHash, Dictionary<string, string> oMediaXmlMapFilename, AsyncContextReadOperation oAsyncContextReadOperation)
|
|
||||||
: base(oTransportClass1, oTransportClass1.m_oAsyncMediaXmlOperation, oTransportClass1.m_aInputParams, oTransportClass1.m_aUrls, oTransportClass1.m_sKey, oTransportClass1.m_sMediaXml, oTransportClass1.m_oFiles, oTransportClass1.m_oFilesEnumerator)
|
|
||||||
{
|
|
||||||
m_oMediaXmlMapHash = oMediaXmlMapHash;
|
|
||||||
m_oMediaXmlMapFilename = oMediaXmlMapFilename;
|
|
||||||
m_oAsyncContextReadOperation = oAsyncContextReadOperation;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
private class TransportClass3 : TransportClass2
|
|
||||||
{
|
|
||||||
public string m_sFilename;
|
|
||||||
public string m_sHash;
|
|
||||||
public string m_sPath;
|
|
||||||
public Storage m_oStorage;
|
|
||||||
public TransportClass3(TransportClass2 oTransportClass2, string sFilename, string sHash, string sPath, Storage oStorage)
|
|
||||||
: base(oTransportClass2, oTransportClass2.m_oMediaXmlMapHash, oTransportClass2.m_oMediaXmlMapFilename, oTransportClass2.m_oAsyncContextReadOperation)
|
|
||||||
{
|
|
||||||
m_sFilename = sFilename;
|
|
||||||
m_sHash = sHash;
|
|
||||||
m_sPath = sPath;
|
|
||||||
m_oStorage = oStorage;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
public class OutputCommand
|
|
||||||
{
|
|
||||||
public int type;
|
|
||||||
public List<string> urls = new List<string>();
|
|
||||||
public int error;
|
|
||||||
public Dictionary<string, object> input = new Dictionary<string,object>();
|
|
||||||
}
|
|
||||||
#endregion
|
|
||||||
}
|
|
362
DocService/UploadService.ashx.cs
Normal file
362
DocService/UploadService.ashx.cs
Normal file
|
@ -0,0 +1,362 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
using System;
|
||||||
|
using System.Net;
|
||||||
|
using System.Configuration;
|
||||||
|
using System.Web;
|
||||||
|
using System.IO;
|
||||||
|
using System.Text;
|
||||||
|
using System.Xml;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Web.Script.Serialization;
|
||||||
|
using System.Collections.Specialized;
|
||||||
|
|
||||||
|
using FileConverterUtils2;
|
||||||
|
|
||||||
|
using log4net;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
|
public class UploadService : IHttpAsyncHandler
|
||||||
|
{
|
||||||
|
private readonly ILog _log = LogManager.GetLogger(typeof(UploadService));
|
||||||
|
|
||||||
|
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, Object extraData)
|
||||||
|
{
|
||||||
|
|
||||||
|
TransportClassMainAshx oTransportClassMainAshx = new TransportClassMainAshx(context, cb);
|
||||||
|
ErrorTypes eError = ErrorTypes.NoError;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_log.Info("Starting process request...");
|
||||||
|
_log.Info(context.Request.QueryString.ToString());
|
||||||
|
|
||||||
|
string sGuid = context.Request.QueryString["key"];
|
||||||
|
int nMaxBytes = Convert.ToInt32(ConfigurationSettings.AppSettings["limits.image.size"] ?? "25000000");
|
||||||
|
if (context.Request.ContentLength <= nMaxBytes)
|
||||||
|
{
|
||||||
|
if (context.Request.Files.Count > 0)
|
||||||
|
{
|
||||||
|
|
||||||
|
int nParamsCount = 0;
|
||||||
|
string sInputParams = "";
|
||||||
|
for (int i = 0, length = context.Request.QueryString.Count; i < length; ++i)
|
||||||
|
{
|
||||||
|
sInputParams += context.Request.QueryString.Get(i) + ":" + context.Request.QueryString.GetKey(i);
|
||||||
|
if (nParamsCount > 0)
|
||||||
|
sInputParams += ",";
|
||||||
|
nParamsCount++;
|
||||||
|
}
|
||||||
|
AsyncMediaXmlOperation oAsyncMediaXmlOperation = new AsyncMediaXmlOperation();
|
||||||
|
List<string> aUrls = new List<string>();
|
||||||
|
TransportClass1 oTransportClass1 = new TransportClass1(oTransportClassMainAshx, oAsyncMediaXmlOperation, context.Request.QueryString, aUrls, sGuid, Path.Combine(sGuid, @"media/media.xml"), context.Request.Files, context.Request.Files.GetEnumerator());
|
||||||
|
oAsyncMediaXmlOperation.GetMediaXmlBegin(oTransportClass1.m_sMediaXml, GetMediaXmlCallback, oTransportClass1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
eError = ErrorTypes.UploadCountFiles;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
eError = ErrorTypes.UploadContentLength;
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
eError = ErrorTypes.Upload;
|
||||||
|
|
||||||
|
_log.Error(context.Request.QueryString.ToString());
|
||||||
|
_log.Error("Exeption: ", e);
|
||||||
|
}
|
||||||
|
if (ErrorTypes.NoError != eError)
|
||||||
|
WriteToResponse(oTransportClassMainAshx, eError, null, context.Request.QueryString);
|
||||||
|
return new AsyncOperationData(extraData);
|
||||||
|
}
|
||||||
|
public void EndProcessRequest(IAsyncResult result)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
public void ProcessRequest(HttpContext context)
|
||||||
|
{
|
||||||
|
throw new InvalidOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsReusable
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#region HelpFunctions
|
||||||
|
private void WriteToResponse(TransportClassMainAshx oTransportClassMainAshx, ErrorTypes eError, List<string> aUrls, NameValueCollection aNameValueCollection)
|
||||||
|
{
|
||||||
|
HttpContext oHttpContext = oTransportClassMainAshx.m_oHttpContext;
|
||||||
|
AsyncCallback oAsyncCallback = oTransportClassMainAshx.m_oAsyncCallback;
|
||||||
|
OutputCommand oOutputCommand = new OutputCommand();
|
||||||
|
if (null != aNameValueCollection)
|
||||||
|
{
|
||||||
|
|
||||||
|
for (int i = 0, length = aNameValueCollection.Count; i < length; ++i)
|
||||||
|
oOutputCommand.input.Add(aNameValueCollection.GetKey(i), aNameValueCollection.Get(i));
|
||||||
|
}
|
||||||
|
oOutputCommand.urls = aUrls;
|
||||||
|
oOutputCommand.error = (int)eError;
|
||||||
|
oOutputCommand.type = (int)PostMessageType.UploadImage;
|
||||||
|
|
||||||
|
JavaScriptSerializer serializer = new JavaScriptSerializer();
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
serializer.Serialize(oOutputCommand, sb);
|
||||||
|
string sJson = sb.ToString();
|
||||||
|
|
||||||
|
oHttpContext.Response.Write("<html><head><script type=\"text/javascript\">function load(){ parent.postMessage(\"" + sJson.Replace("\"", "\\\"") + "\", '*'); }</script></head><body onload='load()'></body></html>");
|
||||||
|
|
||||||
|
oAsyncCallback.Invoke(new AsyncOperationData(null));
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
#region Callbacks
|
||||||
|
private void GetMediaXmlCallbackProcess(TransportClass1 oTransportClass1, Dictionary<string, string> aMediaXmlMapHash, Dictionary<string, string> aMediaXmlMapFilename)
|
||||||
|
{
|
||||||
|
AsyncContextReadOperation oAsyncContextReadOperation = new AsyncContextReadOperation();
|
||||||
|
TransportClass2 oTransportClass2 = new TransportClass2(oTransportClass1, aMediaXmlMapHash, aMediaXmlMapFilename, oAsyncContextReadOperation);
|
||||||
|
HttpPostedFile oCurrentFile = (HttpPostedFile)oTransportClass1.m_oFiles[(string)oTransportClass1.m_oFilesEnumerator.Current];
|
||||||
|
oCurrentFile.InputStream.Position = 0;
|
||||||
|
oAsyncContextReadOperation.ReadContextBegin(oCurrentFile.InputStream, ReadContextCallback, oTransportClass2);
|
||||||
|
}
|
||||||
|
private void GetMediaXmlCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
Dictionary<string, string> aMediaXmlMapHash;
|
||||||
|
Dictionary<string, string> aMediaXmlMapFilename;
|
||||||
|
ErrorTypes eError = oTransportClass1.m_oAsyncMediaXmlOperation.GetMediaXmlEnd(ar, out aMediaXmlMapHash, out aMediaXmlMapFilename);
|
||||||
|
if (ErrorTypes.NoError == eError && oTransportClass1.m_oFilesEnumerator.MoveNext())
|
||||||
|
{
|
||||||
|
GetMediaXmlCallbackProcess(oTransportClass1, aMediaXmlMapHash, aMediaXmlMapFilename);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
WriteToResponse(oTransportClass1, eError, null, oTransportClass1.m_aInputParams);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exeption: ", e);
|
||||||
|
WriteToResponse(oTransportClass1, ErrorTypes.Upload, null, oTransportClass1.m_aInputParams);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void ReadContextCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass2 oTransportClass2 = ar.AsyncState as TransportClass2;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
ErrorTypes eError = oTransportClass2.m_oAsyncContextReadOperation.ReadContextEnd(ar);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
HttpPostedFile oCurrentFile = ((HttpPostedFile)oTransportClass2.m_oFiles[(string)oTransportClass2.m_oFilesEnumerator.Current]);
|
||||||
|
oCurrentFile.InputStream.Position = 0;
|
||||||
|
Stream oImageStream = oCurrentFile.InputStream;
|
||||||
|
byte[] aBuffer = oTransportClass2.m_oAsyncContextReadOperation.m_aOutput.ToArray();
|
||||||
|
int nImageFormat = FormatChecker.GetFileFormat(aBuffer);
|
||||||
|
string sSupportedFormats = ConfigurationSettings.AppSettings["limits.image.types.upload"] ?? "jpg";
|
||||||
|
if (0 != (FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE & nImageFormat) && -1 != sSupportedFormats.IndexOf(FileFormats.ToString(nImageFormat)))
|
||||||
|
{
|
||||||
|
if (FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE_GIF == nImageFormat || FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE_ICO == nImageFormat)
|
||||||
|
{
|
||||||
|
byte[] aNewBuffer;
|
||||||
|
if (Utils.ConvertGifIcoToPng(aBuffer, nImageFormat, out aNewBuffer))
|
||||||
|
{
|
||||||
|
nImageFormat = FileFormats.AVS_OFFICESTUDIO_FILE_IMAGE_PNG;
|
||||||
|
aBuffer = aNewBuffer;
|
||||||
|
oImageStream = new MemoryStream(aBuffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
string sImageHash = null;
|
||||||
|
using (MemoryStream ms = new MemoryStream(aBuffer))
|
||||||
|
sImageHash = Utils.getMD5HexString(ms);
|
||||||
|
|
||||||
|
string sFileName;
|
||||||
|
if (oTransportClass2.m_oMediaXmlMapHash.TryGetValue(sImageHash, out sFileName))
|
||||||
|
{
|
||||||
|
|
||||||
|
ImageUrlProcess(oTransportClass2, Constants.mc_sResourceServiceUrlRel + Path.Combine(oTransportClass2.m_sKey, @"media\" + sFileName).Replace('\\', '/'));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
|
string sSearchName = "image";
|
||||||
|
List<int> aIndexes = new List<int>();
|
||||||
|
foreach (KeyValuePair<string, string> kvp in oTransportClass2.m_oMediaXmlMapFilename)
|
||||||
|
{
|
||||||
|
string sFilename = Path.GetFileNameWithoutExtension(kvp.Key);
|
||||||
|
if (0 == sFilename.IndexOf(sSearchName))
|
||||||
|
{
|
||||||
|
int nCurIndex;
|
||||||
|
if (int.TryParse(sFilename.Substring(sSearchName.Length), out nCurIndex))
|
||||||
|
aIndexes.Add(nCurIndex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
int nMaxIndex = -1;
|
||||||
|
for (int i = 0, length = aIndexes.Count; i < length; ++i)
|
||||||
|
{
|
||||||
|
int nCurIndex = aIndexes[i];
|
||||||
|
if (nMaxIndex < nCurIndex)
|
||||||
|
nMaxIndex = nCurIndex;
|
||||||
|
}
|
||||||
|
int nNewIndex = 1;
|
||||||
|
if (nMaxIndex >= nNewIndex)
|
||||||
|
nNewIndex = nMaxIndex + 1;
|
||||||
|
string sNewName = sSearchName + nNewIndex + "." + FileFormats.ToString(nImageFormat);
|
||||||
|
|
||||||
|
string sNewPath = Path.Combine(oTransportClass2.m_sKey, @"media\" + sNewName).Replace('\\', '/');
|
||||||
|
Storage oStorage = new Storage();
|
||||||
|
TransportClass3 oTransportClass3 = new TransportClass3(oTransportClass2, sNewName, sImageHash, sNewPath, oStorage);
|
||||||
|
oTransportClass3.m_oStorage.WriteFileBegin(sNewPath, oImageStream, WriteUploadedFileCallback, oTransportClass3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
WriteToResponse(oTransportClass2, ErrorTypes.UploadExtension, null, oTransportClass2.m_aInputParams);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
WriteToResponse(oTransportClass2, eError, null, oTransportClass2.m_aInputParams);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exeption: ", e);
|
||||||
|
WriteToResponse(oTransportClass2, ErrorTypes.Upload, null, oTransportClass2.m_aInputParams);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void ImageUrlProcess(TransportClass2 oTransportClass2, string sUrl)
|
||||||
|
{
|
||||||
|
oTransportClass2.m_aUrls.Add(sUrl);
|
||||||
|
if (oTransportClass2.m_oFilesEnumerator.MoveNext())
|
||||||
|
GetMediaXmlCallbackProcess(oTransportClass2, oTransportClass2.m_oMediaXmlMapHash, oTransportClass2.m_oMediaXmlMapFilename);
|
||||||
|
else
|
||||||
|
oTransportClass2.m_oAsyncMediaXmlOperation.WriteMediaXmlBegin(oTransportClass2.m_sMediaXml, oTransportClass2.m_oMediaXmlMapHash, WriteMediaXmlCallback, oTransportClass2);
|
||||||
|
}
|
||||||
|
private void WriteUploadedFileCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass3 oTransportClass3 = ar.AsyncState as TransportClass3;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
int nReadWriteBytes;
|
||||||
|
ErrorTypes eError = oTransportClass3.m_oStorage.WriteFileEnd(ar, out nReadWriteBytes);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
{
|
||||||
|
oTransportClass3.m_oMediaXmlMapHash.Add(oTransportClass3.m_sHash, oTransportClass3.m_sFilename);
|
||||||
|
oTransportClass3.m_oMediaXmlMapFilename.Add(oTransportClass3.m_sFilename, oTransportClass3.m_sHash);
|
||||||
|
ImageUrlProcess(oTransportClass3, Constants.mc_sResourceServiceUrlRel + oTransportClass3.m_sPath.Replace('\\', '/'));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
WriteToResponse(oTransportClass3, eError, null, oTransportClass3.m_aInputParams);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exeption: ", e);
|
||||||
|
WriteToResponse(oTransportClass3, ErrorTypes.Upload, null, oTransportClass3.m_aInputParams);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private void WriteMediaXmlCallback(IAsyncResult ar)
|
||||||
|
{
|
||||||
|
TransportClass1 oTransportClass1 = ar.AsyncState as TransportClass1;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
ErrorTypes eError = oTransportClass1.m_oAsyncMediaXmlOperation.WriteMediaXmlEnd(ar);
|
||||||
|
if (ErrorTypes.NoError == eError)
|
||||||
|
WriteToResponse(oTransportClass1, ErrorTypes.NoError, oTransportClass1.m_aUrls, oTransportClass1.m_aInputParams);
|
||||||
|
else
|
||||||
|
WriteToResponse(oTransportClass1, eError, null, oTransportClass1.m_aInputParams);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
_log.Error("Exeption: ", e);
|
||||||
|
WriteToResponse(oTransportClass1, ErrorTypes.Upload, null, oTransportClass1.m_aInputParams);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
#region TransportClass
|
||||||
|
private class TransportClass1 : TransportClassMainAshx
|
||||||
|
{
|
||||||
|
public AsyncMediaXmlOperation m_oAsyncMediaXmlOperation;
|
||||||
|
public NameValueCollection m_aInputParams;
|
||||||
|
public List<string> m_aUrls = new List<string>();
|
||||||
|
public string m_sKey;
|
||||||
|
public string m_sMediaXml;
|
||||||
|
public HttpFileCollection m_oFiles;
|
||||||
|
public IEnumerator m_oFilesEnumerator;
|
||||||
|
|
||||||
|
public TransportClass1(TransportClassMainAshx oTransportClassMainAshx, AsyncMediaXmlOperation oAsyncMediaXmlOperation, NameValueCollection aInputParams, List<string> aUrls, string sKey, string sMediaXml, HttpFileCollection oFiles, IEnumerator oFilesEnumerator)
|
||||||
|
: base(oTransportClassMainAshx.m_oHttpContext, oTransportClassMainAshx.m_oAsyncCallback)
|
||||||
|
{
|
||||||
|
m_oAsyncMediaXmlOperation = oAsyncMediaXmlOperation;
|
||||||
|
m_aInputParams = aInputParams;
|
||||||
|
m_sKey = sKey;
|
||||||
|
m_oFiles = oFiles;
|
||||||
|
m_oFilesEnumerator = oFilesEnumerator;
|
||||||
|
m_sMediaXml = sMediaXml;
|
||||||
|
m_aUrls = aUrls;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private class TransportClass2 : TransportClass1
|
||||||
|
{
|
||||||
|
public Dictionary<string, string> m_oMediaXmlMapHash = new Dictionary<string, string>();
|
||||||
|
public Dictionary<string, string> m_oMediaXmlMapFilename = new Dictionary<string, string>();
|
||||||
|
public AsyncContextReadOperation m_oAsyncContextReadOperation;
|
||||||
|
public TransportClass2(TransportClass1 oTransportClass1, Dictionary<string, string> oMediaXmlMapHash, Dictionary<string, string> oMediaXmlMapFilename, AsyncContextReadOperation oAsyncContextReadOperation)
|
||||||
|
: base(oTransportClass1, oTransportClass1.m_oAsyncMediaXmlOperation, oTransportClass1.m_aInputParams, oTransportClass1.m_aUrls, oTransportClass1.m_sKey, oTransportClass1.m_sMediaXml, oTransportClass1.m_oFiles, oTransportClass1.m_oFilesEnumerator)
|
||||||
|
{
|
||||||
|
m_oMediaXmlMapHash = oMediaXmlMapHash;
|
||||||
|
m_oMediaXmlMapFilename = oMediaXmlMapFilename;
|
||||||
|
m_oAsyncContextReadOperation = oAsyncContextReadOperation;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private class TransportClass3 : TransportClass2
|
||||||
|
{
|
||||||
|
public string m_sFilename;
|
||||||
|
public string m_sHash;
|
||||||
|
public string m_sPath;
|
||||||
|
public Storage m_oStorage;
|
||||||
|
public TransportClass3(TransportClass2 oTransportClass2, string sFilename, string sHash, string sPath, Storage oStorage)
|
||||||
|
: base(oTransportClass2, oTransportClass2.m_oMediaXmlMapHash, oTransportClass2.m_oMediaXmlMapFilename, oTransportClass2.m_oAsyncContextReadOperation)
|
||||||
|
{
|
||||||
|
m_sFilename = sFilename;
|
||||||
|
m_sHash = sHash;
|
||||||
|
m_sPath = sPath;
|
||||||
|
m_oStorage = oStorage;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public class OutputCommand
|
||||||
|
{
|
||||||
|
public int type;
|
||||||
|
public List<string> urls = new List<string>();
|
||||||
|
public int error;
|
||||||
|
public Dictionary<string, object> input = new Dictionary<string,object>();
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
<%@ WebHandler Language="C#" Class="fileDownloader" %>
|
<%@ WebHandler Language="C#" CodeBehind="fileDownloader.ashx.cs" Class="DocService.fileDownloader" %>
|
||||||
/*
|
/*
|
||||||
* (c) Copyright Ascensio System SIA 2010-2015
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
*
|
*
|
||||||
|
@ -32,75 +32,3 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Net;
|
|
||||||
using System.Configuration;
|
|
||||||
using System.Web;
|
|
||||||
using System.IO;
|
|
||||||
using System.Text;
|
|
||||||
|
|
||||||
public class fileDownloader : IHttpHandler {
|
|
||||||
|
|
||||||
public void ProcessRequest (HttpContext context) {
|
|
||||||
try
|
|
||||||
{
|
|
||||||
|
|
||||||
System.IO.FileInfo file = new System.IO.FileInfo(Convert.ToString(context.Server.MapPath(context.Server.UrlDecode("~" + context.Request.QueryString[0]))));
|
|
||||||
string sOutputFilename = null;
|
|
||||||
if (context.Request.QueryString.Count > 1)
|
|
||||||
sOutputFilename = context.Server.UrlDecode(context.Request.QueryString[1]);
|
|
||||||
if (string.IsNullOrEmpty(sOutputFilename))
|
|
||||||
sOutputFilename = file.Name;
|
|
||||||
if (!file.Exists)
|
|
||||||
return;
|
|
||||||
context.Response.Clear();
|
|
||||||
context.Response.ContentType = "application/octet-stream";
|
|
||||||
if (context.Request.ServerVariables.Get("HTTP_USER_AGENT").Contains("MSIE"))
|
|
||||||
context.Response.AppendHeader("Content-Disposition", "attachment; filename=\"" + context.Server.UrlEncode(sOutputFilename) + "\"");
|
|
||||||
else
|
|
||||||
context.Response.AppendHeader("Content-Disposition", "attachment; filename=\"" + sOutputFilename + "\"");
|
|
||||||
context.Response.AppendHeader("Content-Length", file.Length.ToString());
|
|
||||||
context.Response.TransmitFile(file.FullName);
|
|
||||||
context.Response.Flush();
|
|
||||||
context.ApplicationInstance.CompleteRequest();
|
|
||||||
}
|
|
||||||
catch(Exception){}
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool IsReusable {
|
|
||||||
get {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static string GetIP4Address()
|
|
||||||
{
|
|
||||||
string IP4Address = String.Empty;
|
|
||||||
|
|
||||||
foreach (IPAddress IPA in Dns.GetHostAddresses(HttpContext.Current.Request.UserHostAddress))
|
|
||||||
{
|
|
||||||
if (IPA.AddressFamily.ToString() == "InterNetwork")
|
|
||||||
{
|
|
||||||
IP4Address = IPA.ToString();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (IP4Address != String.Empty)
|
|
||||||
{
|
|
||||||
return IP4Address;
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach (IPAddress IPA in Dns.GetHostAddresses(Dns.GetHostName()))
|
|
||||||
{
|
|
||||||
if (IPA.AddressFamily.ToString() == "InterNetwork")
|
|
||||||
{
|
|
||||||
IP4Address = IPA.ToString();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return IP4Address;
|
|
||||||
}
|
|
||||||
}
|
|
105
DocService/fileDownloader.ashx.cs
Normal file
105
DocService/fileDownloader.ashx.cs
Normal file
|
@ -0,0 +1,105 @@
|
||||||
|
/*
|
||||||
|
* (c) Copyright Ascensio System SIA 2010-2015
|
||||||
|
*
|
||||||
|
* This program is a free software product. You can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
||||||
|
* version 3 as published by the Free Software Foundation. In accordance with
|
||||||
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
||||||
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
||||||
|
* of any third-party rights.
|
||||||
|
*
|
||||||
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
||||||
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
||||||
|
*
|
||||||
|
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
|
||||||
|
* EU, LV-1021.
|
||||||
|
*
|
||||||
|
* The interactive user interfaces in modified source and object code versions
|
||||||
|
* of the Program must display Appropriate Legal Notices, as required under
|
||||||
|
* Section 5 of the GNU AGPL version 3.
|
||||||
|
*
|
||||||
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
||||||
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
||||||
|
* grant you any rights under trademark law for use of our trademarks.
|
||||||
|
*
|
||||||
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
||||||
|
* well as technical writing content are licensed under the terms of the
|
||||||
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
||||||
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
using System;
|
||||||
|
using System.Net;
|
||||||
|
using System.Configuration;
|
||||||
|
using System.Web;
|
||||||
|
using System.IO;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace DocService
|
||||||
|
{
|
||||||
|
public class fileDownloader : IHttpHandler {
|
||||||
|
|
||||||
|
public void ProcessRequest (HttpContext context) {
|
||||||
|
try
|
||||||
|
{
|
||||||
|
|
||||||
|
System.IO.FileInfo file = new System.IO.FileInfo(Convert.ToString(context.Server.MapPath(context.Server.UrlDecode("~" + context.Request.QueryString[0]))));
|
||||||
|
string sOutputFilename = null;
|
||||||
|
if (context.Request.QueryString.Count > 1)
|
||||||
|
sOutputFilename = context.Server.UrlDecode(context.Request.QueryString[1]);
|
||||||
|
if (string.IsNullOrEmpty(sOutputFilename))
|
||||||
|
sOutputFilename = file.Name;
|
||||||
|
if (!file.Exists)
|
||||||
|
return;
|
||||||
|
context.Response.Clear();
|
||||||
|
context.Response.ContentType = "application/octet-stream";
|
||||||
|
if (context.Request.ServerVariables.Get("HTTP_USER_AGENT").Contains("MSIE"))
|
||||||
|
context.Response.AppendHeader("Content-Disposition", "attachment; filename=\"" + context.Server.UrlEncode(sOutputFilename) + "\"");
|
||||||
|
else
|
||||||
|
context.Response.AppendHeader("Content-Disposition", "attachment; filename=\"" + sOutputFilename + "\"");
|
||||||
|
context.Response.AppendHeader("Content-Length", file.Length.ToString());
|
||||||
|
context.Response.TransmitFile(file.FullName);
|
||||||
|
context.Response.Flush();
|
||||||
|
context.ApplicationInstance.CompleteRequest();
|
||||||
|
}
|
||||||
|
catch(Exception){}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsReusable {
|
||||||
|
get {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string GetIP4Address()
|
||||||
|
{
|
||||||
|
string IP4Address = String.Empty;
|
||||||
|
|
||||||
|
foreach (IPAddress IPA in Dns.GetHostAddresses(HttpContext.Current.Request.UserHostAddress))
|
||||||
|
{
|
||||||
|
if (IPA.AddressFamily.ToString() == "InterNetwork")
|
||||||
|
{
|
||||||
|
IP4Address = IPA.ToString();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (IP4Address != String.Empty)
|
||||||
|
{
|
||||||
|
return IP4Address;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach (IPAddress IPA in Dns.GetHostAddresses(Dns.GetHostName()))
|
||||||
|
{
|
||||||
|
if (IPA.AddressFamily.ToString() == "InterNetwork")
|
||||||
|
{
|
||||||
|
IP4Address = IPA.ToString();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return IP4Address;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -135,11 +135,11 @@
|
||||||
</system.web>
|
</system.web>
|
||||||
<system.codedom>
|
<system.codedom>
|
||||||
<compilers>
|
<compilers>
|
||||||
<compiler language="c#;cs;csharp" extension=".cs" type="Microsoft.CSharp.CSharpCodeProvider, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" warningLevel="4" compilerOptions="/d:OPEN_SOURCE">
|
<compiler language="c#;cs;csharp" extension=".cs" type="Microsoft.CSharp.CSharpCodeProvider, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" warningLevel="4">
|
||||||
<providerOption name="CompilerVersion" value="v4.0" />
|
<providerOption name="CompilerVersion" value="v4.0" />
|
||||||
<providerOption name="WarnAsError" value="false" />
|
<providerOption name="WarnAsError" value="false" />
|
||||||
</compiler>
|
</compiler>
|
||||||
<compiler language="vb;vbs;visualbasic;vbscript" extension=".vb" type="Microsoft.VisualBasic.VBCodeProvider, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" warningLevel="4" compilerOptions="/d:OPEN_SOURCE">
|
<compiler language="vb;vbs;visualbasic;vbscript" extension=".vb" type="Microsoft.VisualBasic.VBCodeProvider, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" warningLevel="4">
|
||||||
<providerOption name="CompilerVersion" value="v4.0" />
|
<providerOption name="CompilerVersion" value="v4.0" />
|
||||||
<providerOption name="OptionInfer" value="true" />
|
<providerOption name="OptionInfer" value="true" />
|
||||||
<providerOption name="WarnAsError" value="false" />
|
<providerOption name="WarnAsError" value="false" />
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
This is a Portuguese (Portugal) dictionary for Hunspell:
|
||||||
|
|
||||||
|
Copyright (C) 2006-2009 Josй Joгo de Almeida <jj@di.uminho.pt> ,
|
||||||
|
Rui Vilela <ruivilela@di.uminho.pt> ,
|
||||||
|
Alberto Simхes <ambs@di.uminho.pt>
|
||||||
|
|
||||||
|
Dep. Informбtica, Universidade do Minho
|
||||||
|
Portugal
|
||||||
|
|
||||||
|
All dictionary files and associated programs are currently covered by
|
||||||
|
the (GPL/LGPL/MPL), by this order. See also COPYING file for more
|
||||||
|
details, if available.
|
||||||
|
|
||||||
|
Regarding license versions:
|
||||||
|
1. GPL Version 2
|
||||||
|
2. LGPL Version 2.1
|
||||||
|
3. MPL Version 1.1
|
||||||
|
|
||||||
|
To install : Find a suitable application that uses myspell
|
||||||
|
dictionaries like openoffice, or hunspell terminal aplication. Use
|
||||||
|
the program dictionary application (if it has) for installing the
|
||||||
|
dictionaries. For openoffice, you should make sure that the
|
||||||
|
dictionary.lst file has the following line: DICT pt PT pt_PT
|
||||||
|
|
||||||
|
Automatic instalation: You can automatically download our dictionary
|
||||||
|
using the available plugins, either from mozilla, or OpenOffice. See
|
||||||
|
our site for details.
|
||||||
|
|
||||||
|
Latest versions, suggestions, automatic install, informations at
|
||||||
|
http://natura.di.uminho.pt/
|
||||||
|
|
||||||
|
#This readme will change on next release
|
|
@ -1,4 +1,4 @@
|
||||||
SET UTF-8
|
SET UTF-8
|
||||||
LANG pt_PT
|
LANG pt_PT
|
||||||
TRY aerisontcdmlupvgbfzáhçqjíxãóéêâúõACMPSBTELGRIFVDkHJONôywUKXZWQÁYÍÉàÓèÂÚ
|
TRY aerisontcdmlupvgbfzáhçqjíxãóéêâúõACMPSBTELGRIFVDkHJONôywUKXZWQÁYÍÉàÓèÂÚ
|
||||||
KEY qwertyuiop|asdfghjkl|zxcvbnm
|
KEY qwertyuiop|asdfghjkl|zxcvbnm
|
||||||
|
@ -120,7 +120,7 @@ SFX m 0 mente [^v][^q][^uo] +FSEM=mente,CAT=adv,SUBC
|
||||||
SFX m ável avelmente ável +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX m ável avelmente ável +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
SFX m ível ivelmente ível +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX m ível ivelmente ível +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
|
|
||||||
SFX H Y 38
|
SFX H Y 40
|
||||||
SFX H úrgico urgicamente úrgico +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX H úrgico urgicamente úrgico +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
SFX H 0 amente dor +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX H 0 amente dor +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
SFX H ório oriamente ório +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX H ório oriamente ório +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
|
@ -159,6 +159,8 @@ SFX H émico emicamente émico +FSEM=mente,CAT=adv,SU
|
||||||
SFX H ónio oniamente ónio +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX H ónio oniamente ónio +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
SFX H ásico asicamente ásico +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX H ásico asicamente ásico +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
SFX H ágico agicamente ágico +FSEM=mente,CAT=adv,SUBCAT=modo
|
SFX H ágico agicamente ágico +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
|
SFX H ântico anticamente ântico +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
|
SFX H ócil ocilmente ócil +FSEM=mente,CAT=adv,SUBCAT=modo
|
||||||
|
|
||||||
SFX q Y 32
|
SFX q Y 32
|
||||||
SFX q ologia ólogo ologia +CAT=a_nc,G=m,N=s
|
SFX q ologia ólogo ologia +CAT=a_nc,G=m,N=s
|
||||||
|
@ -243,24 +245,28 @@ SFX r morfismo mórficos morfismo +CAT=adj,G=m,N=p
|
||||||
SFX r morfismo mórficas morfismo +CAT=adj,G=f,N=p
|
SFX r morfismo mórficas morfismo +CAT=adj,G=f,N=p
|
||||||
|
|
||||||
SFX N Y 8
|
SFX N Y 8
|
||||||
SFX N r díssimo [ia]r +CAT=adj;GR=sup,G=m,N=s
|
SFX N r díssimo [ia]r +CAT=adj,GR=sup,G=m,N=s
|
||||||
SFX N r díssima [ia]r +CAT=adj;GR=sup,G=f,N=s
|
SFX N r díssima [ia]r +CAT=adj,GR=sup,G=f,N=s
|
||||||
SFX N r díssimas [ia]r +CAT=adj;GR=sup,G=f,N=p
|
SFX N r díssimas [ia]r +CAT=adj,GR=sup,G=f,N=p
|
||||||
SFX N r díssimos [ia]r +CAT=adj;GR=sup,G=m,N=p
|
SFX N r díssimos [ia]r +CAT=adj,GR=sup,G=m,N=p
|
||||||
SFX N er idíssimo er +CAT=adj;GR=sup,G=m,N=s
|
SFX N er idíssimo er +CAT=adj,GR=sup,G=m,N=s
|
||||||
SFX N er idíssima er +CAT=adj;GR=sup,G=f,N=s
|
SFX N er idíssima er +CAT=adj,GR=sup,G=f,N=s
|
||||||
SFX N er idíssimas er +CAT=adj;GR=sup,G=f,N=p
|
SFX N er idíssimas er +CAT=adj,GR=sup,G=f,N=p
|
||||||
SFX N er idíssimos er +CAT=adj;GR=sup,G=m,N=p
|
SFX N er idíssimos er +CAT=adj,GR=sup,G=m,N=p
|
||||||
|
|
||||||
SFX W Y 8
|
SFX W Y 12
|
||||||
SFX W r dinho [ia]r +CAT=adj;GR=dim,G=m,N=s
|
SFX W r dinho [ia]r +CAT=adj,GR=dim,G=m,N=s
|
||||||
SFX W r dinha [ia]r +CAT=adj;GR=dim,G=f,N=s
|
SFX W r dinha [ia]r +CAT=adj,GR=dim,G=f,N=s
|
||||||
SFX W r dinhas [ia]r +CAT=adj;GR=dim,G=f,N=p
|
SFX W r dinhas [ia]r +CAT=adj,GR=dim,G=f,N=p
|
||||||
SFX W r dinhos [ia]r +CAT=adj;GR=dim,G=m,N=p
|
SFX W r dinhos [ia]r +CAT=adj,GR=dim,G=m,N=p
|
||||||
SFX W er idinho er +CAT=adj;GR=dim,G=m,N=s
|
SFX W er idinho er +CAT=adj,GR=dim,G=m,N=s
|
||||||
SFX W er idinha er +CAT=adj;GR=dim,G=f,N=s
|
SFX W er idinha er +CAT=adj,GR=dim,G=f,N=s
|
||||||
SFX W er idinhas er +CAT=adj;GR=dim,G=f,N=p
|
SFX W er idinhas er +CAT=adj,GR=dim,G=f,N=p
|
||||||
SFX W er idinhos er +CAT=adj;GR=dim,G=m,N=p
|
SFX W er idinhos er +CAT=adj,GR=dim,G=m,N=p
|
||||||
|
SFX W 0 zinho [^ã][eo] +GR=dim
|
||||||
|
SFX W 0 inho l +GR=dim
|
||||||
|
SFX W 0 zinhos [^ã][eo] +N=p,GR=dim
|
||||||
|
SFX W 0 inhos l +N=p,GR=dim
|
||||||
|
|
||||||
SFX s Y 36
|
SFX s Y 36
|
||||||
SFX s o íssimo [^cçg]o +GR=sup,G=m,N=s
|
SFX s o íssimo [^cçg]o +GR=sup,G=m,N=s
|
||||||
|
@ -384,39 +390,42 @@ SFX t a uistas ga +CAT=a_nc,N=p,FSEM=ista
|
||||||
SFX t e istas e +CAT=a_nc,N=p,FSEM=ista
|
SFX t e istas e +CAT=a_nc,N=p,FSEM=ista
|
||||||
SFX t 0 istas [lr] +CAT=a_nc,N=p,FSEM=ista
|
SFX t 0 istas [lr] +CAT=a_nc,N=p,FSEM=ista
|
||||||
|
|
||||||
SFX h Y 47
|
SFX l Y 28
|
||||||
SFX h o inho [^cgçãi]o +GR=dim
|
SFX l o inho [^cgçãi]o +GR=dim
|
||||||
SFX h co quinho co +GR=dim
|
SFX l co quinho co +GR=dim
|
||||||
SFX h ço cinho ço +GR=dim
|
SFX l ço cinho ço +GR=dim
|
||||||
SFX h o uinho go +GR=dim
|
SFX l o uinho go +GR=dim
|
||||||
SFX h 0 zinho ão +GR=dim
|
SFX l 0 zinho ão +GR=dim
|
||||||
SFX h e inho e +G=m,GR=dim
|
SFX l e inho e +G=m,GR=dim
|
||||||
SFX h 0 inho [^ê][sz] +G=m,GR=dim
|
SFX l 0 inho [^ê][sz] +G=m,GR=dim
|
||||||
SFX h ês esinho ês +GR=dim
|
SFX l ês esinho ês +GR=dim
|
||||||
SFX h 0 zinho [irun] +G=m,GR=dim
|
SFX l 0 zinho [irunl] +G=m,GR=dim
|
||||||
SFX h ó ozinho ó +GR=dim
|
SFX l ó ozinho ó +GR=dim
|
||||||
SFX h ô ozinho ô +GR=dim
|
SFX l ô ozinho ô +GR=dim
|
||||||
SFX h é ezinho é +G=m,GR=dim
|
SFX l é ezinho é +G=m,GR=dim
|
||||||
SFX h ú uzinho ú +GR=dim
|
SFX l ú uzinho ú +GR=dim
|
||||||
SFX h m nzinho m +G=m,GR=dim
|
SFX l m nzinho m +G=m,GR=dim
|
||||||
SFX h 0 zinho l +G=m,GR=dim
|
SFX l o inhos [^cgçãi]o +N=p,GR=dim
|
||||||
SFX h o inhos [^cgçãi]o +N=p,GR=dim
|
SFX l co quinhos co +N=p,GR=dim
|
||||||
SFX h co quinhos co +N=p,GR=dim
|
SFX l ço cinhos ço +N=p,GR=dim
|
||||||
SFX h ço cinhos ço +N=p,GR=dim
|
SFX l o uinhos go +N=p,GR=dim
|
||||||
SFX h o uinhos go +N=p,GR=dim
|
SFX l 0 zinhos ão +N=p,GR=dim
|
||||||
SFX h 0 zinhos ão +N=p,GR=dim
|
SFX l e inhos e +G=m,N=p,GR=dim
|
||||||
SFX h e inhos e +G=m,N=p,GR=dim
|
SFX l 0 inhos [^ê][sz] +G=m,N=p,GR=dim
|
||||||
SFX h 0 inhos [^ê][sz] +G=m,N=p,GR=dim
|
SFX l ês esinhos ês +N=p,GR=dim
|
||||||
SFX h ês esinhos ês +N=p,GR=dim
|
SFX l 0 zinhos [irunl] +G=m,N=p,GR=dim
|
||||||
SFX h 0 zinhos [irun] +G=m,N=p,GR=dim
|
SFX l ó ozinhos ó +N=p,GR=dim
|
||||||
SFX h ó ozinhos ó +N=p,GR=dim
|
SFX l ô ozinhos ô +N=p,GR=dim
|
||||||
SFX h ô ozinhos ô +N=p,GR=dim
|
SFX l é ezinhos é +G=m,N=p,GR=dim
|
||||||
SFX h é ezinhos é +G=m,N=p,GR=dim
|
SFX l ú uzinhos ú +N=p,GR=dim
|
||||||
SFX h ú uzinhos ú +N=p,GR=dim
|
SFX l m nzinhos m +G=m,N=p,GR=dim
|
||||||
SFX h m nzinhos m +G=m,N=p,GR=dim
|
|
||||||
SFX h 0 zinhos l +G=m,N=p,GR=dim
|
SFX h Y 27
|
||||||
SFX h o inha [^cgçãi]o +G=f,GR=dim
|
SFX h o inha [^cgçãi]o +G=f,GR=dim
|
||||||
SFX h a inha [^çg]a +G=f,GR=dim
|
SFX h a inha [^çg]a +G=f,GR=dim
|
||||||
|
SFX h co quinha co +G=f,GR=dim
|
||||||
|
SFX h ço cinha ço +G=f,GR=dim
|
||||||
|
SFX h o uinha go +G=f,GR=dim
|
||||||
SFX h ca quinha ca +G=f,GR=dim
|
SFX h ca quinha ca +G=f,GR=dim
|
||||||
SFX h ça cinha ça +G=f,GR=dim
|
SFX h ça cinha ça +G=f,GR=dim
|
||||||
SFX h a uinha ga +G=f,GR=dim
|
SFX h a uinha ga +G=f,GR=dim
|
||||||
|
@ -424,22 +433,31 @@ SFX h á azinha á +G=f,GR=dim
|
||||||
SFX h ã azinha ã +G=f,GR=dim
|
SFX h ã azinha ã +G=f,GR=dim
|
||||||
SFX h 0 zinha ãe +G=f,GR=dim
|
SFX h 0 zinha ãe +G=f,GR=dim
|
||||||
SFX h e inha [^ã]e +G=f,GR=dim
|
SFX h e inha [^ã]e +G=f,GR=dim
|
||||||
|
SFX h 0 zinha [irunl] +G=f,GR=dim
|
||||||
|
SFX h m nzinha m +G=m,GR=dim
|
||||||
SFX h o inhas [^cgçãi]o +G=f,N=p,GR=dim
|
SFX h o inhas [^cgçãi]o +G=f,N=p,GR=dim
|
||||||
SFX h a inhas [^çg]a +G=f,N=p,GR=dim
|
SFX h a inhas [^çg]a +G=f,N=p,GR=dim
|
||||||
SFX h ca quinhas ca +G=f,N=p,GR=dim
|
SFX h ca quinhas ca +G=f,N=p,GR=dim
|
||||||
SFX h ça cinhas ça +G=f,N=p,GR=dim
|
SFX h ça cinhas ça +G=f,N=p,GR=dim
|
||||||
SFX h a uinhas ga +G=f,N=p,GR=dim
|
SFX h a uinhas ga +G=f,N=p,GR=dim
|
||||||
|
SFX h co quinhas co +G=f,N=p,GR=dim
|
||||||
|
SFX h ço cinhas ço +G=f,N=p,GR=dim
|
||||||
|
SFX h o uinhas go +G=f,N=p,GR=dim
|
||||||
SFX h á azinhas á +G=f,N=p,GR=dim
|
SFX h á azinhas á +G=f,N=p,GR=dim
|
||||||
SFX h ã azinhas ã +G=f,N=p,GR=dim
|
SFX h ã azinhas ã +G=f,N=p,GR=dim
|
||||||
SFX h e inhas [^ã]e +G=f,N=p,GR=dim
|
SFX h e inhas [^ã]e +G=f,N=p,GR=dim
|
||||||
|
SFX h 0 zinhas [irunl] +G=f,N=p,GR=dim
|
||||||
|
SFX h m nzinhas m +G=m,N=p,GR=dim
|
||||||
|
|
||||||
SFX z Y 6
|
SFX z Y 8
|
||||||
SFX z 0 zinho [^ã][eo] +GR=dim
|
SFX z 0 zinho [^ã][eo] +GR=dim
|
||||||
SFX z 0 inho l +GR=dim
|
SFX z 0 inho l +GR=dim
|
||||||
SFX z 0 zinha [^ã][eo] +G=f,GR=dim
|
SFX z 0 zinha [^ã][eo] +G=f,GR=dim
|
||||||
SFX z 0 inha l +G=f,GR=dim
|
SFX z 0 inha l +G=f,GR=dim
|
||||||
|
SFX z 0 zinho ão +GR=dim
|
||||||
SFX z 0 zinhos [^ã][eo] +N=p,GR=dim
|
SFX z 0 zinhos [^ã][eo] +N=p,GR=dim
|
||||||
SFX z 0 inhos l +N=p,GR=dim
|
SFX z 0 inhos l +N=p,GR=dim
|
||||||
|
SFX z o ezinhos ão +N=p,GR=dim
|
||||||
|
|
||||||
SFX c Y 8
|
SFX c Y 8
|
||||||
SFX c r ção [ae]r +CAT=nc,G=f,N=s,FSEM=cao
|
SFX c r ção [ae]r +CAT=nc,G=f,N=s,FSEM=cao
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,21 @@
|
||||||
|
% Ukrainian hyphenation patterns.
|
||||||
|
% Copyright 1998-2002 Maksym Polyakov.
|
||||||
|
% Released 2002/12/19.
|
||||||
|
% Please, send bug reports via e-mail:
|
||||||
|
% polyama@auburn.edu
|
||||||
|
%
|
||||||
|
% This is free software; you can redistribute it and/or modify
|
||||||
|
% it under the terms of the GNU General Public License as published by
|
||||||
|
% the Free Software Foundation; either version 2 of the License, or
|
||||||
|
% (at your option) any later version.
|
||||||
|
%
|
||||||
|
% This file is distributed in the hope that it will be useful,
|
||||||
|
% but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
% GNU General Public License for more details.
|
||||||
|
%
|
||||||
|
% You should have received a copy of the GNU General Public License
|
||||||
|
% along with this program; if not, write to the Free Software
|
||||||
|
% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
HYPH uk UA hyph_uk_UA
|
|
@ -0,0 +1,10 @@
|
||||||
|
This is Ukrainian thesaurus for OpenOffice.org version 1.6.0.
|
||||||
|
|
||||||
|
This thesaurus is based on:
|
||||||
|
П. М. Деркач, Короткий словник синонімів української мови, Радянська школа, Київ, 1960
|
||||||
|
С. Караванський, Пошук українського слова
|
||||||
|
|
||||||
|
Copyright (C) 2009
|
||||||
|
Andriy Rysin
|
||||||
|
|
||||||
|
This thesaurus is licensed under GPL, LGPL and MPL (Mozilla Public License) licenses.
|
|
@ -0,0 +1,27 @@
|
||||||
|
This is Ukrainian spelling dictionary for myspell & hunspell version 1.8.0
|
||||||
|
|
||||||
|
This dictionary based on spell-uk project http://ispell-uk.sourceforge.net/
|
||||||
|
|
||||||
|
|
||||||
|
Copyright (C) 1999
|
||||||
|
Vladimir Yakovchuk
|
||||||
|
Oleg Podgurniy
|
||||||
|
|
||||||
|
Copyright (C) 2001
|
||||||
|
Dmytro Kovalyov
|
||||||
|
Maksym Polyakov
|
||||||
|
Andriy Rysin
|
||||||
|
|
||||||
|
Copyright (C) 2002
|
||||||
|
Valentyn Solomko
|
||||||
|
Volodymyr M. Lisivka
|
||||||
|
|
||||||
|
Copyright (C) 2005
|
||||||
|
Andriy Rysin
|
||||||
|
Eugeniy Meshcheryakov
|
||||||
|
Dmytro Kovalyov
|
||||||
|
|
||||||
|
Copyright (C) 2006-2013
|
||||||
|
Andriy Rysin
|
||||||
|
|
||||||
|
This dictionary is licensed under GPL 2.0 or above, LGPL 2.1 or above and MPL (Mozilla Public License) 1.1 licenses.
|
1654
NodeJsProjects/SpellChecker/Dictionaries/uk_UA/hyph_uk_UA.dic
Normal file
1654
NodeJsProjects/SpellChecker/Dictionaries/uk_UA/hyph_uk_UA.dic
Normal file
File diff suppressed because it is too large
Load diff
24966
NodeJsProjects/SpellChecker/Dictionaries/uk_UA/th_uk_UA.dat
Normal file
24966
NodeJsProjects/SpellChecker/Dictionaries/uk_UA/th_uk_UA.dat
Normal file
File diff suppressed because it is too large
Load diff
12446
NodeJsProjects/SpellChecker/Dictionaries/uk_UA/th_uk_UA.idx
Normal file
12446
NodeJsProjects/SpellChecker/Dictionaries/uk_UA/th_uk_UA.idx
Normal file
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -1,160 +0,0 @@
|
||||||
// Module variables
|
|
||||||
var nativeNodeHun = require('./../src/build/Release/nodehun'),
|
|
||||||
os = require('os'),
|
|
||||||
fs = require('fs'),
|
|
||||||
path = require('path'),
|
|
||||||
dictionariesPath = (function(){
|
|
||||||
var dir = __dirname.split(path.sep);
|
|
||||||
dir.pop();
|
|
||||||
dir.push('dictionaries');
|
|
||||||
return dir.join(path.sep) + path.sep;
|
|
||||||
}()),
|
|
||||||
nativeKeys = Object.keys(nativeNodeHun),
|
|
||||||
i = nativeKeys.length,
|
|
||||||
privateRe = /^_/,
|
|
||||||
dictionaries = [],
|
|
||||||
key;
|
|
||||||
|
|
||||||
// Initializations that need to take place
|
|
||||||
nativeNodeHun._setDictionariesPath(dictionariesPath);
|
|
||||||
|
|
||||||
// Set all public methods to be exposed
|
|
||||||
while(i--){
|
|
||||||
key = nativeKeys[i];
|
|
||||||
if(!privateRe.test(key))
|
|
||||||
exports[key] = nativeNodeHun[key];
|
|
||||||
}
|
|
||||||
/*--exports--
|
|
||||||
name:addDictionaryPerm
|
|
||||||
description: adds a new dictionary to the dictionaries path.
|
|
||||||
The last two parameters are optional. The third parameter
|
|
||||||
specifies another dictionary on which to base this new
|
|
||||||
dictionary on. The fourth parameter, when false, which is
|
|
||||||
default, will copy the affixes and words into the new dictionary
|
|
||||||
folder; when true, only the affixes will be copied.
|
|
||||||
@param{string}
|
|
||||||
@param{function}
|
|
||||||
@param{string=}
|
|
||||||
@param{bool=}
|
|
||||||
*/
|
|
||||||
exports.addDictionaryPerm = function(dictionary,callback,base,notDict){
|
|
||||||
var dictPath = dictionariesPath + dictionary,
|
|
||||||
affPath = dictPath + path.sep + dictionary + '.aff',
|
|
||||||
dicPath = dictPath + path.sep + dictionary + '.dic',
|
|
||||||
oneDone = false,
|
|
||||||
error = false,
|
|
||||||
baseAff,baseDic;
|
|
||||||
// Make the dictionary directory
|
|
||||||
fs.mkdir(dictPath,function(err){
|
|
||||||
// If the directory already exists, error out.
|
|
||||||
if(err){
|
|
||||||
callback(err,false);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
//If a base dictionary was indicated let's read it
|
|
||||||
if(typeof base === "string"){
|
|
||||||
baseAff = dictionariesPath + base + path.sep + base + '.aff';
|
|
||||||
fs.readFile(baseAff,function(err,abuf){
|
|
||||||
if(err){
|
|
||||||
error = true;
|
|
||||||
callback(err,false);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
fs.open(affPath,'w',function(err,fd){
|
|
||||||
if(err && !error){
|
|
||||||
error = true
|
|
||||||
callback(err,false);
|
|
||||||
}
|
|
||||||
else if(!error){
|
|
||||||
fs.write(fd,abuf,0,abuf.length,null,function(err,written){
|
|
||||||
if(!error){
|
|
||||||
if(err){
|
|
||||||
callback(err,false);
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
if(oneDone) callback(null,true);
|
|
||||||
oneDone = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
fs.open(affPath,'w',function(err,fd){
|
|
||||||
if(err && !error){
|
|
||||||
callback(err,false);
|
|
||||||
}
|
|
||||||
else if(!error){
|
|
||||||
fs.write(fd,new Buffer('0\n'),0,2,null,function(err,written){
|
|
||||||
if(!error){
|
|
||||||
if(err){
|
|
||||||
callback(err,false);
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
if(oneDone) callback(null,true);
|
|
||||||
oneDone = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if(typeof base === "string" && !notDict){
|
|
||||||
baseDic = dictionariesPath + base + path.sep + base + '.dic';
|
|
||||||
fs.readFile(baseDic,function(err,abuf){
|
|
||||||
if(err && !error){
|
|
||||||
error = true;
|
|
||||||
callback(err);
|
|
||||||
}
|
|
||||||
else if(!error){
|
|
||||||
fs.open(dicPath,'w',function(err,fd){
|
|
||||||
if(err && !error){
|
|
||||||
callback(err,false);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
fs.write(fd,abuf,0,abuf.length,null,function(err,written){
|
|
||||||
if(!error){
|
|
||||||
if(err){
|
|
||||||
callback(err,false);
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
if(oneDone) callback(null,true);
|
|
||||||
oneDone = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
fs.open(dicPath,'w',function(err,fd){
|
|
||||||
if(err && !error){
|
|
||||||
callback(err,false);
|
|
||||||
}
|
|
||||||
else if(!error){
|
|
||||||
fs.write(fd,new Buffer('0\n'),0,2,null,function(err,written){
|
|
||||||
if(!error){
|
|
||||||
if(err){
|
|
||||||
callback(err,false);
|
|
||||||
error = true;
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
if(oneDone) callback(null,true);
|
|
||||||
oneDone = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
|
@ -1,19 +0,0 @@
|
||||||
Copyright (c) 2012 Nathan Sweet, DataSphere Inc.
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a
|
|
||||||
copy of this software and associated documentation files (the "Software"),
|
|
||||||
to deal in the Software without restriction, including without limitation
|
|
||||||
the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
||||||
and/or sell copies of the Software, and to permit persons to whom the
|
|
||||||
Software is furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
|
||||||
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
||||||
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
||||||
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
||||||
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
File diff suppressed because one or more lines are too long
|
@ -1,182 +0,0 @@
|
||||||
Nodehun
|
|
||||||
=======
|
|
||||||
|
|
||||||
Installation
|
|
||||||
------------
|
|
||||||
Nodehun has no "node_module" dependencies (yet), so it can either be installed via npm or simply checked out of git. You'll need [node-gyp](https://github.com/TooTallNate/node-gyp) to build. Nodehun should work on Windows or Unix. You'll also need to make sure that libuv source
|
|
||||||
code is on your system. Usually having node installed is enough, but there are weird cases.
|
|
||||||
|
|
||||||
npm install nodehun
|
|
||||||
cd src
|
|
||||||
node-gyp configure
|
|
||||||
node-gyp build
|
|
||||||
|
|
||||||
|
|
||||||
Introduction
|
|
||||||
------------
|
|
||||||
Yes there are already two nodejs spell checkers based of off hunspell, but one doesn't seem to even be supported anymore, and the other seems to only support simple spelling suggestions. Nodehun aims to expose as much of hunspell's functionality as possible in an easy to understand and maintain way, while also offering additional functionality not even present in hunspell.
|
|
||||||
|
|
||||||
Spell Suggest and Initialization, directory based
|
|
||||||
-------------------------------------------------
|
|
||||||
Initializing nodehun is very easy, it will automatically find the dictionary you are looking for as long as it is inside the dictionaries folder (nodehun ships with US english and Canadian English, but tons of languages are available for free at [open office](http://extensions.services.openoffice.org/dictionary), you should be able to just drop any of open office's dictionary folders into nodehun's dictionary folder and it should automatically work, see the readme file in the dictionaries folder for more directions). From initialization there are only a few built in objects that come with nodehun, most of the functionality you will use are methods in the built in object "Dictionary". Simple spell suggest is very easy.
|
|
||||||
|
|
||||||
var nodehun = require('nodehun'),
|
|
||||||
USDictionary = new nodehun.Dictionary('en_US');
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('color',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "color" is a defined word in the US English dictionary
|
|
||||||
// the output will be: true, null
|
|
||||||
});
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('calor',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "calor" is not a defined word in the US English dictionary
|
|
||||||
// the output will be: false, "carol"
|
|
||||||
});
|
|
||||||
|
|
||||||
Spell Suggest and Initialization, buffer based.
|
|
||||||
-------------------------------------------------
|
|
||||||
Another option for initializing a nodehun dictionary is to pass the raw string output of both the affix and dictionary files of a particular language. This allows you to use an alternate data-store than the servers file system. Please do not actually use `readFileSync`.
|
|
||||||
|
|
||||||
var nodehun = require('nodehun'),
|
|
||||||
fs = require('fs'),
|
|
||||||
USDictionary = new nodehun.Dictionary(fs.readFileSync('./en_US.aff').toString(),fs.readFileSync('./en_US.dic').toString());
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('color',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "color" is a defined word in the US English dictionary
|
|
||||||
// the output will be: true, null
|
|
||||||
});
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('calor',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "calor" is not a defined word in the US English dictionary
|
|
||||||
// the output will be: false, "carol"
|
|
||||||
});
|
|
||||||
|
|
||||||
Spell Suggestions
|
|
||||||
-----------------
|
|
||||||
Nodehun also offers a method that returns an array of words that could possibly match a misspelled word, ordered by most likely to be correct.
|
|
||||||
|
|
||||||
var nodehun = require('nodehun'),
|
|
||||||
USDictionary = new nodehun.Dictionary('en_US');
|
|
||||||
|
|
||||||
USDictionary.spellSuggestions('color',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "color" is a defined word in the US English dictionary
|
|
||||||
// the output will be: true, []
|
|
||||||
});
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('calor',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "calor" is not a defined word in the US English dictionary
|
|
||||||
// the output will be: false, [ 'carol','valor','color','cal or','cal-or','caloric','calorie']
|
|
||||||
});
|
|
||||||
|
|
||||||
Add Dictionary
|
|
||||||
--------------
|
|
||||||
Nodehun also can add another dictionary on top of an existing dictionary object at runtime (this means it is not permanent) in order to merge two dictionaries.
|
|
||||||
|
|
||||||
var nodehun = require('nodehun'),
|
|
||||||
USDictionary = new nodehun.Dictionary('en_US');
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('colour',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "colour" is not a defined word in the US English dictionary
|
|
||||||
// the output will be: false, "color"
|
|
||||||
});
|
|
||||||
|
|
||||||
USDictionary.addDictionary('en_CA',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because the Canadian English dictionary exists,
|
|
||||||
// the output will be: true, 'en_CA'
|
|
||||||
USDictionary.spellSuggest('colour',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "colour" is a defined word in the Canadian English dictionary
|
|
||||||
// the output will be: true, null
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
Add Dictionary, buffer based
|
|
||||||
----------------------------
|
|
||||||
Similar to the alternate means of initializing a nodehun dictionary you can also add a dictionary to an existing one with a raw string, even if the original dictionary wasn't initialized that way. NOTICE: the second argument is now the boolean value `true`, which indicates that the string being passed is a dictionary; if the value was `false` then it would treat the first argument as a path. The callback can be either the 2nd or 3rd argument, if it is the second argument the function will assume you've passed a "path" string. Once again, please do not actually use `readFileSync`.
|
|
||||||
|
|
||||||
var nodehun = require('nodehun'),
|
|
||||||
fs = require('fs'),
|
|
||||||
USDictionary = new nodehun.Dictionary('en_US');
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('colour',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "colour" is not a defined word in the US English dictionary
|
|
||||||
// the output will be: false, "color"
|
|
||||||
});
|
|
||||||
|
|
||||||
USDictionary.addDictionary(fs.readFileSync('./en_CA.dic').toString(),true,function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because the Canadian English dictionary exists,
|
|
||||||
// the output will be: true, 'en_CA'
|
|
||||||
USDictionary.spellSuggest('colour',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "colour" is a defined word in the Canadian English dictionary
|
|
||||||
// the output will be: true, null
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
Add Word
|
|
||||||
--------
|
|
||||||
Nodehun can also add a single word to a dictionary at runtime (this means it is not permanent) in order to have a custom runtime dictionary. If you know anything about Hunspell you can also add flags to the word.
|
|
||||||
|
|
||||||
var nodehun = require('nodehun'),
|
|
||||||
USDictionary = new nodehun.Dictionary('en_US');
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('colour',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "colour" is not a defined word in the US English dictionary
|
|
||||||
// the output will be: false, "color"
|
|
||||||
});
|
|
||||||
|
|
||||||
USDictionary.addWord('colour',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// if the method succeeded then
|
|
||||||
// the output will be: true, 'colour'
|
|
||||||
USDictionary.spellSuggest('colour',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "colour" has been added to the US dictionary object.
|
|
||||||
// the output will be: true, null
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
Remove Word
|
|
||||||
-----------
|
|
||||||
Nodehun can also remove a single word from a dictionary at runtime (this means it is not permanent) in order to have a custom runtime dictionary. If you know anything about Hunspell this method will ignore flags and just strip words that match.
|
|
||||||
|
|
||||||
var nodehun = require('nodehun'),
|
|
||||||
USDictionary = new nodehun.Dictionary('en_US');
|
|
||||||
|
|
||||||
USDictionary.spellSuggest('color',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "color" is a defined word in the US English dictionary
|
|
||||||
// the output will be: true, null
|
|
||||||
});
|
|
||||||
|
|
||||||
USDictionary.removeWord('color',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// if the method succeeded then
|
|
||||||
// the output will be: true, 'color'
|
|
||||||
USDictionary.spellSuggest('color',function(a,b){
|
|
||||||
console.log(a,b);
|
|
||||||
// because "color" has been removed from the US dictionary object.
|
|
||||||
// the output will be: false, "colors"
|
|
||||||
// note that plurals are considered separte words.
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
Add Dictionary Permanently and Add Word Permanently
|
|
||||||
---------------------------------------------------
|
|
||||||
I have deprecated and scrapped these methods as they really violate good design philosophy of a well written node module. These methods can both be easily replicated using node itself. I am trying to move nodehun away from needing files at all, as they are a poor data-store for a distributed system.
|
|
|
@ -1,14 +0,0 @@
|
||||||
{
|
|
||||||
'targets': [
|
|
||||||
{
|
|
||||||
'target_name': 'nodehun',
|
|
||||||
'sources': [
|
|
||||||
'nodehun.cpp'
|
|
||||||
],
|
|
||||||
'cflags': [ '-O3' ],
|
|
||||||
'dependencies': [
|
|
||||||
'hunspell/binding.gyp:hunspell',
|
|
||||||
],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,5 +0,0 @@
|
||||||
Author of Hunspell:
|
|
||||||
Németh László nemeth (at) OpenOffice.org
|
|
||||||
|
|
||||||
Hunspell based on OpenOffice.org's Myspell. MySpell's author:
|
|
||||||
Kevin Hendricks kevin.hendricks (at) sympatico.ca
|
|
|
@ -1,67 +0,0 @@
|
||||||
Developer Credits:
|
|
||||||
|
|
||||||
Special credit and thanks go to ispell's creator Geoff Kuenning.
|
|
||||||
Ispell affix compression code was used as the basis for the
|
|
||||||
affix code used in MySpell. Specifically Geoff's use of a
|
|
||||||
conds[] array that makes it easy to check if the conditions
|
|
||||||
required for a particular affix are present was very
|
|
||||||
ingenious! Kudos to Geoff. Very nicely done.
|
|
||||||
BTW: ispell is available under a BSD style license
|
|
||||||
from Geoff Kuennings ispell website:
|
|
||||||
http://www.cs.ucla.edu/ficus-members/geoff/ispell.html
|
|
||||||
|
|
||||||
|
|
||||||
Kevin Hendricks <kevin.hendricks@sympatico.ca> is the original
|
|
||||||
author and now maintainer of the MySpell codebase. Recent
|
|
||||||
additions include ngram support, and related character maps
|
|
||||||
to help improve and create suggestions for very poorly
|
|
||||||
spelled words.
|
|
||||||
|
|
||||||
Please send any and all contributions or improvements
|
|
||||||
to him or to dev@lingucomponent.openoffice.org.
|
|
||||||
|
|
||||||
|
|
||||||
David Einstein (Deinst@world.std.com) developed an almost
|
|
||||||
complete rewrite of MySpell for use by the Mozilla project.
|
|
||||||
David and I are now working on parallel development tracks
|
|
||||||
to help our respective projects (Mozilla and OpenOffice.org)
|
|
||||||
and we will maintain full affix file and dictionary file
|
|
||||||
compatibility and work on merging our versions of MySpell
|
|
||||||
back into a single tree. David has been a significant help
|
|
||||||
in improving MySpell.
|
|
||||||
|
|
||||||
|
|
||||||
Németh László <nemethl@gyorsposta.hu> is the author of
|
|
||||||
the Hungarian dictionary and he developed and contributed
|
|
||||||
extensive changes to MySpell including ...
|
|
||||||
* code to support compound words in MySpell
|
|
||||||
* fixed numerous problems with encoding case conversion tables.
|
|
||||||
* designed/developed replacement tables to improve suggestions
|
|
||||||
* changed affix file parsing to trees to greatly speed loading
|
|
||||||
* removed the need for malloc/free pairs in suffix_check which
|
|
||||||
speeds up spell checking in suffix rich languages by 20%
|
|
||||||
|
|
||||||
Davide Prina <davideprina@uahoo.com>, Giuseppe Modugno
|
|
||||||
<gppe.modugno@libero.it>, Gianluca Turconi <luctur@comeg.it>
|
|
||||||
all from the it_IT OpenOffice.org team performed an
|
|
||||||
extremely detailed code review of MySpell and generated
|
|
||||||
fixes for bugs, leaks, and speedup improvements.
|
|
||||||
|
|
||||||
Simon Brouwer <simon.oo.o@xs4all.nl> for fixes and enhancements
|
|
||||||
that have greatly improved MySpell auggestions
|
|
||||||
* n-gram suggestions for an initcap word have an init. cap.
|
|
||||||
* fix for too many n-gram suggestions from specialized dictionary,
|
|
||||||
* fix for long suggestions rather than close ones in case of
|
|
||||||
dictionaries with many compound words (kompuuter)
|
|
||||||
* optionally disabling split-word suggestions (controlled
|
|
||||||
by NOSPLITSUGS line in affix file)
|
|
||||||
|
|
||||||
|
|
||||||
Special Thanks to all others who have either contributed ideas or
|
|
||||||
testing for MySpell
|
|
||||||
|
|
||||||
|
|
||||||
Thanks,
|
|
||||||
|
|
||||||
Kevin Hendricks
|
|
||||||
kevin.hendricks@sympatico.ca
|
|
|
@ -1,5 +0,0 @@
|
||||||
* Interactive interface has some visualization problem with long lines
|
|
||||||
|
|
||||||
* Experimental -U, -u options don't support Unicode.
|
|
||||||
|
|
||||||
* Compound handling is not thread safe in Hungarian specific code.
|
|
|
@ -1,12 +0,0 @@
|
||||||
GPL 2.0/LGPL 2.1/MPL 1.1 tri-license
|
|
||||||
|
|
||||||
The contents of this software may be used under the terms of
|
|
||||||
the GNU General Public License Version 2 or later (the "GPL"), or
|
|
||||||
the GNU Lesser General Public License Version 2.1 or later (the "LGPL",
|
|
||||||
see COPYING.LGPL) or (excepting the LGPLed GNU gettext library in the
|
|
||||||
intl/ directory) the Mozilla Public License Version 1.1 or later
|
|
||||||
(the "MPL", see COPYING.MPL).
|
|
||||||
|
|
||||||
Software distributed under these licenses is distributed on an "AS IS" basis,
|
|
||||||
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the licences
|
|
||||||
for the specific language governing rights and limitations under the licenses.
|
|
|
@ -1,515 +0,0 @@
|
||||||
|
|
||||||
GNU LESSER GENERAL PUBLIC LICENSE
|
|
||||||
Version 2.1, February 1999
|
|
||||||
|
|
||||||
Copyright (C) 1991, 1999 Free Software Foundation, Inc.
|
|
||||||
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
Everyone is permitted to copy and distribute verbatim copies
|
|
||||||
of this license document, but changing it is not allowed.
|
|
||||||
|
|
||||||
[This is the first released version of the Lesser GPL. It also counts
|
|
||||||
as the successor of the GNU Library Public License, version 2, hence
|
|
||||||
the version number 2.1.]
|
|
||||||
|
|
||||||
Preamble
|
|
||||||
|
|
||||||
The licenses for most software are designed to take away your
|
|
||||||
freedom to share and change it. By contrast, the GNU General Public
|
|
||||||
Licenses are intended to guarantee your freedom to share and change
|
|
||||||
free software--to make sure the software is free for all its users.
|
|
||||||
|
|
||||||
This license, the Lesser General Public License, applies to some
|
|
||||||
specially designated software packages--typically libraries--of the
|
|
||||||
Free Software Foundation and other authors who decide to use it. You
|
|
||||||
can use it too, but we suggest you first think carefully about whether
|
|
||||||
this license or the ordinary General Public License is the better
|
|
||||||
strategy to use in any particular case, based on the explanations
|
|
||||||
below.
|
|
||||||
|
|
||||||
When we speak of free software, we are referring to freedom of use,
|
|
||||||
not price. Our General Public Licenses are designed to make sure that
|
|
||||||
you have the freedom to distribute copies of free software (and charge
|
|
||||||
for this service if you wish); that you receive source code or can get
|
|
||||||
it if you want it; that you can change the software and use pieces of
|
|
||||||
it in new free programs; and that you are informed that you can do
|
|
||||||
these things.
|
|
||||||
|
|
||||||
To protect your rights, we need to make restrictions that forbid
|
|
||||||
distributors to deny you these rights or to ask you to surrender these
|
|
||||||
rights. These restrictions translate to certain responsibilities for
|
|
||||||
you if you distribute copies of the library or if you modify it.
|
|
||||||
|
|
||||||
For example, if you distribute copies of the library, whether gratis
|
|
||||||
or for a fee, you must give the recipients all the rights that we gave
|
|
||||||
you. You must make sure that they, too, receive or can get the source
|
|
||||||
code. If you link other code with the library, you must provide
|
|
||||||
complete object files to the recipients, so that they can relink them
|
|
||||||
with the library after making changes to the library and recompiling
|
|
||||||
it. And you must show them these terms so they know their rights.
|
|
||||||
|
|
||||||
We protect your rights with a two-step method: (1) we copyright the
|
|
||||||
library, and (2) we offer you this license, which gives you legal
|
|
||||||
permission to copy, distribute and/or modify the library.
|
|
||||||
|
|
||||||
To protect each distributor, we want to make it very clear that
|
|
||||||
there is no warranty for the free library. Also, if the library is
|
|
||||||
modified by someone else and passed on, the recipients should know
|
|
||||||
that what they have is not the original version, so that the original
|
|
||||||
author's reputation will not be affected by problems that might be
|
|
||||||
introduced by others.
|
|
||||||
^L
|
|
||||||
Finally, software patents pose a constant threat to the existence of
|
|
||||||
any free program. We wish to make sure that a company cannot
|
|
||||||
effectively restrict the users of a free program by obtaining a
|
|
||||||
restrictive license from a patent holder. Therefore, we insist that
|
|
||||||
any patent license obtained for a version of the library must be
|
|
||||||
consistent with the full freedom of use specified in this license.
|
|
||||||
|
|
||||||
Most GNU software, including some libraries, is covered by the
|
|
||||||
ordinary GNU General Public License. This license, the GNU Lesser
|
|
||||||
General Public License, applies to certain designated libraries, and
|
|
||||||
is quite different from the ordinary General Public License. We use
|
|
||||||
this license for certain libraries in order to permit linking those
|
|
||||||
libraries into non-free programs.
|
|
||||||
|
|
||||||
When a program is linked with a library, whether statically or using
|
|
||||||
a shared library, the combination of the two is legally speaking a
|
|
||||||
combined work, a derivative of the original library. The ordinary
|
|
||||||
General Public License therefore permits such linking only if the
|
|
||||||
entire combination fits its criteria of freedom. The Lesser General
|
|
||||||
Public License permits more lax criteria for linking other code with
|
|
||||||
the library.
|
|
||||||
|
|
||||||
We call this license the "Lesser" General Public License because it
|
|
||||||
does Less to protect the user's freedom than the ordinary General
|
|
||||||
Public License. It also provides other free software developers Less
|
|
||||||
of an advantage over competing non-free programs. These disadvantages
|
|
||||||
are the reason we use the ordinary General Public License for many
|
|
||||||
libraries. However, the Lesser license provides advantages in certain
|
|
||||||
special circumstances.
|
|
||||||
|
|
||||||
For example, on rare occasions, there may be a special need to
|
|
||||||
encourage the widest possible use of a certain library, so that it
|
|
||||||
becomes
|
|
||||||
a de-facto standard. To achieve this, non-free programs must be
|
|
||||||
allowed to use the library. A more frequent case is that a free
|
|
||||||
library does the same job as widely used non-free libraries. In this
|
|
||||||
case, there is little to gain by limiting the free library to free
|
|
||||||
software only, so we use the Lesser General Public License.
|
|
||||||
|
|
||||||
In other cases, permission to use a particular library in non-free
|
|
||||||
programs enables a greater number of people to use a large body of
|
|
||||||
free software. For example, permission to use the GNU C Library in
|
|
||||||
non-free programs enables many more people to use the whole GNU
|
|
||||||
operating system, as well as its variant, the GNU/Linux operating
|
|
||||||
system.
|
|
||||||
|
|
||||||
Although the Lesser General Public License is Less protective of the
|
|
||||||
users' freedom, it does ensure that the user of a program that is
|
|
||||||
linked with the Library has the freedom and the wherewithal to run
|
|
||||||
that program using a modified version of the Library.
|
|
||||||
|
|
||||||
The precise terms and conditions for copying, distribution and
|
|
||||||
modification follow. Pay close attention to the difference between a
|
|
||||||
"work based on the library" and a "work that uses the library". The
|
|
||||||
former contains code derived from the library, whereas the latter must
|
|
||||||
be combined with the library in order to run.
|
|
||||||
^L
|
|
||||||
GNU LESSER GENERAL PUBLIC LICENSE
|
|
||||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
|
||||||
|
|
||||||
0. This License Agreement applies to any software library or other
|
|
||||||
program which contains a notice placed by the copyright holder or
|
|
||||||
other authorized party saying it may be distributed under the terms of
|
|
||||||
this Lesser General Public License (also called "this License").
|
|
||||||
Each licensee is addressed as "you".
|
|
||||||
|
|
||||||
A "library" means a collection of software functions and/or data
|
|
||||||
prepared so as to be conveniently linked with application programs
|
|
||||||
(which use some of those functions and data) to form executables.
|
|
||||||
|
|
||||||
The "Library", below, refers to any such software library or work
|
|
||||||
which has been distributed under these terms. A "work based on the
|
|
||||||
Library" means either the Library or any derivative work under
|
|
||||||
copyright law: that is to say, a work containing the Library or a
|
|
||||||
portion of it, either verbatim or with modifications and/or translated
|
|
||||||
straightforwardly into another language. (Hereinafter, translation is
|
|
||||||
included without limitation in the term "modification".)
|
|
||||||
|
|
||||||
"Source code" for a work means the preferred form of the work for
|
|
||||||
making modifications to it. For a library, complete source code means
|
|
||||||
all the source code for all modules it contains, plus any associated
|
|
||||||
interface definition files, plus the scripts used to control
|
|
||||||
compilation
|
|
||||||
and installation of the library.
|
|
||||||
|
|
||||||
Activities other than copying, distribution and modification are not
|
|
||||||
covered by this License; they are outside its scope. The act of
|
|
||||||
running a program using the Library is not restricted, and output from
|
|
||||||
such a program is covered only if its contents constitute a work based
|
|
||||||
on the Library (independent of the use of the Library in a tool for
|
|
||||||
writing it). Whether that is true depends on what the Library does
|
|
||||||
and what the program that uses the Library does.
|
|
||||||
|
|
||||||
1. You may copy and distribute verbatim copies of the Library's
|
|
||||||
complete source code as you receive it, in any medium, provided that
|
|
||||||
you conspicuously and appropriately publish on each copy an
|
|
||||||
appropriate copyright notice and disclaimer of warranty; keep intact
|
|
||||||
all the notices that refer to this License and to the absence of any
|
|
||||||
warranty; and distribute a copy of this License along with the
|
|
||||||
Library.
|
|
||||||
|
|
||||||
You may charge a fee for the physical act of transferring a copy,
|
|
||||||
and you may at your option offer warranty protection in exchange for a
|
|
||||||
fee.
|
|
||||||
|
|
||||||
2. You may modify your copy or copies of the Library or any portion
|
|
||||||
of it, thus forming a work based on the Library, and copy and
|
|
||||||
distribute such modifications or work under the terms of Section 1
|
|
||||||
above, provided that you also meet all of these conditions:
|
|
||||||
|
|
||||||
a) The modified work must itself be a software library.
|
|
||||||
|
|
||||||
b) You must cause the files modified to carry prominent notices
|
|
||||||
stating that you changed the files and the date of any change.
|
|
||||||
|
|
||||||
c) You must cause the whole of the work to be licensed at no
|
|
||||||
charge to all third parties under the terms of this License.
|
|
||||||
|
|
||||||
d) If a facility in the modified Library refers to a function or a
|
|
||||||
table of data to be supplied by an application program that uses
|
|
||||||
the facility, other than as an argument passed when the facility
|
|
||||||
is invoked, then you must make a good faith effort to ensure that,
|
|
||||||
in the event an application does not supply such function or
|
|
||||||
table, the facility still operates, and performs whatever part of
|
|
||||||
its purpose remains meaningful.
|
|
||||||
|
|
||||||
(For example, a function in a library to compute square roots has
|
|
||||||
a purpose that is entirely well-defined independent of the
|
|
||||||
application. Therefore, Subsection 2d requires that any
|
|
||||||
application-supplied function or table used by this function must
|
|
||||||
be optional: if the application does not supply it, the square
|
|
||||||
root function must still compute square roots.)
|
|
||||||
|
|
||||||
These requirements apply to the modified work as a whole. If
|
|
||||||
identifiable sections of that work are not derived from the Library,
|
|
||||||
and can be reasonably considered independent and separate works in
|
|
||||||
themselves, then this License, and its terms, do not apply to those
|
|
||||||
sections when you distribute them as separate works. But when you
|
|
||||||
distribute the same sections as part of a whole which is a work based
|
|
||||||
on the Library, the distribution of the whole must be on the terms of
|
|
||||||
this License, whose permissions for other licensees extend to the
|
|
||||||
entire whole, and thus to each and every part regardless of who wrote
|
|
||||||
it.
|
|
||||||
|
|
||||||
Thus, it is not the intent of this section to claim rights or contest
|
|
||||||
your rights to work written entirely by you; rather, the intent is to
|
|
||||||
exercise the right to control the distribution of derivative or
|
|
||||||
collective works based on the Library.
|
|
||||||
|
|
||||||
In addition, mere aggregation of another work not based on the Library
|
|
||||||
with the Library (or with a work based on the Library) on a volume of
|
|
||||||
a storage or distribution medium does not bring the other work under
|
|
||||||
the scope of this License.
|
|
||||||
|
|
||||||
3. You may opt to apply the terms of the ordinary GNU General Public
|
|
||||||
License instead of this License to a given copy of the Library. To do
|
|
||||||
this, you must alter all the notices that refer to this License, so
|
|
||||||
that they refer to the ordinary GNU General Public License, version 2,
|
|
||||||
instead of to this License. (If a newer version than version 2 of the
|
|
||||||
ordinary GNU General Public License has appeared, then you can specify
|
|
||||||
that version instead if you wish.) Do not make any other change in
|
|
||||||
these notices.
|
|
||||||
^L
|
|
||||||
Once this change is made in a given copy, it is irreversible for
|
|
||||||
that copy, so the ordinary GNU General Public License applies to all
|
|
||||||
subsequent copies and derivative works made from that copy.
|
|
||||||
|
|
||||||
This option is useful when you wish to copy part of the code of
|
|
||||||
the Library into a program that is not a library.
|
|
||||||
|
|
||||||
4. You may copy and distribute the Library (or a portion or
|
|
||||||
derivative of it, under Section 2) in object code or executable form
|
|
||||||
under the terms of Sections 1 and 2 above provided that you accompany
|
|
||||||
it with the complete corresponding machine-readable source code, which
|
|
||||||
must be distributed under the terms of Sections 1 and 2 above on a
|
|
||||||
medium customarily used for software interchange.
|
|
||||||
|
|
||||||
If distribution of object code is made by offering access to copy
|
|
||||||
from a designated place, then offering equivalent access to copy the
|
|
||||||
source code from the same place satisfies the requirement to
|
|
||||||
distribute the source code, even though third parties are not
|
|
||||||
compelled to copy the source along with the object code.
|
|
||||||
|
|
||||||
5. A program that contains no derivative of any portion of the
|
|
||||||
Library, but is designed to work with the Library by being compiled or
|
|
||||||
linked with it, is called a "work that uses the Library". Such a
|
|
||||||
work, in isolation, is not a derivative work of the Library, and
|
|
||||||
therefore falls outside the scope of this License.
|
|
||||||
|
|
||||||
However, linking a "work that uses the Library" with the Library
|
|
||||||
creates an executable that is a derivative of the Library (because it
|
|
||||||
contains portions of the Library), rather than a "work that uses the
|
|
||||||
library". The executable is therefore covered by this License.
|
|
||||||
Section 6 states terms for distribution of such executables.
|
|
||||||
|
|
||||||
When a "work that uses the Library" uses material from a header file
|
|
||||||
that is part of the Library, the object code for the work may be a
|
|
||||||
derivative work of the Library even though the source code is not.
|
|
||||||
Whether this is true is especially significant if the work can be
|
|
||||||
linked without the Library, or if the work is itself a library. The
|
|
||||||
threshold for this to be true is not precisely defined by law.
|
|
||||||
|
|
||||||
If such an object file uses only numerical parameters, data
|
|
||||||
structure layouts and accessors, and small macros and small inline
|
|
||||||
functions (ten lines or less in length), then the use of the object
|
|
||||||
file is unrestricted, regardless of whether it is legally a derivative
|
|
||||||
work. (Executables containing this object code plus portions of the
|
|
||||||
Library will still fall under Section 6.)
|
|
||||||
|
|
||||||
Otherwise, if the work is a derivative of the Library, you may
|
|
||||||
distribute the object code for the work under the terms of Section 6.
|
|
||||||
Any executables containing that work also fall under Section 6,
|
|
||||||
whether or not they are linked directly with the Library itself.
|
|
||||||
^L
|
|
||||||
6. As an exception to the Sections above, you may also combine or
|
|
||||||
link a "work that uses the Library" with the Library to produce a
|
|
||||||
work containing portions of the Library, and distribute that work
|
|
||||||
under terms of your choice, provided that the terms permit
|
|
||||||
modification of the work for the customer's own use and reverse
|
|
||||||
engineering for debugging such modifications.
|
|
||||||
|
|
||||||
You must give prominent notice with each copy of the work that the
|
|
||||||
Library is used in it and that the Library and its use are covered by
|
|
||||||
this License. You must supply a copy of this License. If the work
|
|
||||||
during execution displays copyright notices, you must include the
|
|
||||||
copyright notice for the Library among them, as well as a reference
|
|
||||||
directing the user to the copy of this License. Also, you must do one
|
|
||||||
of these things:
|
|
||||||
|
|
||||||
a) Accompany the work with the complete corresponding
|
|
||||||
machine-readable source code for the Library including whatever
|
|
||||||
changes were used in the work (which must be distributed under
|
|
||||||
Sections 1 and 2 above); and, if the work is an executable linked
|
|
||||||
with the Library, with the complete machine-readable "work that
|
|
||||||
uses the Library", as object code and/or source code, so that the
|
|
||||||
user can modify the Library and then relink to produce a modified
|
|
||||||
executable containing the modified Library. (It is understood
|
|
||||||
that the user who changes the contents of definitions files in the
|
|
||||||
Library will not necessarily be able to recompile the application
|
|
||||||
to use the modified definitions.)
|
|
||||||
|
|
||||||
b) Use a suitable shared library mechanism for linking with the
|
|
||||||
Library. A suitable mechanism is one that (1) uses at run time a
|
|
||||||
copy of the library already present on the user's computer system,
|
|
||||||
rather than copying library functions into the executable, and (2)
|
|
||||||
will operate properly with a modified version of the library, if
|
|
||||||
the user installs one, as long as the modified version is
|
|
||||||
interface-compatible with the version that the work was made with.
|
|
||||||
|
|
||||||
c) Accompany the work with a written offer, valid for at
|
|
||||||
least three years, to give the same user the materials
|
|
||||||
specified in Subsection 6a, above, for a charge no more
|
|
||||||
than the cost of performing this distribution.
|
|
||||||
|
|
||||||
d) If distribution of the work is made by offering access to copy
|
|
||||||
from a designated place, offer equivalent access to copy the above
|
|
||||||
specified materials from the same place.
|
|
||||||
|
|
||||||
e) Verify that the user has already received a copy of these
|
|
||||||
materials or that you have already sent this user a copy.
|
|
||||||
|
|
||||||
For an executable, the required form of the "work that uses the
|
|
||||||
Library" must include any data and utility programs needed for
|
|
||||||
reproducing the executable from it. However, as a special exception,
|
|
||||||
the materials to be distributed need not include anything that is
|
|
||||||
normally distributed (in either source or binary form) with the major
|
|
||||||
components (compiler, kernel, and so on) of the operating system on
|
|
||||||
which the executable runs, unless that component itself accompanies
|
|
||||||
the executable.
|
|
||||||
|
|
||||||
It may happen that this requirement contradicts the license
|
|
||||||
restrictions of other proprietary libraries that do not normally
|
|
||||||
accompany the operating system. Such a contradiction means you cannot
|
|
||||||
use both them and the Library together in an executable that you
|
|
||||||
distribute.
|
|
||||||
^L
|
|
||||||
7. You may place library facilities that are a work based on the
|
|
||||||
Library side-by-side in a single library together with other library
|
|
||||||
facilities not covered by this License, and distribute such a combined
|
|
||||||
library, provided that the separate distribution of the work based on
|
|
||||||
the Library and of the other library facilities is otherwise
|
|
||||||
permitted, and provided that you do these two things:
|
|
||||||
|
|
||||||
a) Accompany the combined library with a copy of the same work
|
|
||||||
based on the Library, uncombined with any other library
|
|
||||||
facilities. This must be distributed under the terms of the
|
|
||||||
Sections above.
|
|
||||||
|
|
||||||
b) Give prominent notice with the combined library of the fact
|
|
||||||
that part of it is a work based on the Library, and explaining
|
|
||||||
where to find the accompanying uncombined form of the same work.
|
|
||||||
|
|
||||||
8. You may not copy, modify, sublicense, link with, or distribute
|
|
||||||
the Library except as expressly provided under this License. Any
|
|
||||||
attempt otherwise to copy, modify, sublicense, link with, or
|
|
||||||
distribute the Library is void, and will automatically terminate your
|
|
||||||
rights under this License. However, parties who have received copies,
|
|
||||||
or rights, from you under this License will not have their licenses
|
|
||||||
terminated so long as such parties remain in full compliance.
|
|
||||||
|
|
||||||
9. You are not required to accept this License, since you have not
|
|
||||||
signed it. However, nothing else grants you permission to modify or
|
|
||||||
distribute the Library or its derivative works. These actions are
|
|
||||||
prohibited by law if you do not accept this License. Therefore, by
|
|
||||||
modifying or distributing the Library (or any work based on the
|
|
||||||
Library), you indicate your acceptance of this License to do so, and
|
|
||||||
all its terms and conditions for copying, distributing or modifying
|
|
||||||
the Library or works based on it.
|
|
||||||
|
|
||||||
10. Each time you redistribute the Library (or any work based on the
|
|
||||||
Library), the recipient automatically receives a license from the
|
|
||||||
original licensor to copy, distribute, link with or modify the Library
|
|
||||||
subject to these terms and conditions. You may not impose any further
|
|
||||||
restrictions on the recipients' exercise of the rights granted herein.
|
|
||||||
You are not responsible for enforcing compliance by third parties with
|
|
||||||
this License.
|
|
||||||
^L
|
|
||||||
11. If, as a consequence of a court judgment or allegation of patent
|
|
||||||
infringement or for any other reason (not limited to patent issues),
|
|
||||||
conditions are imposed on you (whether by court order, agreement or
|
|
||||||
otherwise) that contradict the conditions of this License, they do not
|
|
||||||
excuse you from the conditions of this License. If you cannot
|
|
||||||
distribute so as to satisfy simultaneously your obligations under this
|
|
||||||
License and any other pertinent obligations, then as a consequence you
|
|
||||||
may not distribute the Library at all. For example, if a patent
|
|
||||||
license would not permit royalty-free redistribution of the Library by
|
|
||||||
all those who receive copies directly or indirectly through you, then
|
|
||||||
the only way you could satisfy both it and this License would be to
|
|
||||||
refrain entirely from distribution of the Library.
|
|
||||||
|
|
||||||
If any portion of this section is held invalid or unenforceable under
|
|
||||||
any particular circumstance, the balance of the section is intended to
|
|
||||||
apply, and the section as a whole is intended to apply in other
|
|
||||||
circumstances.
|
|
||||||
|
|
||||||
It is not the purpose of this section to induce you to infringe any
|
|
||||||
patents or other property right claims or to contest validity of any
|
|
||||||
such claims; this section has the sole purpose of protecting the
|
|
||||||
integrity of the free software distribution system which is
|
|
||||||
implemented by public license practices. Many people have made
|
|
||||||
generous contributions to the wide range of software distributed
|
|
||||||
through that system in reliance on consistent application of that
|
|
||||||
system; it is up to the author/donor to decide if he or she is willing
|
|
||||||
to distribute software through any other system and a licensee cannot
|
|
||||||
impose that choice.
|
|
||||||
|
|
||||||
This section is intended to make thoroughly clear what is believed to
|
|
||||||
be a consequence of the rest of this License.
|
|
||||||
|
|
||||||
12. If the distribution and/or use of the Library is restricted in
|
|
||||||
certain countries either by patents or by copyrighted interfaces, the
|
|
||||||
original copyright holder who places the Library under this License
|
|
||||||
may add an explicit geographical distribution limitation excluding those
|
|
||||||
countries, so that distribution is permitted only in or among
|
|
||||||
countries not thus excluded. In such case, this License incorporates
|
|
||||||
the limitation as if written in the body of this License.
|
|
||||||
|
|
||||||
13. The Free Software Foundation may publish revised and/or new
|
|
||||||
versions of the Lesser General Public License from time to time.
|
|
||||||
Such new versions will be similar in spirit to the present version,
|
|
||||||
but may differ in detail to address new problems or concerns.
|
|
||||||
|
|
||||||
Each version is given a distinguishing version number. If the Library
|
|
||||||
specifies a version number of this License which applies to it and
|
|
||||||
"any later version", you have the option of following the terms and
|
|
||||||
conditions either of that version or of any later version published by
|
|
||||||
the Free Software Foundation. If the Library does not specify a
|
|
||||||
license version number, you may choose any version ever published by
|
|
||||||
the Free Software Foundation.
|
|
||||||
^L
|
|
||||||
14. If you wish to incorporate parts of the Library into other free
|
|
||||||
programs whose distribution conditions are incompatible with these,
|
|
||||||
write to the author to ask for permission. For software which is
|
|
||||||
copyrighted by the Free Software Foundation, write to the Free
|
|
||||||
Software Foundation; we sometimes make exceptions for this. Our
|
|
||||||
decision will be guided by the two goals of preserving the free status
|
|
||||||
of all derivatives of our free software and of promoting the sharing
|
|
||||||
and reuse of software generally.
|
|
||||||
|
|
||||||
NO WARRANTY
|
|
||||||
|
|
||||||
15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
|
|
||||||
WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
|
|
||||||
EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
|
|
||||||
OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
|
|
||||||
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
||||||
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
|
|
||||||
LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
|
|
||||||
THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
|
||||||
|
|
||||||
16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
|
|
||||||
WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
|
|
||||||
AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
|
|
||||||
FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
|
|
||||||
CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
|
|
||||||
LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
|
|
||||||
RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
|
|
||||||
FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
|
|
||||||
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
|
|
||||||
DAMAGES.
|
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
|
||||||
^L
|
|
||||||
How to Apply These Terms to Your New Libraries
|
|
||||||
|
|
||||||
If you develop a new library, and you want it to be of the greatest
|
|
||||||
possible use to the public, we recommend making it free software that
|
|
||||||
everyone can redistribute and change. You can do so by permitting
|
|
||||||
redistribution under these terms (or, alternatively, under the terms
|
|
||||||
of the ordinary General Public License).
|
|
||||||
|
|
||||||
To apply these terms, attach the following notices to the library.
|
|
||||||
It is safest to attach them to the start of each source file to most
|
|
||||||
effectively convey the exclusion of warranty; and each file should
|
|
||||||
have at least the "copyright" line and a pointer to where the full
|
|
||||||
notice is found.
|
|
||||||
|
|
||||||
|
|
||||||
<one line to give the library's name and a brief idea of what it
|
|
||||||
does.>
|
|
||||||
Copyright (C) <year> <name of author>
|
|
||||||
|
|
||||||
This library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Lesser General Public
|
|
||||||
License as published by the Free Software Foundation; either
|
|
||||||
version 2 of the License, or (at your option) any later version.
|
|
||||||
|
|
||||||
This library is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Lesser General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public
|
|
||||||
License along with this library; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
||||||
|
|
||||||
Also add information on how to contact you by electronic and paper
|
|
||||||
mail.
|
|
||||||
|
|
||||||
You should also get your employer (if you work as a programmer) or
|
|
||||||
your
|
|
||||||
school, if any, to sign a "copyright disclaimer" for the library, if
|
|
||||||
necessary. Here is a sample; alter the names:
|
|
||||||
|
|
||||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the
|
|
||||||
library `Frob' (a library for tweaking knobs) written by James
|
|
||||||
Random Hacker.
|
|
||||||
|
|
||||||
<signature of Ty Coon>, 1 April 1990
|
|
||||||
Ty Coon, President of Vice
|
|
||||||
|
|
||||||
That's all there is to it!
|
|
||||||
|
|
||||||
|
|
|
@ -1,470 +0,0 @@
|
||||||
MOZILLA PUBLIC LICENSE
|
|
||||||
Version 1.1
|
|
||||||
|
|
||||||
---------------
|
|
||||||
|
|
||||||
1. Definitions.
|
|
||||||
|
|
||||||
1.0.1. "Commercial Use" means distribution or otherwise making the
|
|
||||||
Covered Code available to a third party.
|
|
||||||
|
|
||||||
1.1. "Contributor" means each entity that creates or contributes to
|
|
||||||
the creation of Modifications.
|
|
||||||
|
|
||||||
1.2. "Contributor Version" means the combination of the Original
|
|
||||||
Code, prior Modifications used by a Contributor, and the Modifications
|
|
||||||
made by that particular Contributor.
|
|
||||||
|
|
||||||
1.3. "Covered Code" means the Original Code or Modifications or the
|
|
||||||
combination of the Original Code and Modifications, in each case
|
|
||||||
including portions thereof.
|
|
||||||
|
|
||||||
1.4. "Electronic Distribution Mechanism" means a mechanism generally
|
|
||||||
accepted in the software development community for the electronic
|
|
||||||
transfer of data.
|
|
||||||
|
|
||||||
1.5. "Executable" means Covered Code in any form other than Source
|
|
||||||
Code.
|
|
||||||
|
|
||||||
1.6. "Initial Developer" means the individual or entity identified
|
|
||||||
as the Initial Developer in the Source Code notice required by Exhibit
|
|
||||||
A.
|
|
||||||
|
|
||||||
1.7. "Larger Work" means a work which combines Covered Code or
|
|
||||||
portions thereof with code not governed by the terms of this License.
|
|
||||||
|
|
||||||
1.8. "License" means this document.
|
|
||||||
|
|
||||||
1.8.1. "Licensable" means having the right to grant, to the maximum
|
|
||||||
extent possible, whether at the time of the initial grant or
|
|
||||||
subsequently acquired, any and all of the rights conveyed herein.
|
|
||||||
|
|
||||||
1.9. "Modifications" means any addition to or deletion from the
|
|
||||||
substance or structure of either the Original Code or any previous
|
|
||||||
Modifications. When Covered Code is released as a series of files, a
|
|
||||||
Modification is:
|
|
||||||
A. Any addition to or deletion from the contents of a file
|
|
||||||
containing Original Code or previous Modifications.
|
|
||||||
|
|
||||||
B. Any new file that contains any part of the Original Code or
|
|
||||||
previous Modifications.
|
|
||||||
|
|
||||||
1.10. "Original Code" means Source Code of computer software code
|
|
||||||
which is described in the Source Code notice required by Exhibit A as
|
|
||||||
Original Code, and which, at the time of its release under this
|
|
||||||
License is not already Covered Code governed by this License.
|
|
||||||
|
|
||||||
1.10.1. "Patent Claims" means any patent claim(s), now owned or
|
|
||||||
hereafter acquired, including without limitation, method, process,
|
|
||||||
and apparatus claims, in any patent Licensable by grantor.
|
|
||||||
|
|
||||||
1.11. "Source Code" means the preferred form of the Covered Code for
|
|
||||||
making modifications to it, including all modules it contains, plus
|
|
||||||
any associated interface definition files, scripts used to control
|
|
||||||
compilation and installation of an Executable, or source code
|
|
||||||
differential comparisons against either the Original Code or another
|
|
||||||
well known, available Covered Code of the Contributor's choice. The
|
|
||||||
Source Code can be in a compressed or archival form, provided the
|
|
||||||
appropriate decompression or de-archiving software is widely available
|
|
||||||
for no charge.
|
|
||||||
|
|
||||||
1.12. "You" (or "Your") means an individual or a legal entity
|
|
||||||
exercising rights under, and complying with all of the terms of, this
|
|
||||||
License or a future version of this License issued under Section 6.1.
|
|
||||||
For legal entities, "You" includes any entity which controls, is
|
|
||||||
controlled by, or is under common control with You. For purposes of
|
|
||||||
this definition, "control" means (a) the power, direct or indirect,
|
|
||||||
to cause the direction or management of such entity, whether by
|
|
||||||
contract or otherwise, or (b) ownership of more than fifty percent
|
|
||||||
(50%) of the outstanding shares or beneficial ownership of such
|
|
||||||
entity.
|
|
||||||
|
|
||||||
2. Source Code License.
|
|
||||||
|
|
||||||
2.1. The Initial Developer Grant.
|
|
||||||
The Initial Developer hereby grants You a world-wide, royalty-free,
|
|
||||||
non-exclusive license, subject to third party intellectual property
|
|
||||||
claims:
|
|
||||||
(a) under intellectual property rights (other than patent or
|
|
||||||
trademark) Licensable by Initial Developer to use, reproduce,
|
|
||||||
modify, display, perform, sublicense and distribute the Original
|
|
||||||
Code (or portions thereof) with or without Modifications, and/or
|
|
||||||
as part of a Larger Work; and
|
|
||||||
|
|
||||||
(b) under Patents Claims infringed by the making, using or
|
|
||||||
selling of Original Code, to make, have made, use, practice,
|
|
||||||
sell, and offer for sale, and/or otherwise dispose of the
|
|
||||||
Original Code (or portions thereof).
|
|
||||||
|
|
||||||
(c) the licenses granted in this Section 2.1(a) and (b) are
|
|
||||||
effective on the date Initial Developer first distributes
|
|
||||||
Original Code under the terms of this License.
|
|
||||||
|
|
||||||
(d) Notwithstanding Section 2.1(b) above, no patent license is
|
|
||||||
granted: 1) for code that You delete from the Original Code; 2)
|
|
||||||
separate from the Original Code; or 3) for infringements caused
|
|
||||||
by: i) the modification of the Original Code or ii) the
|
|
||||||
combination of the Original Code with other software or devices.
|
|
||||||
|
|
||||||
2.2. Contributor Grant.
|
|
||||||
Subject to third party intellectual property claims, each Contributor
|
|
||||||
hereby grants You a world-wide, royalty-free, non-exclusive license
|
|
||||||
|
|
||||||
(a) under intellectual property rights (other than patent or
|
|
||||||
trademark) Licensable by Contributor, to use, reproduce, modify,
|
|
||||||
display, perform, sublicense and distribute the Modifications
|
|
||||||
created by such Contributor (or portions thereof) either on an
|
|
||||||
unmodified basis, with other Modifications, as Covered Code
|
|
||||||
and/or as part of a Larger Work; and
|
|
||||||
|
|
||||||
(b) under Patent Claims infringed by the making, using, or
|
|
||||||
selling of Modifications made by that Contributor either alone
|
|
||||||
and/or in combination with its Contributor Version (or portions
|
|
||||||
of such combination), to make, use, sell, offer for sale, have
|
|
||||||
made, and/or otherwise dispose of: 1) Modifications made by that
|
|
||||||
Contributor (or portions thereof); and 2) the combination of
|
|
||||||
Modifications made by that Contributor with its Contributor
|
|
||||||
Version (or portions of such combination).
|
|
||||||
|
|
||||||
(c) the licenses granted in Sections 2.2(a) and 2.2(b) are
|
|
||||||
effective on the date Contributor first makes Commercial Use of
|
|
||||||
the Covered Code.
|
|
||||||
|
|
||||||
(d) Notwithstanding Section 2.2(b) above, no patent license is
|
|
||||||
granted: 1) for any code that Contributor has deleted from the
|
|
||||||
Contributor Version; 2) separate from the Contributor Version;
|
|
||||||
3) for infringements caused by: i) third party modifications of
|
|
||||||
Contributor Version or ii) the combination of Modifications made
|
|
||||||
by that Contributor with other software (except as part of the
|
|
||||||
Contributor Version) or other devices; or 4) under Patent Claims
|
|
||||||
infringed by Covered Code in the absence of Modifications made by
|
|
||||||
that Contributor.
|
|
||||||
|
|
||||||
3. Distribution Obligations.
|
|
||||||
|
|
||||||
3.1. Application of License.
|
|
||||||
The Modifications which You create or to which You contribute are
|
|
||||||
governed by the terms of this License, including without limitation
|
|
||||||
Section 2.2. The Source Code version of Covered Code may be
|
|
||||||
distributed only under the terms of this License or a future version
|
|
||||||
of this License released under Section 6.1, and You must include a
|
|
||||||
copy of this License with every copy of the Source Code You
|
|
||||||
distribute. You may not offer or impose any terms on any Source Code
|
|
||||||
version that alters or restricts the applicable version of this
|
|
||||||
License or the recipients' rights hereunder. However, You may include
|
|
||||||
an additional document offering the additional rights described in
|
|
||||||
Section 3.5.
|
|
||||||
|
|
||||||
3.2. Availability of Source Code.
|
|
||||||
Any Modification which You create or to which You contribute must be
|
|
||||||
made available in Source Code form under the terms of this License
|
|
||||||
either on the same media as an Executable version or via an accepted
|
|
||||||
Electronic Distribution Mechanism to anyone to whom you made an
|
|
||||||
Executable version available; and if made available via Electronic
|
|
||||||
Distribution Mechanism, must remain available for at least twelve (12)
|
|
||||||
months after the date it initially became available, or at least six
|
|
||||||
(6) months after a subsequent version of that particular Modification
|
|
||||||
has been made available to such recipients. You are responsible for
|
|
||||||
ensuring that the Source Code version remains available even if the
|
|
||||||
Electronic Distribution Mechanism is maintained by a third party.
|
|
||||||
|
|
||||||
3.3. Description of Modifications.
|
|
||||||
You must cause all Covered Code to which You contribute to contain a
|
|
||||||
file documenting the changes You made to create that Covered Code and
|
|
||||||
the date of any change. You must include a prominent statement that
|
|
||||||
the Modification is derived, directly or indirectly, from Original
|
|
||||||
Code provided by the Initial Developer and including the name of the
|
|
||||||
Initial Developer in (a) the Source Code, and (b) in any notice in an
|
|
||||||
Executable version or related documentation in which You describe the
|
|
||||||
origin or ownership of the Covered Code.
|
|
||||||
|
|
||||||
3.4. Intellectual Property Matters
|
|
||||||
(a) Third Party Claims.
|
|
||||||
If Contributor has knowledge that a license under a third party's
|
|
||||||
intellectual property rights is required to exercise the rights
|
|
||||||
granted by such Contributor under Sections 2.1 or 2.2,
|
|
||||||
Contributor must include a text file with the Source Code
|
|
||||||
distribution titled "LEGAL" which describes the claim and the
|
|
||||||
party making the claim in sufficient detail that a recipient will
|
|
||||||
know whom to contact. If Contributor obtains such knowledge after
|
|
||||||
the Modification is made available as described in Section 3.2,
|
|
||||||
Contributor shall promptly modify the LEGAL file in all copies
|
|
||||||
Contributor makes available thereafter and shall take other steps
|
|
||||||
(such as notifying appropriate mailing lists or newsgroups)
|
|
||||||
reasonably calculated to inform those who received the Covered
|
|
||||||
Code that new knowledge has been obtained.
|
|
||||||
|
|
||||||
(b) Contributor APIs.
|
|
||||||
If Contributor's Modifications include an application programming
|
|
||||||
interface and Contributor has knowledge of patent licenses which
|
|
||||||
are reasonably necessary to implement that API, Contributor must
|
|
||||||
also include this information in the LEGAL file.
|
|
||||||
|
|
||||||
(c) Representations.
|
|
||||||
Contributor represents that, except as disclosed pursuant to
|
|
||||||
Section 3.4(a) above, Contributor believes that Contributor's
|
|
||||||
Modifications are Contributor's original creation(s) and/or
|
|
||||||
Contributor has sufficient rights to grant the rights conveyed by
|
|
||||||
this License.
|
|
||||||
|
|
||||||
3.5. Required Notices.
|
|
||||||
You must duplicate the notice in Exhibit A in each file of the Source
|
|
||||||
Code. If it is not possible to put such notice in a particular Source
|
|
||||||
Code file due to its structure, then You must include such notice in a
|
|
||||||
location (such as a relevant directory) where a user would be likely
|
|
||||||
to look for such a notice. If You created one or more Modification(s)
|
|
||||||
You may add your name as a Contributor to the notice described in
|
|
||||||
Exhibit A. You must also duplicate this License in any documentation
|
|
||||||
for the Source Code where You describe recipients' rights or ownership
|
|
||||||
rights relating to Covered Code. You may choose to offer, and to
|
|
||||||
charge a fee for, warranty, support, indemnity or liability
|
|
||||||
obligations to one or more recipients of Covered Code. However, You
|
|
||||||
may do so only on Your own behalf, and not on behalf of the Initial
|
|
||||||
Developer or any Contributor. You must make it absolutely clear than
|
|
||||||
any such warranty, support, indemnity or liability obligation is
|
|
||||||
offered by You alone, and You hereby agree to indemnify the Initial
|
|
||||||
Developer and every Contributor for any liability incurred by the
|
|
||||||
Initial Developer or such Contributor as a result of warranty,
|
|
||||||
support, indemnity or liability terms You offer.
|
|
||||||
|
|
||||||
3.6. Distribution of Executable Versions.
|
|
||||||
You may distribute Covered Code in Executable form only if the
|
|
||||||
requirements of Section 3.1-3.5 have been met for that Covered Code,
|
|
||||||
and if You include a notice stating that the Source Code version of
|
|
||||||
the Covered Code is available under the terms of this License,
|
|
||||||
including a description of how and where You have fulfilled the
|
|
||||||
obligations of Section 3.2. The notice must be conspicuously included
|
|
||||||
in any notice in an Executable version, related documentation or
|
|
||||||
collateral in which You describe recipients' rights relating to the
|
|
||||||
Covered Code. You may distribute the Executable version of Covered
|
|
||||||
Code or ownership rights under a license of Your choice, which may
|
|
||||||
contain terms different from this License, provided that You are in
|
|
||||||
compliance with the terms of this License and that the license for the
|
|
||||||
Executable version does not attempt to limit or alter the recipient's
|
|
||||||
rights in the Source Code version from the rights set forth in this
|
|
||||||
License. If You distribute the Executable version under a different
|
|
||||||
license You must make it absolutely clear that any terms which differ
|
|
||||||
from this License are offered by You alone, not by the Initial
|
|
||||||
Developer or any Contributor. You hereby agree to indemnify the
|
|
||||||
Initial Developer and every Contributor for any liability incurred by
|
|
||||||
the Initial Developer or such Contributor as a result of any such
|
|
||||||
terms You offer.
|
|
||||||
|
|
||||||
3.7. Larger Works.
|
|
||||||
You may create a Larger Work by combining Covered Code with other code
|
|
||||||
not governed by the terms of this License and distribute the Larger
|
|
||||||
Work as a single product. In such a case, You must make sure the
|
|
||||||
requirements of this License are fulfilled for the Covered Code.
|
|
||||||
|
|
||||||
4. Inability to Comply Due to Statute or Regulation.
|
|
||||||
|
|
||||||
If it is impossible for You to comply with any of the terms of this
|
|
||||||
License with respect to some or all of the Covered Code due to
|
|
||||||
statute, judicial order, or regulation then You must: (a) comply with
|
|
||||||
the terms of this License to the maximum extent possible; and (b)
|
|
||||||
describe the limitations and the code they affect. Such description
|
|
||||||
must be included in the LEGAL file described in Section 3.4 and must
|
|
||||||
be included with all distributions of the Source Code. Except to the
|
|
||||||
extent prohibited by statute or regulation, such description must be
|
|
||||||
sufficiently detailed for a recipient of ordinary skill to be able to
|
|
||||||
understand it.
|
|
||||||
|
|
||||||
5. Application of this License.
|
|
||||||
|
|
||||||
This License applies to code to which the Initial Developer has
|
|
||||||
attached the notice in Exhibit A and to related Covered Code.
|
|
||||||
|
|
||||||
6. Versions of the License.
|
|
||||||
|
|
||||||
6.1. New Versions.
|
|
||||||
Netscape Communications Corporation ("Netscape") may publish revised
|
|
||||||
and/or new versions of the License from time to time. Each version
|
|
||||||
will be given a distinguishing version number.
|
|
||||||
|
|
||||||
6.2. Effect of New Versions.
|
|
||||||
Once Covered Code has been published under a particular version of the
|
|
||||||
License, You may always continue to use it under the terms of that
|
|
||||||
version. You may also choose to use such Covered Code under the terms
|
|
||||||
of any subsequent version of the License published by Netscape. No one
|
|
||||||
other than Netscape has the right to modify the terms applicable to
|
|
||||||
Covered Code created under this License.
|
|
||||||
|
|
||||||
6.3. Derivative Works.
|
|
||||||
If You create or use a modified version of this License (which you may
|
|
||||||
only do in order to apply it to code which is not already Covered Code
|
|
||||||
governed by this License), You must (a) rename Your license so that
|
|
||||||
the phrases "Mozilla", "MOZILLAPL", "MOZPL", "Netscape",
|
|
||||||
"MPL", "NPL" or any confusingly similar phrase do not appear in your
|
|
||||||
license (except to note that your license differs from this License)
|
|
||||||
and (b) otherwise make it clear that Your version of the license
|
|
||||||
contains terms which differ from the Mozilla Public License and
|
|
||||||
Netscape Public License. (Filling in the name of the Initial
|
|
||||||
Developer, Original Code or Contributor in the notice described in
|
|
||||||
Exhibit A shall not of themselves be deemed to be modifications of
|
|
||||||
this License.)
|
|
||||||
|
|
||||||
7. DISCLAIMER OF WARRANTY.
|
|
||||||
|
|
||||||
COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
||||||
WITHOUT LIMITATION, WARRANTIES THAT THE COVERED CODE IS FREE OF
|
|
||||||
DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING.
|
|
||||||
THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED CODE
|
|
||||||
IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT,
|
|
||||||
YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE
|
|
||||||
COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER
|
|
||||||
OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF
|
|
||||||
ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER.
|
|
||||||
|
|
||||||
8. TERMINATION.
|
|
||||||
|
|
||||||
8.1. This License and the rights granted hereunder will terminate
|
|
||||||
automatically if You fail to comply with terms herein and fail to cure
|
|
||||||
such breach within 30 days of becoming aware of the breach. All
|
|
||||||
sublicenses to the Covered Code which are properly granted shall
|
|
||||||
survive any termination of this License. Provisions which, by their
|
|
||||||
nature, must remain in effect beyond the termination of this License
|
|
||||||
shall survive.
|
|
||||||
|
|
||||||
8.2. If You initiate litigation by asserting a patent infringement
|
|
||||||
claim (excluding declatory judgment actions) against Initial Developer
|
|
||||||
or a Contributor (the Initial Developer or Contributor against whom
|
|
||||||
You file such action is referred to as "Participant") alleging that:
|
|
||||||
|
|
||||||
(a) such Participant's Contributor Version directly or indirectly
|
|
||||||
infringes any patent, then any and all rights granted by such
|
|
||||||
Participant to You under Sections 2.1 and/or 2.2 of this License
|
|
||||||
shall, upon 60 days notice from Participant terminate prospectively,
|
|
||||||
unless if within 60 days after receipt of notice You either: (i)
|
|
||||||
agree in writing to pay Participant a mutually agreeable reasonable
|
|
||||||
royalty for Your past and future use of Modifications made by such
|
|
||||||
Participant, or (ii) withdraw Your litigation claim with respect to
|
|
||||||
the Contributor Version against such Participant. If within 60 days
|
|
||||||
of notice, a reasonable royalty and payment arrangement are not
|
|
||||||
mutually agreed upon in writing by the parties or the litigation claim
|
|
||||||
is not withdrawn, the rights granted by Participant to You under
|
|
||||||
Sections 2.1 and/or 2.2 automatically terminate at the expiration of
|
|
||||||
the 60 day notice period specified above.
|
|
||||||
|
|
||||||
(b) any software, hardware, or device, other than such Participant's
|
|
||||||
Contributor Version, directly or indirectly infringes any patent, then
|
|
||||||
any rights granted to You by such Participant under Sections 2.1(b)
|
|
||||||
and 2.2(b) are revoked effective as of the date You first made, used,
|
|
||||||
sold, distributed, or had made, Modifications made by that
|
|
||||||
Participant.
|
|
||||||
|
|
||||||
8.3. If You assert a patent infringement claim against Participant
|
|
||||||
alleging that such Participant's Contributor Version directly or
|
|
||||||
indirectly infringes any patent where such claim is resolved (such as
|
|
||||||
by license or settlement) prior to the initiation of patent
|
|
||||||
infringement litigation, then the reasonable value of the licenses
|
|
||||||
granted by such Participant under Sections 2.1 or 2.2 shall be taken
|
|
||||||
into account in determining the amount or value of any payment or
|
|
||||||
license.
|
|
||||||
|
|
||||||
8.4. In the event of termination under Sections 8.1 or 8.2 above,
|
|
||||||
all end user license agreements (excluding distributors and resellers)
|
|
||||||
which have been validly granted by You or any distributor hereunder
|
|
||||||
prior to termination shall survive termination.
|
|
||||||
|
|
||||||
9. LIMITATION OF LIABILITY.
|
|
||||||
|
|
||||||
UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT
|
|
||||||
(INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL YOU, THE INITIAL
|
|
||||||
DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED CODE,
|
|
||||||
OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO ANY PERSON FOR
|
|
||||||
ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY
|
|
||||||
CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL,
|
|
||||||
WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER
|
|
||||||
COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN
|
|
||||||
INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF
|
|
||||||
LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY
|
|
||||||
RESULTING FROM SUCH PARTY'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW
|
|
||||||
PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE
|
|
||||||
EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO
|
|
||||||
THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU.
|
|
||||||
|
|
||||||
10. U.S. GOVERNMENT END USERS.
|
|
||||||
|
|
||||||
The Covered Code is a "commercial item," as that term is defined in
|
|
||||||
48 C.F.R. 2.101 (Oct. 1995), consisting of "commercial computer
|
|
||||||
software" and "commercial computer software documentation," as such
|
|
||||||
terms are used in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48
|
|
||||||
C.F.R. 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995),
|
|
||||||
all U.S. Government End Users acquire Covered Code with only those
|
|
||||||
rights set forth herein.
|
|
||||||
|
|
||||||
11. MISCELLANEOUS.
|
|
||||||
|
|
||||||
This License represents the complete agreement concerning subject
|
|
||||||
matter hereof. If any provision of this License is held to be
|
|
||||||
unenforceable, such provision shall be reformed only to the extent
|
|
||||||
necessary to make it enforceable. This License shall be governed by
|
|
||||||
California law provisions (except to the extent applicable law, if
|
|
||||||
any, provides otherwise), excluding its conflict-of-law provisions.
|
|
||||||
With respect to disputes in which at least one party is a citizen of,
|
|
||||||
or an entity chartered or registered to do business in the United
|
|
||||||
States of America, any litigation relating to this License shall be
|
|
||||||
subject to the jurisdiction of the Federal Courts of the Northern
|
|
||||||
District of California, with venue lying in Santa Clara County,
|
|
||||||
California, with the losing party responsible for costs, including
|
|
||||||
without limitation, court costs and reasonable attorneys' fees and
|
|
||||||
expenses. The application of the United Nations Convention on
|
|
||||||
Contracts for the International Sale of Goods is expressly excluded.
|
|
||||||
Any law or regulation which provides that the language of a contract
|
|
||||||
shall be construed against the drafter shall not apply to this
|
|
||||||
License.
|
|
||||||
|
|
||||||
12. RESPONSIBILITY FOR CLAIMS.
|
|
||||||
|
|
||||||
As between Initial Developer and the Contributors, each party is
|
|
||||||
responsible for claims and damages arising, directly or indirectly,
|
|
||||||
out of its utilization of rights under this License and You agree to
|
|
||||||
work with Initial Developer and Contributors to distribute such
|
|
||||||
responsibility on an equitable basis. Nothing herein is intended or
|
|
||||||
shall be deemed to constitute any admission of liability.
|
|
||||||
|
|
||||||
13. MULTIPLE-LICENSED CODE.
|
|
||||||
|
|
||||||
Initial Developer may designate portions of the Covered Code as
|
|
||||||
"Multiple-Licensed". "Multiple-Licensed" means that the Initial
|
|
||||||
Developer permits you to utilize portions of the Covered Code under
|
|
||||||
Your choice of the NPL or the alternative licenses, if any, specified
|
|
||||||
by the Initial Developer in the file described in Exhibit A.
|
|
||||||
|
|
||||||
EXHIBIT A -Mozilla Public License.
|
|
||||||
|
|
||||||
``The contents of this file are subject to the Mozilla Public License
|
|
||||||
Version 1.1 (the "License"); you may not use this file except in
|
|
||||||
compliance with the License. You may obtain a copy of the License at
|
|
||||||
http://www.mozilla.org/MPL/
|
|
||||||
|
|
||||||
Software distributed under the License is distributed on an "AS IS"
|
|
||||||
basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
|
|
||||||
License for the specific language governing rights and limitations
|
|
||||||
under the License.
|
|
||||||
|
|
||||||
The Original Code is ______________________________________.
|
|
||||||
|
|
||||||
The Initial Developer of the Original Code is ________________________.
|
|
||||||
Portions created by ______________________ are Copyright (C) ______
|
|
||||||
_______________________. All Rights Reserved.
|
|
||||||
|
|
||||||
Contributor(s): ______________________________________.
|
|
||||||
|
|
||||||
Alternatively, the contents of this file may be used under the terms
|
|
||||||
of the _____ license (the "[___] License"), in which case the
|
|
||||||
provisions of [______] License are applicable instead of those
|
|
||||||
above. If you wish to allow use of your version of this file only
|
|
||||||
under the terms of the [____] License and not to allow others to use
|
|
||||||
your version of this file under the MPL, indicate your decision by
|
|
||||||
deleting the provisions above and replace them with the notice and
|
|
||||||
other provisions required by the [___] License. If you do not delete
|
|
||||||
the provisions above, a recipient may use your version of this file
|
|
||||||
under either the MPL or the [___] License."
|
|
||||||
|
|
||||||
[NOTE: The text of this Exhibit A may differ slightly from the text of
|
|
||||||
the notices in the Source Code files of the Original Code. You should
|
|
||||||
use the text of this Exhibit A rather than the text found in the
|
|
||||||
Original Code Source Code for Your Modifications.]
|
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,524 +0,0 @@
|
||||||
Myspell has a lot of parallel development, that is not documented here.
|
|
||||||
|
|
||||||
2005-01-11: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* hunspell.cxx:
|
|
||||||
- interaktív javításnál hiányzó új sor karakterek pótlása.
|
|
||||||
A hibát Gefferth András és Khiraly jelezte.
|
|
||||||
* csutil.cxx:
|
|
||||||
- pontosvesszők törlése a GCC 3.4-es fordító igényeinek megfelelően
|
|
||||||
A hibát Dvornik László jelezte.
|
|
||||||
- i változó ismételt deklarásának törlése, ami helyenként hibás
|
|
||||||
fordítást eredményez.
|
|
||||||
A hibát Lódoktor és Bencsáth Boldizsár jelezte.
|
|
||||||
* OLVASS.EL:
|
|
||||||
- Windows alatti fordításnál Langid.cxx módosítandó. A hibát
|
|
||||||
Lódoktor jelezte.
|
|
||||||
|
|
||||||
2004-12-15 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* src/morphbase/*:
|
|
||||||
- handling K&R morphological encoding (remove plus signs from output)
|
|
||||||
- LEMMA_PRESENT: put only morphological description to output
|
|
||||||
- LANG parameter, langnum variable in source for writing language-dependent codes
|
|
||||||
- remove HU_KOTOHANGZO
|
|
||||||
- etc.
|
|
||||||
* doc/hunspell.4:
|
|
||||||
- adding some
|
|
||||||
|
|
||||||
2004-09-29 Halácsy Péter <peter@halacsy.com>
|
|
||||||
|
|
||||||
* doc/ : bemásoltam a hunspell.1 hunspell.4 man oldalakat
|
|
||||||
* doc/hunspell.1: Kivettem a -s -m kapcsolókról szóló részt
|
|
||||||
|
|
||||||
2004-09-28 Halácsy Péter <peter@halacsy.com>
|
|
||||||
|
|
||||||
* src/hunspell/hunspell.cxx (indexing_interface): Ezt kiszedtem a
|
|
||||||
HunSpell-bol, mert nem ide valo. Ez egy kulon program lehet.
|
|
||||||
(main): a hunstem üzemmódot is kidobtam, ez se ide való
|
|
||||||
(main): meg a hunmorph üzemmódot is
|
|
||||||
|
|
||||||
* src/morphbase/morphbase.cxx (MorphBase): Átneveztem a MySpell
|
|
||||||
osztályt MorphBase-re
|
|
||||||
(stems): Átnevezten a suggest_stems metódust stem -re (mint to stem)
|
|
||||||
|
|
||||||
2004-08-25 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* src/hunbase/suggestmgr.cxx: tövezés visszaállítása, nem
|
|
||||||
működik még az igekötők hozzátoldása a tőhöz, továbbá a
|
|
||||||
kivételek kezelése (ehhez a 0.99.4-es szótár szükséges még).
|
|
||||||
* src/hunbase/myspell.cxx: -s vissza a tövezéshez
|
|
||||||
* src/hunbase/atypes.hxx: HUNSTEM makró definiálása itt az
|
|
||||||
affixmgr.cxx feltételes kódjához
|
|
||||||
|
|
||||||
2004-08-12 Halacsy Peter
|
|
||||||
* src/misc/lexfilter.cxx : uj program, ami a szotar szureshez hasznalhato
|
|
||||||
lecserelheti a mostani hunmorph, hunspell -G -1 funkciokat
|
|
||||||
|
|
||||||
* src/hunbase/myspell.cxx (analyzer) : Uj metodust vettem fel, ami mar
|
|
||||||
karaktertombben adja vissza az elemzes eredmenyet
|
|
||||||
|
|
||||||
2004-08-03 Halácsy Péter <peter@halacsy.com>
|
|
||||||
|
|
||||||
* src/hunspell/hunspell.cxx (HUNSPELL_VERSION): Áttettem ide ennek definiálását
|
|
||||||
|
|
||||||
2004-07-31 Halácsy Péter <peter@halacsy.com>
|
|
||||||
|
|
||||||
* src/hunbase/suggestmgr.cxx (fixstems): A fixstems miért itt van
|
|
||||||
és miért így hívják. Ez mehetne egy külön osztályba.
|
|
||||||
|
|
||||||
2004-07-31 Halácsy Péter <peter@halacsy.com>
|
|
||||||
|
|
||||||
* src/huntoken/htmlparser.cxx: Egyebkent az include-ok kezelese
|
|
||||||
eleg zavaros. Peldaul itt minek a textparser.hxx includolasa?
|
|
||||||
|
|
||||||
* src/huntoken/textparser.hxx (MAXLNLEN): Áthoztam ide a MAXLNLEN makrót
|
|
||||||
az atypes.hxx-bol, hogy a fuggoseget megszuntessem
|
|
||||||
|
|
||||||
* src/hunbase/myspell.cxx (suggest): Kivettem azt a részt, ami visszaadja a HUNSPELL_VERSION stringet
|
|
||||||
ha a VERSION_KEYWORD a bemeneti string. Csúnya gányolásnak tartottam
|
|
||||||
|
|
||||||
2004-07-27 Halácsy Péter <peter@halacsy.com>
|
|
||||||
|
|
||||||
* src/hunbase/myspell.cxx (morph_with_correction):
|
|
||||||
|
|
||||||
* src/hunbase/baseaffix.hxx (class AffEntry): Allandora felvettem a morphcode mezot (last htypes.hxx)
|
|
||||||
|
|
||||||
* src/hunbase/affentry.hxx: Kivettem a hunmorph felteteleket (last htypes.hxx)
|
|
||||||
|
|
||||||
* src/hunbase/htypes.hxx (struct hentry): Kivettem a HUNMORPH feltetelt a char* description korul. Ertem,
|
|
||||||
hogy hatekonyabb egy folosleges mutato nelkul, ha nincs morf info, de szerintem felesleges
|
|
||||||
|
|
||||||
* src/hunbase/myspell.hxx: HUNSPELL_VERSION es VERSION_KEYWORD makrokat kivettem. Valamiert a
|
|
||||||
hunspellnek kell majd
|
|
||||||
|
|
||||||
* src/hunbase/config.hxx (FLAG): config.hxx torolve, helyet atveszi a kozponti config.h; FLAG
|
|
||||||
definicioja az atypes.hxx-be ment
|
|
||||||
|
|
||||||
* src/hunbase/atypes.hxx (FLAG): config.hxx megszuntetese erdekeben attettem ide a FLAG makro
|
|
||||||
definialasat, ami az EXT_CLASS-tol fugg
|
|
||||||
|
|
||||||
config.hxx include kicserelve a configure altal kezelt config.h-ra
|
|
||||||
|
|
||||||
2004-06-29: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* affixmgr.cxx:
|
|
||||||
- csak utolsó tagként megengedett szavak (compound3) toldalék
|
|
||||||
nélküli előfordulásának engedélyezése (pl. macskapár)
|
|
||||||
- többszörösen összetett szavak toldalékolt alakjainak morfológiai
|
|
||||||
elemzése
|
|
||||||
* myspell.cxx:
|
|
||||||
- rövidítések, számok, kötőjeles összetett szavak és a
|
|
||||||
-e határozószót tartalmazó szavak morfológiai elemzése
|
|
||||||
* suggestmgr.cxx: suggest_morph_for_spelling_error() optimalizálása
|
|
||||||
(csak a felhasznált egy javaslatot keresi meg, többet nem).
|
|
||||||
* csutil.cxx: kimenetben szereplő üres sorok törlése
|
|
||||||
|
|
||||||
2004-06-10: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* suggestmgr.cxx: összetett szavak elemzésének korlátozása
|
|
||||||
- a tövezés még nincs megvalósítva a 0.9.9-es változatban
|
|
||||||
(helyette a Hunspell 0.9.7 használandó a Magyar Ispell 0.99.4-es
|
|
||||||
változatával)
|
|
||||||
|
|
||||||
2004-05-19: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.9f-alpha
|
|
||||||
|
|
||||||
- morf. leírás sztringkezelése jav.
|
|
||||||
- EXT_CLASS: config.cxx-ben
|
|
||||||
- nagybetűs alakok is elemezve (a hibát Tron Viktor jelezte)
|
|
||||||
- szebb kimenet
|
|
||||||
- rule119 törölve
|
|
||||||
- firstparser.cxx javítva
|
|
||||||
|
|
||||||
2004-02-13: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.8a:
|
|
||||||
- MAXUSERWORD helyett USERWORD, nincs korlát
|
|
||||||
- description \t-vel dic fájlba
|
|
||||||
- homonimák kezelése
|
|
||||||
- aff formátumbővítés
|
|
||||||
- konfixumok
|
|
||||||
- _morpho függvények
|
|
||||||
- kettős szuffixum
|
|
||||||
- hunmorph
|
|
||||||
- lásd tests/hunmorph
|
|
||||||
|
|
||||||
2004-01-29: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.7-sztaki:
|
|
||||||
- memóriakezelési hibák javítása
|
|
||||||
|
|
||||||
2003-12-17: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.7-es változat:
|
|
||||||
* affixmgr.cxx:
|
|
||||||
- suffix_check() javítás (tmpword kiváltása isRevSubSet()
|
|
||||||
függvénnyel
|
|
||||||
- betöltés optimalizálása, build_pfxlist() helyett:
|
|
||||||
- build_pfxtree()
|
|
||||||
- process_sfx_tree_to_list(), process_sfx_inorder()
|
|
||||||
|
|
||||||
* csutil.cxx:
|
|
||||||
- isSubSet() gyorsabb változata
|
|
||||||
- isRevSubSet()
|
|
||||||
|
|
||||||
* langid.cxx, hunp.cxx:
|
|
||||||
- nyelvfelismerő osztály és program (l. man hunp)
|
|
||||||
* man/hunp.1:
|
|
||||||
- nyelvfelismerő program leírása
|
|
||||||
|
|
||||||
* firstparser.cxx:
|
|
||||||
- csak a tabulátorjelet tartalmazó sorokból a tabulátorjel
|
|
||||||
előtti részt adja vissza (l. man Hunspell, -1 kapcsoló)
|
|
||||||
|
|
||||||
* hunspell.cxx:
|
|
||||||
- -u, -U, -u2 kapcsolók: tipikus hibák kijelzése;
|
|
||||||
automatikus, illetve lektorált javítása. L. man hunspell.
|
|
||||||
|
|
||||||
- -w kapcsoló teljes sor vizsgálatához
|
|
||||||
|
|
||||||
* hunspell.cxx:
|
|
||||||
- spell(): javítás (Valgrind hibajelzés alapján)
|
|
||||||
|
|
||||||
* hunspell.cxx: sprintf()-ek elé strlen() feltételvizsgálat
|
|
||||||
|
|
||||||
* suggestmgr.cxx:
|
|
||||||
- 0.99.4-es Hunspell szótárral bekerült tövezési hiba
|
|
||||||
javítása (nem produktív ragozású, összetett szóbam szereplő
|
|
||||||
főneveknél lépett fel ez a probléma).
|
|
||||||
|
|
||||||
* OLVASS.EL:
|
|
||||||
- bővítés
|
|
||||||
|
|
||||||
2003-11-03: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* SuggestMgr::permute_accent():
|
|
||||||
- illegális memóriaolvasási hiba javítása.
|
|
||||||
* example.cxx::
|
|
||||||
- dupla free() a "" karakterlánc tövezése után
|
|
||||||
|
|
||||||
A hibákat Sarlós Tamás <stamas@csillag.ilab.sztaki.hu>
|
|
||||||
fedezte fel a figyelemre méltó Valgrind nyomkövető
|
|
||||||
programmal (http://developer.kde.org/~sewardj/)
|
|
||||||
|
|
||||||
2003-10-22: Bencsáth Boldizsár <boldi@datacontact.hu>
|
|
||||||
* affixmgr.[ch]xx, csutil.[ch]xx: Az eredeti
|
|
||||||
MySpell foltjainak alkalmazása az OpenOffice.org 1.1
|
|
||||||
kompatibilitás érdekében. Itt karakterkezelő
|
|
||||||
segédfüggvények lettek áthelyezve elérhetőbb helyre.
|
|
||||||
|
|
||||||
* dictmgr.[ch]xx: Itt etype paraméter hozzáadása.
|
|
||||||
|
|
||||||
* makefile.mk: Itt angol szótárak megjegyzésbe tétele.
|
|
||||||
|
|
||||||
2003-10-04: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.6.3-as változat:
|
|
||||||
* myspell.cxx: suggest() függvényben hibás
|
|
||||||
memóriafoglalás javítása. A hiba a pontra végződő
|
|
||||||
helytelen szavakra adott javaslattevés során
|
|
||||||
jelentkezett. A hibás működést Khiraly
|
|
||||||
<khiraly@gmx.net> jelezte.
|
|
||||||
|
|
||||||
2003-09-15: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.6.2-es változat:
|
|
||||||
* latexparser.cxx: TeX elemző javítása:
|
|
||||||
- elemzési hiba ({{}}})
|
|
||||||
- verb+ +, \verb stb. kezelése
|
|
||||||
|
|
||||||
2003-09-01: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.6-os változat:
|
|
||||||
|
|
||||||
* affentry.cxx: check2 törlése, lehetséges
|
|
||||||
tövek tárolása
|
|
||||||
* suggestmgr.cxx, myspell.cxx: suggest_pos_stems()
|
|
||||||
az ismeretlen szavak névszóragjainak és
|
|
||||||
jeleinek leválasztására.
|
|
||||||
|
|
||||||
* affixmgr.cxx, suggestmgr.cxx: suggest_stems()
|
|
||||||
szálkezeléshez módosított és javított függvény
|
|
||||||
|
|
||||||
* myspell.cxx: számok tövezése (teszt: 5-nek)
|
|
||||||
|
|
||||||
* myspell.cxx: egy karakter + szó javaslatok
|
|
||||||
törlése (például cápak->cápa k)
|
|
||||||
|
|
||||||
* affixmgr.cxx, myspell.cxx, hunspell.cxx: szótár
|
|
||||||
verziószámának kiírása
|
|
||||||
|
|
||||||
* hunspell.cxx: \r karaktert tartalmazó sorok
|
|
||||||
helyes megjelenítése
|
|
||||||
|
|
||||||
* myspell.cxx, hunspell.cxx: rövidítés végi pontok
|
|
||||||
hozzáadása függvénykönyvtár szinten
|
|
||||||
|
|
||||||
* hunspell.cxx: pipe_interface(): standard bemenet
|
|
||||||
tövezésénél hiányzó memóriafelszabadítás pótlása
|
|
||||||
|
|
||||||
* Makefile: install javítása, több feltételvizsgálat
|
|
||||||
deinstall szakasz
|
|
||||||
|
|
||||||
2003-07-22: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.5-ös változat
|
|
||||||
* suggestmgr.cxx: marhalevél->lelevél tövezés javítása
|
|
||||||
* myspell.cxx: nagy kezdőbetűs rövidítések vizsgálata (Bp., Btk.)
|
|
||||||
- pontot tartalmazó számok helyesnek való elfogadása, ha:
|
|
||||||
- az első pontot legalább egy,
|
|
||||||
- de legfeljebb három számjegy előzi meg,
|
|
||||||
- a pontok nem egymás mellett helyezkednek el,
|
|
||||||
- az utolsó pont után legfeljebb két számjegy van.
|
|
||||||
Ezzel elfogadjuk az időpontokat (12.00-kor), a pontozásokat
|
|
||||||
(1.1.2-ben), de kizárjuk a szóköz nélküli hibás dátummegadásokat
|
|
||||||
(2003.7.22.), valamint a tizedesvessző helyett ponttal írt
|
|
||||||
tizedestörteket (3.456, 4563.34).
|
|
||||||
- Javítás a tiltott szavakra adott kötőjeles javaslatoknál:
|
|
||||||
Straussal->Strauss-szal, és nem ,,Strauss szal''.
|
|
||||||
* hunspell.cxx: csak a -a kapcsoló megadásával élnek a
|
|
||||||
csőfelületi parancsok. Ezért most már nincsenek figyelmen
|
|
||||||
kívül hagyva például a kötőjellel kezdődő sorok, ha a -l
|
|
||||||
kapcsolóval hibás szavakat keresünk egy állományban.
|
|
||||||
* man/hunspell.1: a -a kapcsoló leírásának kiegészítése.
|
|
||||||
|
|
||||||
2003-06-13: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.4-es változat
|
|
||||||
* bin/*: makedb, lookdb segédprogramok az indexeléshez
|
|
||||||
* man/*: hunstem, makedb, lookdb
|
|
||||||
* hunspell.cxx: pipe_interface: nyomkövető kiírás törlése
|
|
||||||
- LOG #ifdef-be
|
|
||||||
|
|
||||||
2003-06-11: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.3-es változat
|
|
||||||
* suggestmgr.cxx: nagybetűs javaslat tulajdonneveknél
|
|
||||||
* hunspell.cxx: pipe_interface: hiba javítása
|
|
||||||
|
|
||||||
2003-06-05: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.2-es változat
|
|
||||||
* hunspell.cxx: -s kapcsoló
|
|
||||||
* suggestmgr.cxx: suggest_stems()
|
|
||||||
Szótövek előállítása
|
|
||||||
* example.cxx: példa a szótövek előállítására
|
|
||||||
|
|
||||||
2003-05-13: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* 0.9.1-es változat
|
|
||||||
* hunspell.cxx:
|
|
||||||
- rl_escape(), stb.: a readline sorban ki lett kapcsolva
|
|
||||||
a fájlnév-kiegészítés, és helyette a két Escape lenyomás
|
|
||||||
megszakítja a szövegbevitelt. A Csere műveletnél is a
|
|
||||||
readline() hívás található most már.
|
|
||||||
- egy hibás sprintf() sor javítva lett
|
|
||||||
* Makefile.unix:
|
|
||||||
- beállítások elkülönítve az állomány elején
|
|
||||||
- Makefile most már szimbólikus kötés
|
|
||||||
* ooomagyarispellteszt.txt: tesztállomány
|
|
||||||
|
|
||||||
2003-04-28: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* affixmgr.cxx:
|
|
||||||
- y végű szavak kezelése: bővebb leírás a
|
|
||||||
Magyar Ispell Changelog állományában.
|
|
||||||
|
|
||||||
* *parser.cxx:
|
|
||||||
ISO-8859-1 HTML karakterentitások közül a betűértékűek
|
|
||||||
(csak az ISO-8859-2-ben nem szereplők) felismerése
|
|
||||||
és kezelése.
|
|
||||||
|
|
||||||
2003-04-21: Goldman Elenonóra <eleonora46@gmx.net>
|
|
||||||
* *.dll függvénykönyvtár előállítása Windows alatt:
|
|
||||||
- StdAfx.h
|
|
||||||
- libmyspell.def
|
|
||||||
- dlltest.cpp
|
|
||||||
|
|
||||||
2003-04-16: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* Hunspell.cxx, stb: a Mispell átnevezése Hunspell-lé.
|
|
||||||
A nevet Kornai András <andras@kornai.com> javasolta.
|
|
||||||
Könyvtárak: /usr/share/mispell -> /usr/share/myspell
|
|
||||||
(korábban is ez volt).
|
|
||||||
A /usr/share/hunmorph szótár a helye a speciális
|
|
||||||
morfológiai információkat tartalmazó Hunmorph (bővített
|
|
||||||
Myspell szótárformátumú) szótárállományoknak.
|
|
||||||
* Licenc: LGPL
|
|
||||||
* config.hxx: SZOSZABLYA_POSSIBLE_ROOTS
|
|
||||||
Ha a makrót bekapcsoljuk, akkor kiírásra kerülnek
|
|
||||||
a lehetséges tövek is, az alkalmazott ragozási szabály
|
|
||||||
osztályának betűjelével, illetve az alapszóval együtt.
|
|
||||||
|
|
||||||
2003-04-10: Németh László <nemethl@gyorsposta.hu>:
|
|
||||||
* affixmgr.cxx:
|
|
||||||
- kötőhangzók helyes kezelése (hu_kotohangzo kapcsolóval),
|
|
||||||
l. még Magyar Ispell Changelog
|
|
||||||
|
|
||||||
2003-03-24: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: pipe_interface(): az adatfájl szűrésnél fellépő
|
|
||||||
memóriaszivárgás megszüntetése a kimaradt free(token) pótlásával
|
|
||||||
* affixmgr.cxx: prefix_check(): leg-, legesleg- confixum ellenőrzés
|
|
||||||
- onlyroot kapcsoló a csak tőszót érintő tiltáshoz. L. Magyar Ispell
|
|
||||||
Az affixum állományban új kapcsolót adhatunk meg az
|
|
||||||
ONLYROOT paranccsal bevezetve. A kapcsoló módosítja a tiltókapcsoló
|
|
||||||
működését. L. man 4 mispell
|
|
||||||
* myspell.cxx:
|
|
||||||
- spell(): nagybetűs tulajdonnevek ellenőrzése (pl. BALATON)
|
|
||||||
- onlyroot vizsgálat forbiddenword mellett -> mangrove kezelése
|
|
||||||
|
|
||||||
2003-03-17: Goldman Elenonóra <eleonora46@gmx.net>
|
|
||||||
* Windows port
|
|
||||||
* makefile.Windows:
|
|
||||||
|
|
||||||
2003-03-04: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* firstparser.[ch]xx: adatfájlok szűréséhez (l. -1 kapcsoló)
|
|
||||||
* mispell.cxx: -L, -1, -G kapcsolók
|
|
||||||
* man/mispell.1: -L, -1, -G kapcsolók
|
|
||||||
|
|
||||||
2003-03-03: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: -l, -p, WORDLIST
|
|
||||||
* man/mispell.1: -l, -p, WORDLIST
|
|
||||||
|
|
||||||
2003-02-26: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: dialog_screen():
|
|
||||||
TILTOTT! (FORBIDDEN!) megjelenítése a tiltott szóösszetételek
|
|
||||||
esetén.
|
|
||||||
* suggestmgr.cxx:
|
|
||||||
- check(): -ó, -ő képzős igeneveket érintő kód törlése
|
|
||||||
- check_forbidden(): a 6 szótagnál hosszabb, tiltott szótövekre
|
|
||||||
vonatkozó javaslatok nem kötőjellel, hanem szóközzel elválasztva
|
|
||||||
tartalmazzák a szavakat, ehhez szükséges a check_forbidden().
|
|
||||||
* man/*: új kézikönyv oldal az állományok formátumáról (mispell(4)),
|
|
||||||
a mispell(1) bővítése.
|
|
||||||
* Makefile, mispell.mo: Bíró Árpád <biro_arpad@yahoo.com> javításai
|
|
||||||
|
|
||||||
2003-02-18: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: interactive_interface()
|
|
||||||
- nem nyeli el a MAXLNLEN-t meghaladó méretű sorokban a MAXLNLEN
|
|
||||||
méretű részek határán lévő karaktereket, és a nem újsor karakterre
|
|
||||||
végződő állományok utolsó karakterét. (Hibát viszont még mindig
|
|
||||||
jelez, ha a MAXLNLEN határ feldarabol egy amúgy helyes szót.)
|
|
||||||
A MAXLNLEN 8192 karakter jelenleg.
|
|
||||||
- readline függvénykönyvtár használata a bevitelnél
|
|
||||||
- tőfelvételnél egy lehetséges tő előállítása, és a beviteli
|
|
||||||
sorban való feltüntetése. Az így megjelenő szó javítható.
|
|
||||||
- --help kapcsoló
|
|
||||||
* Makefile: Javítások az install szakaszban.
|
|
||||||
A hibákat Bíró Árpád <biro_arpad@yahoo.com> jelezte.
|
|
||||||
|
|
||||||
2003-02-07: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: put_dots_to_suggestions()
|
|
||||||
- realloc() cseréje malloc()-ra ismeretlen eredetű lefagyás miatt.
|
|
||||||
- lehetséges az Ispellhez hasonlóan a kapcsolókat kézzel megadni a
|
|
||||||
saját szótárban a szavak után egy perjelet követően: például a
|
|
||||||
valamicsúnyaszó/w
|
|
||||||
sor megadása után a valamicsúnyaszó és toldalékolt változatai hibásak
|
|
||||||
lesznek az ellenőrzés alatt. (További kapcsolók leírásáért lásd a
|
|
||||||
Magyar Ispell forrásában az aff/aff.fej állományt.)
|
|
||||||
* affixmgr.cxx: compound_check()
|
|
||||||
- repl_chars() hívása a megfelelő helyre lett téve, ezzel a
|
|
||||||
javaslattevés sebessége kétszeresére nőtt.
|
|
||||||
- A dinamikus memóriakezelés lecserelése veremmemóriára nem járt
|
|
||||||
lényeges sebességnövekedéssel, de a közeljövőben ezzel elkerülhető
|
|
||||||
az a memóriaszivárgás, ami például itt a tiltott szavak kezelésénél
|
|
||||||
volt az előző változatban (javítva).
|
|
||||||
* affentry.cxx, affixmgr.cxx: szótő-előállító kód megalapozása:
|
|
||||||
get_possible_root() metódus az utolsó toldalék-leválasztás
|
|
||||||
eredményével tér vissza.
|
|
||||||
|
|
||||||
2003-02-05: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: put_dots_to_suggestions(): amennyiben
|
|
||||||
a felismert szó pontra, vagy pontokra végződik, a
|
|
||||||
javaslatokat is bővíti ezzel.
|
|
||||||
- @, valamint 1-nél több pontot magába foglaló (de nem arra végződő)
|
|
||||||
szavak ellenőrzésének tiltása (e-mail, fájlnevek, még nem opcionális).
|
|
||||||
- Hosszú sorok helyes megjelenítése.
|
|
||||||
- Tabulátorjelet tartalmazó sorok helyes megjelenítése.
|
|
||||||
- Mozaikszavak tőfelvételénél kötőjeles alak automatikus rögzítése
|
|
||||||
Pl.: BKV//URH mellett BKV-//URH- is bekerül a saját szótárba
|
|
||||||
(a ragozott mozaikszavak felismerése tehát automatikus lesz, kivéve a
|
|
||||||
nem triviális -val/-vel toldalékos alakoké, amit külön kell felvenni.)
|
|
||||||
- PuT törlése (helyette MySpell::put_word(), put_word_suffix(),
|
|
||||||
put_word_pattern() eljárások a saját szótár bővítésére)
|
|
||||||
- dupla szavak ellenőrzésének törlése a MySpell kódból (áthelyezés majd a
|
|
||||||
Mispell felületbe), hogy a MySpell meghívható maradjon párhuzamosan
|
|
||||||
futó szálakból.
|
|
||||||
|
|
||||||
2002-12-30: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* *parser.cxx, *parser.hxx: elemző osztályok a régi és csúnya kód helyett
|
|
||||||
|
|
||||||
2002-12-10: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* myspell.cxx: 35°-os, 20%-kal kezelése
|
|
||||||
* man/mispell.1: kézikönyv
|
|
||||||
|
|
||||||
2002-12-04: Noll János <johnzero@johnzero.hu>
|
|
||||||
* spdaemon/: kiszolgáló felület, ld. README.spdaemon
|
|
||||||
|
|
||||||
2002-12-04: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: Emacs kompatibilitáshoz hibák javítása (pl. többszörös -d)
|
|
||||||
* mispell.cxx: CURSES makróval kikapcsolható az interaktív felület + locale
|
|
||||||
(Windows, Macintosh)
|
|
||||||
|
|
||||||
2002-11-30: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* affixmgr.cxx: get_checkdoublewords()
|
|
||||||
|
|
||||||
2002-11-25: Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* affixmgr.cxx: mozgószabály (hu_mov_rule)
|
|
||||||
* myspell.cxx: mozgószabály
|
|
||||||
* affixmgr.cxx: kiötlőjénekmacskát (affix is összetettben, ha prefix)
|
|
||||||
|
|
||||||
2002-11-08 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* myspell.cxx: balatonnak->Balatonnak, balatoninak
|
|
||||||
|
|
||||||
2002-11-07 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* myspell: 0.6-os változat
|
|
||||||
|
|
||||||
2002-10-31 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* Egyszerűbb név: Magyar MySpell 0.5 után -> MIspell 0.6
|
|
||||||
* mispell.cxx: többnyelvű interaktív felület (ncurses, locale)
|
|
||||||
* Makefile: make install
|
|
||||||
|
|
||||||
2002-09-22 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* affixmgr.cxx: compound_check() macskaugom->macskaugrom, stb. javítása
|
|
||||||
* affixmgr.cxx: compound_check() szóismétlés (pl. macskamacska) tiltása
|
|
||||||
* myspell.cxx: szóismétlődés tiltása (pl. kutya kutya) második rossz
|
|
||||||
* suggestmgr.cxx: macskaírat->macska írat mellett ->macskairat
|
|
||||||
|
|
||||||
2002-07-29 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell Windowsra, teszt Emacs-szel (vagy Emacs-csal)
|
|
||||||
* tiltott szavakat nem javasol, és összetett szóban sem fogad el
|
|
||||||
* fonev_morfo, fonev_morfo2 álszótövek elutasítása (házakmacska)
|
|
||||||
* kötőjeles szavak kezelése
|
|
||||||
* számok kezelése, kötőjeles alakjaikkal együtt, CHECKNUM kapcsoló
|
|
||||||
|
|
||||||
2002-07-17 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: MySpell Ispell cső interfész
|
|
||||||
|
|
||||||
2002-07-04 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* mispell.cxx: MySpell Ispell cső interfész
|
|
||||||
* affxmgr.cxx: szszerű kiszűrése,
|
|
||||||
* új funkciók:
|
|
||||||
COMPOUNDFIRST: szó szerepelhet első tagként a szóöszetételekben
|
|
||||||
COMPOUNDLAST: szó szerepelhet utolsó tagként a szóöszetételekben
|
|
||||||
FORBIDDENWORD: tiltott szavak kapcsolója (utú, uta, stb.)
|
|
||||||
|
|
||||||
2002-06-25 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* myspell.cxx, suggestmgr.cxx: get_compound() char* helyett char
|
|
||||||
* affxmgr.cxx: check_repl() a helyesnek tűnő, de hibás összetett
|
|
||||||
szavak kiszűrésére (pl. tejles, szervíz)
|
|
||||||
A szóösszetétel elfogadása előtt még megnézzük, hogy a szó
|
|
||||||
nem-e a cseretáblázatban felvett hibát tartalmaz,
|
|
||||||
ha igen, akkor a szó hibásnak minősül, hiába helyes szóösszetétel.
|
|
||||||
* affxmgr.cxx, suggestmgr.xx: accent: ékezetesítő.
|
|
||||||
Leírás: README.accent
|
|
||||||
További optimalizáció: az ékezet nélküli betű ékezetes
|
|
||||||
változatai számának függvényében
|
|
||||||
|
|
||||||
2002-06-05 Noll János <johnzero@johnzero.hu>
|
|
||||||
* myspell.cxx, suggestmgr.cxx: mem. szivárgás javítása
|
|
||||||
(a get_compound() felszabadítás nélkül lett meghíva).
|
|
||||||
A hiba a GNU mtrace segítségével lett detektálva.
|
|
||||||
|
|
||||||
2002-06-03 Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* Licenc: GPL
|
|
||||||
* Lásd MYSPELL.HU
|
|
||||||
* compound_check: 6-3 szabály, stb.
|
|
||||||
|
|
||||||
MySpell:
|
|
||||||
|
|
||||||
2002-xx-xx Kevin Hendricks <kevin.hendricks@sympatico.ca>
|
|
||||||
* REP: ismétlések kiszűrése a javaslatokból
|
|
||||||
* COMPOUNDMIN
|
|
||||||
|
|
||||||
2002-xx-xx Németh László <nemethl@gyorsposta.hu>
|
|
||||||
* REP cseretáblázat
|
|
||||||
* COMPOUND, szóösszetételképzés
|
|
||||||
|
|
||||||
2002-xx-xx David Einstein <Deinst@world.std.com>
|
|
||||||
* optimalizált MySpell algoritmus
|
|
||||||
|
|
||||||
2001-xx-xx Kevin Hendricks <kevin.hendricks@sympatico.ca>
|
|
||||||
* Működő ellenőrző, Ispell toldaléktömörítési algoritmussal
|
|
|
@ -1,229 +0,0 @@
|
||||||
Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002 Free Software
|
|
||||||
Foundation, Inc.
|
|
||||||
|
|
||||||
This file is free documentation; the Free Software Foundation gives
|
|
||||||
unlimited permission to copy, distribute and modify it.
|
|
||||||
|
|
||||||
Basic Installation
|
|
||||||
==================
|
|
||||||
|
|
||||||
These are generic installation instructions.
|
|
||||||
|
|
||||||
The `configure' shell script attempts to guess correct values for
|
|
||||||
various system-dependent variables used during compilation. It uses
|
|
||||||
those values to create a `Makefile' in each directory of the package.
|
|
||||||
It may also create one or more `.h' files containing system-dependent
|
|
||||||
definitions. Finally, it creates a shell script `config.status' that
|
|
||||||
you can run in the future to recreate the current configuration, and a
|
|
||||||
file `config.log' containing compiler output (useful mainly for
|
|
||||||
debugging `configure').
|
|
||||||
|
|
||||||
It can also use an optional file (typically called `config.cache'
|
|
||||||
and enabled with `--cache-file=config.cache' or simply `-C') that saves
|
|
||||||
the results of its tests to speed up reconfiguring. (Caching is
|
|
||||||
disabled by default to prevent problems with accidental use of stale
|
|
||||||
cache files.)
|
|
||||||
|
|
||||||
If you need to do unusual things to compile the package, please try
|
|
||||||
to figure out how `configure' could check whether to do them, and mail
|
|
||||||
diffs or instructions to the address given in the `README' so they can
|
|
||||||
be considered for the next release. If you are using the cache, and at
|
|
||||||
some point `config.cache' contains results you don't want to keep, you
|
|
||||||
may remove or edit it.
|
|
||||||
|
|
||||||
The file `configure.ac' (or `configure.in') is used to create
|
|
||||||
`configure' by a program called `autoconf'. You only need
|
|
||||||
`configure.ac' if you want to change it or regenerate `configure' using
|
|
||||||
a newer version of `autoconf'.
|
|
||||||
|
|
||||||
The simplest way to compile this package is:
|
|
||||||
|
|
||||||
1. `cd' to the directory containing the package's source code and type
|
|
||||||
`./configure' to configure the package for your system. If you're
|
|
||||||
using `csh' on an old version of System V, you might need to type
|
|
||||||
`sh ./configure' instead to prevent `csh' from trying to execute
|
|
||||||
`configure' itself.
|
|
||||||
|
|
||||||
Running `configure' takes awhile. While running, it prints some
|
|
||||||
messages telling which features it is checking for.
|
|
||||||
|
|
||||||
2. Type `make' to compile the package.
|
|
||||||
|
|
||||||
3. Optionally, type `make check' to run any self-tests that come with
|
|
||||||
the package.
|
|
||||||
|
|
||||||
4. Type `make install' to install the programs and any data files and
|
|
||||||
documentation.
|
|
||||||
|
|
||||||
5. You can remove the program binaries and object files from the
|
|
||||||
source code directory by typing `make clean'. To also remove the
|
|
||||||
files that `configure' created (so you can compile the package for
|
|
||||||
a different kind of computer), type `make distclean'. There is
|
|
||||||
also a `make maintainer-clean' target, but that is intended mainly
|
|
||||||
for the package's developers. If you use it, you may have to get
|
|
||||||
all sorts of other programs in order to regenerate files that came
|
|
||||||
with the distribution.
|
|
||||||
|
|
||||||
Compilers and Options
|
|
||||||
=====================
|
|
||||||
|
|
||||||
Some systems require unusual options for compilation or linking that
|
|
||||||
the `configure' script does not know about. Run `./configure --help'
|
|
||||||
for details on some of the pertinent environment variables.
|
|
||||||
|
|
||||||
You can give `configure' initial values for configuration parameters
|
|
||||||
by setting variables in the command line or in the environment. Here
|
|
||||||
is an example:
|
|
||||||
|
|
||||||
./configure CC=c89 CFLAGS=-O2 LIBS=-lposix
|
|
||||||
|
|
||||||
*Note Defining Variables::, for more details.
|
|
||||||
|
|
||||||
Compiling For Multiple Architectures
|
|
||||||
====================================
|
|
||||||
|
|
||||||
You can compile the package for more than one kind of computer at the
|
|
||||||
same time, by placing the object files for each architecture in their
|
|
||||||
own directory. To do this, you must use a version of `make' that
|
|
||||||
supports the `VPATH' variable, such as GNU `make'. `cd' to the
|
|
||||||
directory where you want the object files and executables to go and run
|
|
||||||
the `configure' script. `configure' automatically checks for the
|
|
||||||
source code in the directory that `configure' is in and in `..'.
|
|
||||||
|
|
||||||
If you have to use a `make' that does not support the `VPATH'
|
|
||||||
variable, you have to compile the package for one architecture at a
|
|
||||||
time in the source code directory. After you have installed the
|
|
||||||
package for one architecture, use `make distclean' before reconfiguring
|
|
||||||
for another architecture.
|
|
||||||
|
|
||||||
Installation Names
|
|
||||||
==================
|
|
||||||
|
|
||||||
By default, `make install' will install the package's files in
|
|
||||||
`/usr/local/bin', `/usr/local/man', etc. You can specify an
|
|
||||||
installation prefix other than `/usr/local' by giving `configure' the
|
|
||||||
option `--prefix=PATH'.
|
|
||||||
|
|
||||||
You can specify separate installation prefixes for
|
|
||||||
architecture-specific files and architecture-independent files. If you
|
|
||||||
give `configure' the option `--exec-prefix=PATH', the package will use
|
|
||||||
PATH as the prefix for installing programs and libraries.
|
|
||||||
Documentation and other data files will still use the regular prefix.
|
|
||||||
|
|
||||||
In addition, if you use an unusual directory layout you can give
|
|
||||||
options like `--bindir=PATH' to specify different values for particular
|
|
||||||
kinds of files. Run `configure --help' for a list of the directories
|
|
||||||
you can set and what kinds of files go in them.
|
|
||||||
|
|
||||||
If the package supports it, you can cause programs to be installed
|
|
||||||
with an extra prefix or suffix on their names by giving `configure' the
|
|
||||||
option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'.
|
|
||||||
|
|
||||||
Optional Features
|
|
||||||
=================
|
|
||||||
|
|
||||||
Some packages pay attention to `--enable-FEATURE' options to
|
|
||||||
`configure', where FEATURE indicates an optional part of the package.
|
|
||||||
They may also pay attention to `--with-PACKAGE' options, where PACKAGE
|
|
||||||
is something like `gnu-as' or `x' (for the X Window System). The
|
|
||||||
`README' should mention any `--enable-' and `--with-' options that the
|
|
||||||
package recognizes.
|
|
||||||
|
|
||||||
For packages that use the X Window System, `configure' can usually
|
|
||||||
find the X include and library files automatically, but if it doesn't,
|
|
||||||
you can use the `configure' options `--x-includes=DIR' and
|
|
||||||
`--x-libraries=DIR' to specify their locations.
|
|
||||||
|
|
||||||
Specifying the System Type
|
|
||||||
==========================
|
|
||||||
|
|
||||||
There may be some features `configure' cannot figure out
|
|
||||||
automatically, but needs to determine by the type of machine the package
|
|
||||||
will run on. Usually, assuming the package is built to be run on the
|
|
||||||
_same_ architectures, `configure' can figure that out, but if it prints
|
|
||||||
a message saying it cannot guess the machine type, give it the
|
|
||||||
`--build=TYPE' option. TYPE can either be a short name for the system
|
|
||||||
type, such as `sun4', or a canonical name which has the form:
|
|
||||||
|
|
||||||
CPU-COMPANY-SYSTEM
|
|
||||||
|
|
||||||
where SYSTEM can have one of these forms:
|
|
||||||
|
|
||||||
OS KERNEL-OS
|
|
||||||
|
|
||||||
See the file `config.sub' for the possible values of each field. If
|
|
||||||
`config.sub' isn't included in this package, then this package doesn't
|
|
||||||
need to know the machine type.
|
|
||||||
|
|
||||||
If you are _building_ compiler tools for cross-compiling, you should
|
|
||||||
use the `--target=TYPE' option to select the type of system they will
|
|
||||||
produce code for.
|
|
||||||
|
|
||||||
If you want to _use_ a cross compiler, that generates code for a
|
|
||||||
platform different from the build platform, you should specify the
|
|
||||||
"host" platform (i.e., that on which the generated programs will
|
|
||||||
eventually be run) with `--host=TYPE'.
|
|
||||||
|
|
||||||
Sharing Defaults
|
|
||||||
================
|
|
||||||
|
|
||||||
If you want to set default values for `configure' scripts to share,
|
|
||||||
you can create a site shell script called `config.site' that gives
|
|
||||||
default values for variables like `CC', `cache_file', and `prefix'.
|
|
||||||
`configure' looks for `PREFIX/share/config.site' if it exists, then
|
|
||||||
`PREFIX/etc/config.site' if it exists. Or, you can set the
|
|
||||||
`CONFIG_SITE' environment variable to the location of the site script.
|
|
||||||
A warning: not all `configure' scripts look for a site script.
|
|
||||||
|
|
||||||
Defining Variables
|
|
||||||
==================
|
|
||||||
|
|
||||||
Variables not defined in a site shell script can be set in the
|
|
||||||
environment passed to `configure'. However, some packages may run
|
|
||||||
configure again during the build, and the customized values of these
|
|
||||||
variables may be lost. In order to avoid this problem, you should set
|
|
||||||
them in the `configure' command line, using `VAR=value'. For example:
|
|
||||||
|
|
||||||
./configure CC=/usr/local2/bin/gcc
|
|
||||||
|
|
||||||
will cause the specified gcc to be used as the C compiler (unless it is
|
|
||||||
overridden in the site shell script).
|
|
||||||
|
|
||||||
`configure' Invocation
|
|
||||||
======================
|
|
||||||
|
|
||||||
`configure' recognizes the following options to control how it
|
|
||||||
operates.
|
|
||||||
|
|
||||||
`--help'
|
|
||||||
`-h'
|
|
||||||
Print a summary of the options to `configure', and exit.
|
|
||||||
|
|
||||||
`--version'
|
|
||||||
`-V'
|
|
||||||
Print the version of Autoconf used to generate the `configure'
|
|
||||||
script, and exit.
|
|
||||||
|
|
||||||
`--cache-file=FILE'
|
|
||||||
Enable the cache: use and save the results of the tests in FILE,
|
|
||||||
traditionally `config.cache'. FILE defaults to `/dev/null' to
|
|
||||||
disable caching.
|
|
||||||
|
|
||||||
`--config-cache'
|
|
||||||
`-C'
|
|
||||||
Alias for `--cache-file=config.cache'.
|
|
||||||
|
|
||||||
`--quiet'
|
|
||||||
`--silent'
|
|
||||||
`-q'
|
|
||||||
Do not print messages saying which checks are being made. To
|
|
||||||
suppress all normal output, redirect it to `/dev/null' (any error
|
|
||||||
messages will still be shown).
|
|
||||||
|
|
||||||
`--srcdir=DIR'
|
|
||||||
Look for the package's source code in directory DIR. Usually
|
|
||||||
`configure' can determine that directory automatically.
|
|
||||||
|
|
||||||
`configure' also accepts some other, not widely useful, options. Run
|
|
||||||
`configure --help' for more details.
|
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
ACLOCAL_AMFLAGS = -I m4
|
|
||||||
|
|
||||||
SUBDIRS= intl po src man m4 tests
|
|
||||||
|
|
||||||
pkgconfdir = $(libdir)/pkgconfig
|
|
||||||
pkgconf_DATA = hunspell.pc
|
|
||||||
|
|
||||||
EXTRA_DIST = BUGS README.myspell AUTHORS.myspell license.myspell license.hunspell \
|
|
||||||
ChangeLog.O COPYING.MPL COPYING.LGPL hunspell.pc.in
|
|
|
@ -1,855 +0,0 @@
|
||||||
# Makefile.in generated by automake 1.11.1 from Makefile.am.
|
|
||||||
# @configure_input@
|
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
|
||||||
# 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation,
|
|
||||||
# Inc.
|
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
@SET_MAKE@
|
|
||||||
|
|
||||||
VPATH = @srcdir@
|
|
||||||
pkgdatadir = $(datadir)/@PACKAGE@
|
|
||||||
pkgincludedir = $(includedir)/@PACKAGE@
|
|
||||||
pkglibdir = $(libdir)/@PACKAGE@
|
|
||||||
pkglibexecdir = $(libexecdir)/@PACKAGE@
|
|
||||||
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
|
||||||
install_sh_DATA = $(install_sh) -c -m 644
|
|
||||||
install_sh_PROGRAM = $(install_sh) -c
|
|
||||||
install_sh_SCRIPT = $(install_sh) -c
|
|
||||||
INSTALL_HEADER = $(INSTALL_DATA)
|
|
||||||
transform = $(program_transform_name)
|
|
||||||
NORMAL_INSTALL = :
|
|
||||||
PRE_INSTALL = :
|
|
||||||
POST_INSTALL = :
|
|
||||||
NORMAL_UNINSTALL = :
|
|
||||||
PRE_UNINSTALL = :
|
|
||||||
POST_UNINSTALL = :
|
|
||||||
build_triplet = @build@
|
|
||||||
host_triplet = @host@
|
|
||||||
target_triplet = @target@
|
|
||||||
subdir = .
|
|
||||||
DIST_COMMON = README $(am__configure_deps) $(srcdir)/Makefile.am \
|
|
||||||
$(srcdir)/Makefile.in $(srcdir)/config.h.in \
|
|
||||||
$(srcdir)/hunspell.pc.in $(top_srcdir)/configure \
|
|
||||||
$(top_srcdir)/intl/Makefile.in ABOUT-NLS AUTHORS COPYING \
|
|
||||||
ChangeLog INSTALL NEWS THANKS TODO config.guess config.rpath \
|
|
||||||
config.sub depcomp install-sh ltmain.sh missing mkinstalldirs
|
|
||||||
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
|
||||||
am__aclocal_m4_deps = $(top_srcdir)/m4/codeset.m4 \
|
|
||||||
$(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/glibc2.m4 \
|
|
||||||
$(top_srcdir)/m4/glibc21.m4 $(top_srcdir)/m4/iconv.m4 \
|
|
||||||
$(top_srcdir)/m4/intdiv0.m4 $(top_srcdir)/m4/intl.m4 \
|
|
||||||
$(top_srcdir)/m4/intlmacosx.m4 $(top_srcdir)/m4/intmax.m4 \
|
|
||||||
$(top_srcdir)/m4/inttypes-pri.m4 \
|
|
||||||
$(top_srcdir)/m4/inttypes_h.m4 $(top_srcdir)/m4/lcmessage.m4 \
|
|
||||||
$(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \
|
|
||||||
$(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libtool.m4 \
|
|
||||||
$(top_srcdir)/m4/lock.m4 $(top_srcdir)/m4/longlong.m4 \
|
|
||||||
$(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \
|
|
||||||
$(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \
|
|
||||||
$(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \
|
|
||||||
$(top_srcdir)/m4/printf-posix.m4 $(top_srcdir)/m4/progtest.m4 \
|
|
||||||
$(top_srcdir)/m4/size_max.m4 $(top_srcdir)/m4/stdint_h.m4 \
|
|
||||||
$(top_srcdir)/m4/uintmax_t.m4 $(top_srcdir)/m4/visibility.m4 \
|
|
||||||
$(top_srcdir)/m4/wchar_t.m4 $(top_srcdir)/m4/wint_t.m4 \
|
|
||||||
$(top_srcdir)/m4/xsize.m4 $(top_srcdir)/configure.ac
|
|
||||||
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
|
||||||
$(ACLOCAL_M4)
|
|
||||||
am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
|
|
||||||
configure.lineno config.status.lineno
|
|
||||||
mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
|
|
||||||
CONFIG_HEADER = config.h
|
|
||||||
CONFIG_CLEAN_FILES = hunspell.pc intl/Makefile
|
|
||||||
CONFIG_CLEAN_VPATH_FILES =
|
|
||||||
SOURCES =
|
|
||||||
DIST_SOURCES =
|
|
||||||
RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \
|
|
||||||
html-recursive info-recursive install-data-recursive \
|
|
||||||
install-dvi-recursive install-exec-recursive \
|
|
||||||
install-html-recursive install-info-recursive \
|
|
||||||
install-pdf-recursive install-ps-recursive install-recursive \
|
|
||||||
installcheck-recursive installdirs-recursive pdf-recursive \
|
|
||||||
ps-recursive uninstall-recursive
|
|
||||||
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
|
||||||
am__vpath_adj = case $$p in \
|
|
||||||
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
|
||||||
*) f=$$p;; \
|
|
||||||
esac;
|
|
||||||
am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
|
|
||||||
am__install_max = 40
|
|
||||||
am__nobase_strip_setup = \
|
|
||||||
srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
|
|
||||||
am__nobase_strip = \
|
|
||||||
for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
|
|
||||||
am__nobase_list = $(am__nobase_strip_setup); \
|
|
||||||
for p in $$list; do echo "$$p $$p"; done | \
|
|
||||||
sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
|
|
||||||
$(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
|
|
||||||
if (++n[$$2] == $(am__install_max)) \
|
|
||||||
{ print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
|
|
||||||
END { for (dir in files) print dir, files[dir] }'
|
|
||||||
am__base_list = \
|
|
||||||
sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
|
|
||||||
sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
|
|
||||||
am__installdirs = "$(DESTDIR)$(pkgconfdir)"
|
|
||||||
DATA = $(pkgconf_DATA)
|
|
||||||
RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \
|
|
||||||
distclean-recursive maintainer-clean-recursive
|
|
||||||
AM_RECURSIVE_TARGETS = $(RECURSIVE_TARGETS:-recursive=) \
|
|
||||||
$(RECURSIVE_CLEAN_TARGETS:-recursive=) tags TAGS ctags CTAGS \
|
|
||||||
distdir dist dist-all distcheck
|
|
||||||
ETAGS = etags
|
|
||||||
CTAGS = ctags
|
|
||||||
DIST_SUBDIRS = $(SUBDIRS)
|
|
||||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
|
||||||
distdir = $(PACKAGE)-$(VERSION)
|
|
||||||
top_distdir = $(distdir)
|
|
||||||
am__remove_distdir = \
|
|
||||||
{ test ! -d "$(distdir)" \
|
|
||||||
|| { find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \
|
|
||||||
&& rm -fr "$(distdir)"; }; }
|
|
||||||
am__relativize = \
|
|
||||||
dir0=`pwd`; \
|
|
||||||
sed_first='s,^\([^/]*\)/.*$$,\1,'; \
|
|
||||||
sed_rest='s,^[^/]*/*,,'; \
|
|
||||||
sed_last='s,^.*/\([^/]*\)$$,\1,'; \
|
|
||||||
sed_butlast='s,/*[^/]*$$,,'; \
|
|
||||||
while test -n "$$dir1"; do \
|
|
||||||
first=`echo "$$dir1" | sed -e "$$sed_first"`; \
|
|
||||||
if test "$$first" != "."; then \
|
|
||||||
if test "$$first" = ".."; then \
|
|
||||||
dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \
|
|
||||||
dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \
|
|
||||||
else \
|
|
||||||
first2=`echo "$$dir2" | sed -e "$$sed_first"`; \
|
|
||||||
if test "$$first2" = "$$first"; then \
|
|
||||||
dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \
|
|
||||||
else \
|
|
||||||
dir2="../$$dir2"; \
|
|
||||||
fi; \
|
|
||||||
dir0="$$dir0"/"$$first"; \
|
|
||||||
fi; \
|
|
||||||
fi; \
|
|
||||||
dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \
|
|
||||||
done; \
|
|
||||||
reldir="$$dir2"
|
|
||||||
DIST_ARCHIVES = $(distdir).tar.gz
|
|
||||||
GZIP_ENV = --best
|
|
||||||
distuninstallcheck_listfiles = find . -type f -print
|
|
||||||
distcleancheck_listfiles = find . -type f -print
|
|
||||||
ACLOCAL = @ACLOCAL@
|
|
||||||
ALLOCA = @ALLOCA@
|
|
||||||
AMTAR = @AMTAR@
|
|
||||||
AR = @AR@
|
|
||||||
AS = @AS@
|
|
||||||
AUTOCONF = @AUTOCONF@
|
|
||||||
AUTOHEADER = @AUTOHEADER@
|
|
||||||
AUTOMAKE = @AUTOMAKE@
|
|
||||||
AWK = @AWK@
|
|
||||||
BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@
|
|
||||||
CATOBJEXT = @CATOBJEXT@
|
|
||||||
CC = @CC@
|
|
||||||
CCDEPMODE = @CCDEPMODE@
|
|
||||||
CFLAGS = @CFLAGS@
|
|
||||||
CFLAG_VISIBILITY = @CFLAG_VISIBILITY@
|
|
||||||
CPP = @CPP@
|
|
||||||
CPPFLAGS = @CPPFLAGS@
|
|
||||||
CURSESLIB = @CURSESLIB@
|
|
||||||
CXX = @CXX@
|
|
||||||
CXXCPP = @CXXCPP@
|
|
||||||
CXXDEPMODE = @CXXDEPMODE@
|
|
||||||
CXXFLAGS = @CXXFLAGS@
|
|
||||||
CYGPATH_W = @CYGPATH_W@
|
|
||||||
DATADIRNAME = @DATADIRNAME@
|
|
||||||
DEFS = @DEFS@
|
|
||||||
DEPDIR = @DEPDIR@
|
|
||||||
DLLTOOL = @DLLTOOL@
|
|
||||||
DSYMUTIL = @DSYMUTIL@
|
|
||||||
DUMPBIN = @DUMPBIN@
|
|
||||||
ECHO_C = @ECHO_C@
|
|
||||||
ECHO_N = @ECHO_N@
|
|
||||||
ECHO_T = @ECHO_T@
|
|
||||||
EGREP = @EGREP@
|
|
||||||
EXEEXT = @EXEEXT@
|
|
||||||
FGREP = @FGREP@
|
|
||||||
GENCAT = @GENCAT@
|
|
||||||
GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@
|
|
||||||
GLIBC2 = @GLIBC2@
|
|
||||||
GLIBC21 = @GLIBC21@
|
|
||||||
GMSGFMT = @GMSGFMT@
|
|
||||||
GMSGFMT_015 = @GMSGFMT_015@
|
|
||||||
GREP = @GREP@
|
|
||||||
HAVE_ASPRINTF = @HAVE_ASPRINTF@
|
|
||||||
HAVE_POSIX_PRINTF = @HAVE_POSIX_PRINTF@
|
|
||||||
HAVE_SNPRINTF = @HAVE_SNPRINTF@
|
|
||||||
HAVE_VISIBILITY = @HAVE_VISIBILITY@
|
|
||||||
HAVE_WPRINTF = @HAVE_WPRINTF@
|
|
||||||
HUNSPELL_VERSION_MAJOR = @HUNSPELL_VERSION_MAJOR@
|
|
||||||
HUNSPELL_VERSION_MINOR = @HUNSPELL_VERSION_MINOR@
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
|
||||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
|
||||||
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
|
||||||
INSTOBJEXT = @INSTOBJEXT@
|
|
||||||
INTLBISON = @INTLBISON@
|
|
||||||
INTLLIBS = @INTLLIBS@
|
|
||||||
INTLOBJS = @INTLOBJS@
|
|
||||||
INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@
|
|
||||||
INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@
|
|
||||||
LD = @LD@
|
|
||||||
LDFLAGS = @LDFLAGS@
|
|
||||||
LIBICONV = @LIBICONV@
|
|
||||||
LIBINTL = @LIBINTL@
|
|
||||||
LIBMULTITHREAD = @LIBMULTITHREAD@
|
|
||||||
LIBOBJS = @LIBOBJS@
|
|
||||||
LIBPTH = @LIBPTH@
|
|
||||||
LIBPTH_PREFIX = @LIBPTH_PREFIX@
|
|
||||||
LIBS = @LIBS@
|
|
||||||
LIBTHREAD = @LIBTHREAD@
|
|
||||||
LIBTOOL = @LIBTOOL@
|
|
||||||
LIPO = @LIPO@
|
|
||||||
LN_S = @LN_S@
|
|
||||||
LTLIBC = @LTLIBC@
|
|
||||||
LTLIBICONV = @LTLIBICONV@
|
|
||||||
LTLIBINTL = @LTLIBINTL@
|
|
||||||
LTLIBMULTITHREAD = @LTLIBMULTITHREAD@
|
|
||||||
LTLIBOBJS = @LTLIBOBJS@
|
|
||||||
LTLIBPTH = @LTLIBPTH@
|
|
||||||
LTLIBTHREAD = @LTLIBTHREAD@
|
|
||||||
MAKEINFO = @MAKEINFO@
|
|
||||||
MKDIR_P = @MKDIR_P@
|
|
||||||
MSGFMT = @MSGFMT@
|
|
||||||
MSGFMT_015 = @MSGFMT_015@
|
|
||||||
MSGMERGE = @MSGMERGE@
|
|
||||||
NM = @NM@
|
|
||||||
NMEDIT = @NMEDIT@
|
|
||||||
OBJDUMP = @OBJDUMP@
|
|
||||||
OBJEXT = @OBJEXT@
|
|
||||||
OTOOL = @OTOOL@
|
|
||||||
OTOOL64 = @OTOOL64@
|
|
||||||
PACKAGE = @PACKAGE@
|
|
||||||
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
|
||||||
PACKAGE_NAME = @PACKAGE_NAME@
|
|
||||||
PACKAGE_STRING = @PACKAGE_STRING@
|
|
||||||
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
|
||||||
PACKAGE_URL = @PACKAGE_URL@
|
|
||||||
PACKAGE_VERSION = @PACKAGE_VERSION@
|
|
||||||
PATH_SEPARATOR = @PATH_SEPARATOR@
|
|
||||||
POSUB = @POSUB@
|
|
||||||
PRI_MACROS_BROKEN = @PRI_MACROS_BROKEN@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
READLINELIB = @READLINELIB@
|
|
||||||
SED = @SED@
|
|
||||||
SET_MAKE = @SET_MAKE@
|
|
||||||
SHELL = @SHELL@
|
|
||||||
STRIP = @STRIP@
|
|
||||||
USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@
|
|
||||||
USE_NLS = @USE_NLS@
|
|
||||||
VERSION = @VERSION@
|
|
||||||
WINDRES = @WINDRES@
|
|
||||||
WOE32 = @WOE32@
|
|
||||||
WOE32DLL = @WOE32DLL@
|
|
||||||
XFAILED = @XFAILED@
|
|
||||||
XGETTEXT = @XGETTEXT@
|
|
||||||
XGETTEXT_015 = @XGETTEXT_015@
|
|
||||||
XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@
|
|
||||||
abs_builddir = @abs_builddir@
|
|
||||||
abs_srcdir = @abs_srcdir@
|
|
||||||
abs_top_builddir = @abs_top_builddir@
|
|
||||||
abs_top_srcdir = @abs_top_srcdir@
|
|
||||||
ac_ct_CC = @ac_ct_CC@
|
|
||||||
ac_ct_CXX = @ac_ct_CXX@
|
|
||||||
ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
|
|
||||||
am__include = @am__include@
|
|
||||||
am__leading_dot = @am__leading_dot@
|
|
||||||
am__quote = @am__quote@
|
|
||||||
am__tar = @am__tar@
|
|
||||||
am__untar = @am__untar@
|
|
||||||
bindir = @bindir@
|
|
||||||
build = @build@
|
|
||||||
build_alias = @build_alias@
|
|
||||||
build_cpu = @build_cpu@
|
|
||||||
build_os = @build_os@
|
|
||||||
build_vendor = @build_vendor@
|
|
||||||
builddir = @builddir@
|
|
||||||
datadir = @datadir@
|
|
||||||
datarootdir = @datarootdir@
|
|
||||||
docdir = @docdir@
|
|
||||||
dvidir = @dvidir@
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
host = @host@
|
|
||||||
host_alias = @host_alias@
|
|
||||||
host_cpu = @host_cpu@
|
|
||||||
host_os = @host_os@
|
|
||||||
host_vendor = @host_vendor@
|
|
||||||
htmldir = @htmldir@
|
|
||||||
includedir = @includedir@
|
|
||||||
infodir = @infodir@
|
|
||||||
install_sh = @install_sh@
|
|
||||||
libdir = @libdir@
|
|
||||||
libexecdir = @libexecdir@
|
|
||||||
localedir = @localedir@
|
|
||||||
localstatedir = @localstatedir@
|
|
||||||
lt_ECHO = @lt_ECHO@
|
|
||||||
mandir = @mandir@
|
|
||||||
mkdir_p = @mkdir_p@
|
|
||||||
oldincludedir = @oldincludedir@
|
|
||||||
pdfdir = @pdfdir@
|
|
||||||
prefix = @prefix@
|
|
||||||
program_transform_name = @program_transform_name@
|
|
||||||
psdir = @psdir@
|
|
||||||
sbindir = @sbindir@
|
|
||||||
sharedstatedir = @sharedstatedir@
|
|
||||||
srcdir = @srcdir@
|
|
||||||
sysconfdir = @sysconfdir@
|
|
||||||
target = @target@
|
|
||||||
target_alias = @target_alias@
|
|
||||||
target_cpu = @target_cpu@
|
|
||||||
target_os = @target_os@
|
|
||||||
target_vendor = @target_vendor@
|
|
||||||
top_build_prefix = @top_build_prefix@
|
|
||||||
top_builddir = @top_builddir@
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
ACLOCAL_AMFLAGS = -I m4
|
|
||||||
SUBDIRS = intl po src man m4 tests
|
|
||||||
pkgconfdir = $(libdir)/pkgconfig
|
|
||||||
pkgconf_DATA = hunspell.pc
|
|
||||||
EXTRA_DIST = BUGS README.myspell AUTHORS.myspell license.myspell license.hunspell \
|
|
||||||
ChangeLog.O COPYING.MPL COPYING.LGPL hunspell.pc.in
|
|
||||||
|
|
||||||
all: config.h
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) all-recursive
|
|
||||||
|
|
||||||
.SUFFIXES:
|
|
||||||
am--refresh:
|
|
||||||
@:
|
|
||||||
$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
|
|
||||||
@for dep in $?; do \
|
|
||||||
case '$(am__configure_deps)' in \
|
|
||||||
*$$dep*) \
|
|
||||||
echo ' cd $(srcdir) && $(AUTOMAKE) --gnu'; \
|
|
||||||
$(am__cd) $(srcdir) && $(AUTOMAKE) --gnu \
|
|
||||||
&& exit 0; \
|
|
||||||
exit 1;; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile'; \
|
|
||||||
$(am__cd) $(top_srcdir) && \
|
|
||||||
$(AUTOMAKE) --gnu Makefile
|
|
||||||
.PRECIOUS: Makefile
|
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
||||||
@case '$?' in \
|
|
||||||
*config.status*) \
|
|
||||||
echo ' $(SHELL) ./config.status'; \
|
|
||||||
$(SHELL) ./config.status;; \
|
|
||||||
*) \
|
|
||||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
|
|
||||||
esac;
|
|
||||||
|
|
||||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
|
||||||
$(SHELL) ./config.status --recheck
|
|
||||||
|
|
||||||
$(top_srcdir)/configure: $(am__configure_deps)
|
|
||||||
$(am__cd) $(srcdir) && $(AUTOCONF)
|
|
||||||
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
|
|
||||||
$(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS)
|
|
||||||
$(am__aclocal_m4_deps):
|
|
||||||
|
|
||||||
config.h: stamp-h1
|
|
||||||
@if test ! -f $@; then \
|
|
||||||
rm -f stamp-h1; \
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) stamp-h1; \
|
|
||||||
else :; fi
|
|
||||||
|
|
||||||
stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status
|
|
||||||
@rm -f stamp-h1
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status config.h
|
|
||||||
$(srcdir)/config.h.in: $(am__configure_deps)
|
|
||||||
($(am__cd) $(top_srcdir) && $(AUTOHEADER))
|
|
||||||
rm -f stamp-h1
|
|
||||||
touch $@
|
|
||||||
|
|
||||||
distclean-hdr:
|
|
||||||
-rm -f config.h stamp-h1
|
|
||||||
hunspell.pc: $(top_builddir)/config.status $(srcdir)/hunspell.pc.in
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $@
|
|
||||||
intl/Makefile: $(top_builddir)/config.status $(top_srcdir)/intl/Makefile.in
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $@
|
|
||||||
|
|
||||||
mostlyclean-libtool:
|
|
||||||
-rm -f *.lo
|
|
||||||
|
|
||||||
clean-libtool:
|
|
||||||
-rm -rf .libs _libs
|
|
||||||
|
|
||||||
distclean-libtool:
|
|
||||||
-rm -f libtool config.lt
|
|
||||||
install-pkgconfDATA: $(pkgconf_DATA)
|
|
||||||
@$(NORMAL_INSTALL)
|
|
||||||
test -z "$(pkgconfdir)" || $(MKDIR_P) "$(DESTDIR)$(pkgconfdir)"
|
|
||||||
@list='$(pkgconf_DATA)'; test -n "$(pkgconfdir)" || list=; \
|
|
||||||
for p in $$list; do \
|
|
||||||
if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
|
|
||||||
echo "$$d$$p"; \
|
|
||||||
done | $(am__base_list) | \
|
|
||||||
while read files; do \
|
|
||||||
echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfdir)'"; \
|
|
||||||
$(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfdir)" || exit $$?; \
|
|
||||||
done
|
|
||||||
|
|
||||||
uninstall-pkgconfDATA:
|
|
||||||
@$(NORMAL_UNINSTALL)
|
|
||||||
@list='$(pkgconf_DATA)'; test -n "$(pkgconfdir)" || list=; \
|
|
||||||
files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
|
|
||||||
test -n "$$files" || exit 0; \
|
|
||||||
echo " ( cd '$(DESTDIR)$(pkgconfdir)' && rm -f" $$files ")"; \
|
|
||||||
cd "$(DESTDIR)$(pkgconfdir)" && rm -f $$files
|
|
||||||
|
|
||||||
# This directory's subdirectories are mostly independent; you can cd
|
|
||||||
# into them and run `make' without going through this Makefile.
|
|
||||||
# To change the values of `make' variables: instead of editing Makefiles,
|
|
||||||
# (1) if the variable is set in `config.status', edit `config.status'
|
|
||||||
# (which will cause the Makefiles to be regenerated when you run `make');
|
|
||||||
# (2) otherwise, pass the desired values on the `make' command line.
|
|
||||||
$(RECURSIVE_TARGETS):
|
|
||||||
@fail= failcom='exit 1'; \
|
|
||||||
for f in x $$MAKEFLAGS; do \
|
|
||||||
case $$f in \
|
|
||||||
*=* | --[!k]*);; \
|
|
||||||
*k*) failcom='fail=yes';; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
dot_seen=no; \
|
|
||||||
target=`echo $@ | sed s/-recursive//`; \
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
echo "Making $$target in $$subdir"; \
|
|
||||||
if test "$$subdir" = "."; then \
|
|
||||||
dot_seen=yes; \
|
|
||||||
local_target="$$target-am"; \
|
|
||||||
else \
|
|
||||||
local_target="$$target"; \
|
|
||||||
fi; \
|
|
||||||
($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
|
||||||
|| eval $$failcom; \
|
|
||||||
done; \
|
|
||||||
if test "$$dot_seen" = "no"; then \
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
|
|
||||||
fi; test -z "$$fail"
|
|
||||||
|
|
||||||
$(RECURSIVE_CLEAN_TARGETS):
|
|
||||||
@fail= failcom='exit 1'; \
|
|
||||||
for f in x $$MAKEFLAGS; do \
|
|
||||||
case $$f in \
|
|
||||||
*=* | --[!k]*);; \
|
|
||||||
*k*) failcom='fail=yes';; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
dot_seen=no; \
|
|
||||||
case "$@" in \
|
|
||||||
distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
|
|
||||||
*) list='$(SUBDIRS)' ;; \
|
|
||||||
esac; \
|
|
||||||
rev=''; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = "."; then :; else \
|
|
||||||
rev="$$subdir $$rev"; \
|
|
||||||
fi; \
|
|
||||||
done; \
|
|
||||||
rev="$$rev ."; \
|
|
||||||
target=`echo $@ | sed s/-recursive//`; \
|
|
||||||
for subdir in $$rev; do \
|
|
||||||
echo "Making $$target in $$subdir"; \
|
|
||||||
if test "$$subdir" = "."; then \
|
|
||||||
local_target="$$target-am"; \
|
|
||||||
else \
|
|
||||||
local_target="$$target"; \
|
|
||||||
fi; \
|
|
||||||
($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
|
||||||
|| eval $$failcom; \
|
|
||||||
done && test -z "$$fail"
|
|
||||||
tags-recursive:
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
test "$$subdir" = . || ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \
|
|
||||||
done
|
|
||||||
ctags-recursive:
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
test "$$subdir" = . || ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \
|
|
||||||
done
|
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
|
||||||
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
|
||||||
mkid -fID $$unique
|
|
||||||
tags: TAGS
|
|
||||||
|
|
||||||
TAGS: tags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
set x; \
|
|
||||||
here=`pwd`; \
|
|
||||||
if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \
|
|
||||||
include_option=--etags-include; \
|
|
||||||
empty_fix=.; \
|
|
||||||
else \
|
|
||||||
include_option=--include; \
|
|
||||||
empty_fix=; \
|
|
||||||
fi; \
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = .; then :; else \
|
|
||||||
test ! -f $$subdir/TAGS || \
|
|
||||||
set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \
|
|
||||||
fi; \
|
|
||||||
done; \
|
|
||||||
list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
|
||||||
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
|
||||||
shift; \
|
|
||||||
if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
|
|
||||||
test -n "$$unique" || unique=$$empty_fix; \
|
|
||||||
if test $$# -gt 0; then \
|
|
||||||
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
|
||||||
"$$@" $$unique; \
|
|
||||||
else \
|
|
||||||
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
|
||||||
$$unique; \
|
|
||||||
fi; \
|
|
||||||
fi
|
|
||||||
ctags: CTAGS
|
|
||||||
CTAGS: ctags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) '{ files[$$0] = 1; nonempty = 1; } \
|
|
||||||
END { if (nonempty) { for (i in files) print i; }; }'`; \
|
|
||||||
test -z "$(CTAGS_ARGS)$$unique" \
|
|
||||||
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
|
||||||
$$unique
|
|
||||||
|
|
||||||
GTAGS:
|
|
||||||
here=`$(am__cd) $(top_builddir) && pwd` \
|
|
||||||
&& $(am__cd) $(top_srcdir) \
|
|
||||||
&& gtags -i $(GTAGS_ARGS) "$$here"
|
|
||||||
|
|
||||||
distclean-tags:
|
|
||||||
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
|
||||||
|
|
||||||
distdir: $(DISTFILES)
|
|
||||||
$(am__remove_distdir)
|
|
||||||
test -d "$(distdir)" || mkdir "$(distdir)"
|
|
||||||
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
|
||||||
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
|
||||||
list='$(DISTFILES)'; \
|
|
||||||
dist_files=`for file in $$list; do echo $$file; done | \
|
|
||||||
sed -e "s|^$$srcdirstrip/||;t" \
|
|
||||||
-e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
|
|
||||||
case $$dist_files in \
|
|
||||||
*/*) $(MKDIR_P) `echo "$$dist_files" | \
|
|
||||||
sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
|
|
||||||
sort -u` ;; \
|
|
||||||
esac; \
|
|
||||||
for file in $$dist_files; do \
|
|
||||||
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
|
||||||
if test -d $$d/$$file; then \
|
|
||||||
dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
|
|
||||||
if test -d "$(distdir)/$$file"; then \
|
|
||||||
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
|
|
||||||
fi; \
|
|
||||||
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
|
||||||
cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
|
|
||||||
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
|
|
||||||
fi; \
|
|
||||||
cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
|
|
||||||
else \
|
|
||||||
test -f "$(distdir)/$$file" \
|
|
||||||
|| cp -p $$d/$$file "$(distdir)/$$file" \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
@list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = .; then :; else \
|
|
||||||
test -d "$(distdir)/$$subdir" \
|
|
||||||
|| $(MKDIR_P) "$(distdir)/$$subdir" \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
@list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = .; then :; else \
|
|
||||||
dir1=$$subdir; dir2="$(distdir)/$$subdir"; \
|
|
||||||
$(am__relativize); \
|
|
||||||
new_distdir=$$reldir; \
|
|
||||||
dir1=$$subdir; dir2="$(top_distdir)"; \
|
|
||||||
$(am__relativize); \
|
|
||||||
new_top_distdir=$$reldir; \
|
|
||||||
echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \
|
|
||||||
echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \
|
|
||||||
($(am__cd) $$subdir && \
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) \
|
|
||||||
top_distdir="$$new_top_distdir" \
|
|
||||||
distdir="$$new_distdir" \
|
|
||||||
am__remove_distdir=: \
|
|
||||||
am__skip_length_check=: \
|
|
||||||
am__skip_mode_fix=: \
|
|
||||||
distdir) \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
-test -n "$(am__skip_mode_fix)" \
|
|
||||||
|| find "$(distdir)" -type d ! -perm -755 \
|
|
||||||
-exec chmod u+rwx,go+rx {} \; -o \
|
|
||||||
! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
|
|
||||||
! -type d ! -perm -400 -exec chmod a+r {} \; -o \
|
|
||||||
! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \
|
|
||||||
|| chmod -R a+r "$(distdir)"
|
|
||||||
dist-gzip: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-bzip2: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | bzip2 -9 -c >$(distdir).tar.bz2
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-lzma: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | lzma -9 -c >$(distdir).tar.lzma
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-xz: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | xz -c >$(distdir).tar.xz
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-tarZ: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-shar: distdir
|
|
||||||
shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-zip: distdir
|
|
||||||
-rm -f $(distdir).zip
|
|
||||||
zip -rq $(distdir).zip $(distdir)
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist dist-all: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
# This target untars the dist file and tries a VPATH configuration. Then
|
|
||||||
# it guarantees that the distribution is self-contained by making another
|
|
||||||
# tarfile.
|
|
||||||
distcheck: dist
|
|
||||||
case '$(DIST_ARCHIVES)' in \
|
|
||||||
*.tar.gz*) \
|
|
||||||
GZIP=$(GZIP_ENV) gzip -dc $(distdir).tar.gz | $(am__untar) ;;\
|
|
||||||
*.tar.bz2*) \
|
|
||||||
bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\
|
|
||||||
*.tar.lzma*) \
|
|
||||||
lzma -dc $(distdir).tar.lzma | $(am__untar) ;;\
|
|
||||||
*.tar.xz*) \
|
|
||||||
xz -dc $(distdir).tar.xz | $(am__untar) ;;\
|
|
||||||
*.tar.Z*) \
|
|
||||||
uncompress -c $(distdir).tar.Z | $(am__untar) ;;\
|
|
||||||
*.shar.gz*) \
|
|
||||||
GZIP=$(GZIP_ENV) gzip -dc $(distdir).shar.gz | unshar ;;\
|
|
||||||
*.zip*) \
|
|
||||||
unzip $(distdir).zip ;;\
|
|
||||||
esac
|
|
||||||
chmod -R a-w $(distdir); chmod a+w $(distdir)
|
|
||||||
mkdir $(distdir)/_build
|
|
||||||
mkdir $(distdir)/_inst
|
|
||||||
chmod a-w $(distdir)
|
|
||||||
test -d $(distdir)/_build || exit 0; \
|
|
||||||
dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \
|
|
||||||
&& dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \
|
|
||||||
&& am__cwd=`pwd` \
|
|
||||||
&& $(am__cd) $(distdir)/_build \
|
|
||||||
&& ../configure --srcdir=.. --prefix="$$dc_install_base" \
|
|
||||||
--with-included-gettext \
|
|
||||||
$(DISTCHECK_CONFIGURE_FLAGS) \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) dvi \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) check \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) install \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) installcheck \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) uninstall \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \
|
|
||||||
distuninstallcheck \
|
|
||||||
&& chmod -R a-w "$$dc_install_base" \
|
|
||||||
&& ({ \
|
|
||||||
(cd ../.. && umask 077 && mkdir "$$dc_destdir") \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \
|
|
||||||
distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \
|
|
||||||
} || { rm -rf "$$dc_destdir"; exit 1; }) \
|
|
||||||
&& rm -rf "$$dc_destdir" \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) dist \
|
|
||||||
&& rm -rf $(DIST_ARCHIVES) \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) distcleancheck \
|
|
||||||
&& cd "$$am__cwd" \
|
|
||||||
|| exit 1
|
|
||||||
$(am__remove_distdir)
|
|
||||||
@(echo "$(distdir) archives ready for distribution: "; \
|
|
||||||
list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \
|
|
||||||
sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x'
|
|
||||||
distuninstallcheck:
|
|
||||||
@$(am__cd) '$(distuninstallcheck_dir)' \
|
|
||||||
&& test `$(distuninstallcheck_listfiles) | wc -l` -le 1 \
|
|
||||||
|| { echo "ERROR: files left after uninstall:" ; \
|
|
||||||
if test -n "$(DESTDIR)"; then \
|
|
||||||
echo " (check DESTDIR support)"; \
|
|
||||||
fi ; \
|
|
||||||
$(distuninstallcheck_listfiles) ; \
|
|
||||||
exit 1; } >&2
|
|
||||||
distcleancheck: distclean
|
|
||||||
@if test '$(srcdir)' = . ; then \
|
|
||||||
echo "ERROR: distcleancheck can only run from a VPATH build" ; \
|
|
||||||
exit 1 ; \
|
|
||||||
fi
|
|
||||||
@test `$(distcleancheck_listfiles) | wc -l` -eq 0 \
|
|
||||||
|| { echo "ERROR: files left in build directory after distclean:" ; \
|
|
||||||
$(distcleancheck_listfiles) ; \
|
|
||||||
exit 1; } >&2
|
|
||||||
check-am: all-am
|
|
||||||
check: check-recursive
|
|
||||||
all-am: Makefile $(DATA) config.h
|
|
||||||
installdirs: installdirs-recursive
|
|
||||||
installdirs-am:
|
|
||||||
for dir in "$(DESTDIR)$(pkgconfdir)"; do \
|
|
||||||
test -z "$$dir" || $(MKDIR_P) "$$dir"; \
|
|
||||||
done
|
|
||||||
install: install-recursive
|
|
||||||
install-exec: install-exec-recursive
|
|
||||||
install-data: install-data-recursive
|
|
||||||
uninstall: uninstall-recursive
|
|
||||||
|
|
||||||
install-am: all-am
|
|
||||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
|
||||||
|
|
||||||
installcheck: installcheck-recursive
|
|
||||||
install-strip:
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
|
||||||
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
|
||||||
`test -z '$(STRIP)' || \
|
|
||||||
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
|
||||||
mostlyclean-generic:
|
|
||||||
|
|
||||||
clean-generic:
|
|
||||||
|
|
||||||
distclean-generic:
|
|
||||||
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
|
||||||
-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
|
|
||||||
|
|
||||||
maintainer-clean-generic:
|
|
||||||
@echo "This command is intended for maintainers to use"
|
|
||||||
@echo "it deletes files that may require special tools to rebuild."
|
|
||||||
clean: clean-recursive
|
|
||||||
|
|
||||||
clean-am: clean-generic clean-libtool mostlyclean-am
|
|
||||||
|
|
||||||
distclean: distclean-recursive
|
|
||||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
|
||||||
-rm -f Makefile
|
|
||||||
distclean-am: clean-am distclean-generic distclean-hdr \
|
|
||||||
distclean-libtool distclean-tags
|
|
||||||
|
|
||||||
dvi: dvi-recursive
|
|
||||||
|
|
||||||
dvi-am:
|
|
||||||
|
|
||||||
html: html-recursive
|
|
||||||
|
|
||||||
html-am:
|
|
||||||
|
|
||||||
info: info-recursive
|
|
||||||
|
|
||||||
info-am:
|
|
||||||
|
|
||||||
install-data-am: install-pkgconfDATA
|
|
||||||
|
|
||||||
install-dvi: install-dvi-recursive
|
|
||||||
|
|
||||||
install-dvi-am:
|
|
||||||
|
|
||||||
install-exec-am:
|
|
||||||
|
|
||||||
install-html: install-html-recursive
|
|
||||||
|
|
||||||
install-html-am:
|
|
||||||
|
|
||||||
install-info: install-info-recursive
|
|
||||||
|
|
||||||
install-info-am:
|
|
||||||
|
|
||||||
install-man:
|
|
||||||
|
|
||||||
install-pdf: install-pdf-recursive
|
|
||||||
|
|
||||||
install-pdf-am:
|
|
||||||
|
|
||||||
install-ps: install-ps-recursive
|
|
||||||
|
|
||||||
install-ps-am:
|
|
||||||
|
|
||||||
installcheck-am:
|
|
||||||
|
|
||||||
maintainer-clean: maintainer-clean-recursive
|
|
||||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
|
||||||
-rm -rf $(top_srcdir)/autom4te.cache
|
|
||||||
-rm -f Makefile
|
|
||||||
maintainer-clean-am: distclean-am maintainer-clean-generic
|
|
||||||
|
|
||||||
mostlyclean: mostlyclean-recursive
|
|
||||||
|
|
||||||
mostlyclean-am: mostlyclean-generic mostlyclean-libtool
|
|
||||||
|
|
||||||
pdf: pdf-recursive
|
|
||||||
|
|
||||||
pdf-am:
|
|
||||||
|
|
||||||
ps: ps-recursive
|
|
||||||
|
|
||||||
ps-am:
|
|
||||||
|
|
||||||
uninstall-am: uninstall-pkgconfDATA
|
|
||||||
|
|
||||||
.MAKE: $(RECURSIVE_CLEAN_TARGETS) $(RECURSIVE_TARGETS) all \
|
|
||||||
ctags-recursive install-am install-strip tags-recursive
|
|
||||||
|
|
||||||
.PHONY: $(RECURSIVE_CLEAN_TARGETS) $(RECURSIVE_TARGETS) CTAGS GTAGS \
|
|
||||||
all all-am am--refresh check check-am clean clean-generic \
|
|
||||||
clean-libtool ctags ctags-recursive dist dist-all dist-bzip2 \
|
|
||||||
dist-gzip dist-lzma dist-shar dist-tarZ dist-xz dist-zip \
|
|
||||||
distcheck distclean distclean-generic distclean-hdr \
|
|
||||||
distclean-libtool distclean-tags distcleancheck distdir \
|
|
||||||
distuninstallcheck dvi dvi-am html html-am info info-am \
|
|
||||||
install install-am install-data install-data-am install-dvi \
|
|
||||||
install-dvi-am install-exec install-exec-am install-html \
|
|
||||||
install-html-am install-info install-info-am install-man \
|
|
||||||
install-pdf install-pdf-am install-pkgconfDATA install-ps \
|
|
||||||
install-ps-am install-strip installcheck installcheck-am \
|
|
||||||
installdirs installdirs-am maintainer-clean \
|
|
||||||
maintainer-clean-generic mostlyclean mostlyclean-generic \
|
|
||||||
mostlyclean-libtool pdf pdf-am ps ps-am tags tags-recursive \
|
|
||||||
uninstall uninstall-am uninstall-pkgconfDATA
|
|
||||||
|
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
|
||||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
||||||
.NOEXPORT:
|
|
|
@ -1,646 +0,0 @@
|
||||||
2011-02-02: Hunspell 1.3.2 release:
|
|
||||||
- fix library versioning
|
|
||||||
- improved manual
|
|
||||||
|
|
||||||
2011-02-02: Hunspell 1.3.1 release:
|
|
||||||
- bug fixes
|
|
||||||
|
|
||||||
2011-01-26: Hunspell 1.2.15/1.3 release:
|
|
||||||
- new features: MAXDIFF, ONLYMAXDIFF, MAXCPDSUGS, FORBIDWARN, see manual
|
|
||||||
- bug fixes
|
|
||||||
|
|
||||||
2011-01-21:
|
|
||||||
- new features: FORCEUCASE and WARN, see manual
|
|
||||||
- new options: -r to filter potential mistakes (rare words
|
|
||||||
signed by flag WARN in the dictionary)
|
|
||||||
- limited and optimized suggestions
|
|
||||||
|
|
||||||
2011-01-06: Hunspell 1.2.14 release:
|
|
||||||
- bug fix
|
|
||||||
2011-01-03: Hunspell 1.2.13 release:
|
|
||||||
- bug fixes
|
|
||||||
- improved compound handling and
|
|
||||||
other improvements supported by OpenTaal Foundation, Netherlands
|
|
||||||
2010-07-15: Hunspell 1.2.12 release
|
|
||||||
2010-05-06: Hunspell 1.2.11 release:
|
|
||||||
- Maintenance release bug fixes
|
|
||||||
2010-04-30: Hunspell 1.2.10 release:
|
|
||||||
- Maintenance release bug fixes
|
|
||||||
2010-03-03: Hunspell 1.2.9 release:
|
|
||||||
- Maintenance release bug fixes and warnings
|
|
||||||
- MAP support for composed characters or character sequences
|
|
||||||
2008-11-01: Hunspell 1.2.8 release:
|
|
||||||
- Default BREAK feature and better hyphenated word suggestion to accept
|
|
||||||
and fix (compound) words with hyphen characters by spell checker
|
|
||||||
instead of by work breaking code of OpenOffice.org. With this feature
|
|
||||||
it's possible to accept hyphenated compound words, such as "scot-free",
|
|
||||||
where "scot" is not a correct English word.
|
|
||||||
|
|
||||||
- ICONV & OCONV: input and output conversion tables for optional character
|
|
||||||
handling or using special inner format. Example:
|
|
||||||
|
|
||||||
# Accepting de facto replacements of the Romanian comma acuted letters
|
|
||||||
SET UTF-8
|
|
||||||
ICONV 4
|
|
||||||
ICONV ÅŸ È™
|
|
||||||
ICONV ţ ț
|
|
||||||
ICONV Ş Ș
|
|
||||||
ICONV Ţ Ț
|
|
||||||
|
|
||||||
Typical usage of ICONV/OCONV is to manage an inner format for a segmental
|
|
||||||
writing system, like the Ethiopic script of the Amharic language.
|
|
||||||
|
|
||||||
- Extended CHECKCOMPOUNDPATTERN to handle conpound word alternations, like
|
|
||||||
sandhi feature of Telugu and other writing systems.
|
|
||||||
|
|
||||||
- SIMPLIFIEDTRIPLE compound word feature: allow simplified Swedish and
|
|
||||||
Norwegian compound word forms, like tillåta (till|låta) and
|
|
||||||
bussjåfør (buss|sjåfør)
|
|
||||||
|
|
||||||
- wordforms: word generator script for dictionary developers (Hunspell
|
|
||||||
version of unmunch).
|
|
||||||
|
|
||||||
- bug fixes
|
|
||||||
|
|
||||||
2008-08-15: Hunspell 1.2.7 release:
|
|
||||||
- FULLSTRIP: new option for affix handling. With FULLSTRIP, affix rules can
|
|
||||||
strip full words, not only one less characters.
|
|
||||||
- COMPOUNDRULE works with all flag types. (COMPOUNDRULE is for pattern
|
|
||||||
matching. For example, en_US dictionary of OpenOffice.org uses COMPOUNDRULE
|
|
||||||
for ordinal number recognition: 1st, 2nd, 11th, 12th, 22nd, 112th, 1000122nd
|
|
||||||
etc.).
|
|
||||||
- optimized suggestions:
|
|
||||||
- modified 1-character distance suggestion algorithms: search a TRY character
|
|
||||||
in all position instead of all TRY characters in a character position
|
|
||||||
(it can give more readable suggestion order, also better suggestions
|
|
||||||
in the first positions, when TRY characters are sorted by frequency.)
|
|
||||||
For example, suggestions for "moze":
|
|
||||||
ooze, doze, Roze, maze, more etc. (Hunspell 1.2.6),
|
|
||||||
maze, more, mote, ooze, mole etc. (Hunspell 1.2.7).
|
|
||||||
- extended compound word checking for better COMPOUNDRULE related
|
|
||||||
suggestions, for example English ordinal numbers: 121323th -> 121323rd
|
|
||||||
(it needs also a th->rd REP definition).
|
|
||||||
- bug fixes
|
|
||||||
|
|
||||||
2008-07-15: Hunspell 1.2.6 release:
|
|
||||||
- bug fix release (fix affix rule condition checking of sk_SK dictionary,
|
|
||||||
iconv support in stemming and morphological analysis of the Hunspell
|
|
||||||
utility, see also Changelog)
|
|
||||||
|
|
||||||
2008-07-09: Hunspell 1.2.5 release:
|
|
||||||
- bug fix release (fix affix rule condition checking of en_GB dictionary,
|
|
||||||
also morphological analysis by dictionaries with two-level suffixes)
|
|
||||||
|
|
||||||
2008-06-18: Hunspell 1.2.4-2 release:
|
|
||||||
- fix GCC compiler warnings
|
|
||||||
|
|
||||||
2008-06-17: Hunspell 1.2.4 release:
|
|
||||||
- add free_list() for C, C++ interfaces to deallocate suggestion lists
|
|
||||||
|
|
||||||
- bug fixes
|
|
||||||
|
|
||||||
2008-06-17: Hunspell 1.2.3 release:
|
|
||||||
- extended XML interface to use morphological functions by standard
|
|
||||||
spell checking interface, spell() and suggest(). See hunspell.3 manual page.
|
|
||||||
|
|
||||||
- default dash suggestions for compound words: newword-> new word and new-word
|
|
||||||
|
|
||||||
- new manual pages: hunspell.3, hzip.1, hunzip.1.
|
|
||||||
|
|
||||||
- bug fixes
|
|
||||||
|
|
||||||
2008-04-12: Hunspell 1.2.2 release:
|
|
||||||
- extended dictionary (dic file) support to use multiple base and
|
|
||||||
special dictionaries.
|
|
||||||
|
|
||||||
- new and improved options of command line hunspell:
|
|
||||||
-m: morphological analysis or flag debug mode (without affix
|
|
||||||
rule data it signs the flag of the affix rules)
|
|
||||||
-s: stemming mode
|
|
||||||
-D: list available dictionaries and search path
|
|
||||||
-d: support extra dictionaries by comma separated list. Example:
|
|
||||||
|
|
||||||
hunspell -d en_US,en_med,de_DE,de_med,de_geo UNESCO.txt
|
|
||||||
|
|
||||||
- forbidding in personal dictionary (with asterisk, / signs affixation)
|
|
||||||
|
|
||||||
- optional compressed dictionary format "hzip" for aff and dic files
|
|
||||||
usage:
|
|
||||||
hzip example.aff example.dic
|
|
||||||
mv example.aff example.dic /tmp
|
|
||||||
hunspell -d example
|
|
||||||
hunzip example.aff.hz >example.aff
|
|
||||||
hunzip example.dic.hz >example.dic
|
|
||||||
|
|
||||||
- new affix compression tool "affixcompress": compression tool for
|
|
||||||
large (millions of words) dictionaries.
|
|
||||||
|
|
||||||
- support encrypted dictionaries for closed OpenOffice.org extensions or
|
|
||||||
other commercial programs
|
|
||||||
|
|
||||||
- improved manual
|
|
||||||
|
|
||||||
- bug fixes
|
|
||||||
|
|
||||||
2007-11-01: Hunspell 1.2.1 release:
|
|
||||||
- new memory efficient condition checking algorithm for affix rules
|
|
||||||
|
|
||||||
- new morphological functions:
|
|
||||||
- stem() for stemming
|
|
||||||
- analyze() for morphological analysis
|
|
||||||
- generate() for morphological generation
|
|
||||||
|
|
||||||
- new demos:
|
|
||||||
- analyze: stemming, morphological analysis and generation
|
|
||||||
- chmorph: morphological conversion of texts
|
|
||||||
|
|
||||||
2007-09-05: Hunspell 1.1.12 release:
|
|
||||||
- dictionary based phonetic suggestion for words with
|
|
||||||
special or foreign pronounciation or alternative (bad) transliteration
|
|
||||||
(see Changelog, tests/phone.* and manual).
|
|
||||||
|
|
||||||
- improved data structure and memory optimization for dictionaries
|
|
||||||
with variable count fields
|
|
||||||
|
|
||||||
- bug fixes for Unicode encoding dictionaries and ngram suggestions
|
|
||||||
|
|
||||||
- improved REP suggestions with space: it works without dictionary
|
|
||||||
modification
|
|
||||||
|
|
||||||
- updated and new project files for Windows API
|
|
||||||
|
|
||||||
2007-08-27: Hunspell 1.1.11 release:
|
|
||||||
- portability fixes
|
|
||||||
|
|
||||||
2007-08-23: Hunspell 1.1.10 release:
|
|
||||||
- pronounciation based suggestion using Björn Jacke's original Aspell
|
|
||||||
phonetic transcription algorithm (http://aspell.net), relicensed under
|
|
||||||
GPL/LGPL/MPL tri-license with the permission of the author
|
|
||||||
|
|
||||||
- keyboard base suggestion by KEY (see manual)
|
|
||||||
|
|
||||||
- better time limits for suggestion search
|
|
||||||
|
|
||||||
- test environment for suggestion based on Wikipedia data
|
|
||||||
|
|
||||||
- bug fixes for non standard Mozilla platforms etc.
|
|
||||||
|
|
||||||
2007-07-25: Hunspell 1.1.9 release:
|
|
||||||
- better tokenization:
|
|
||||||
- for URLs, mail addresses and directory paths (default: skip these tokens)
|
|
||||||
- for colons in words (for Finnish and Swedish)
|
|
||||||
|
|
||||||
- new examples:
|
|
||||||
- affixation of personal dictionary words
|
|
||||||
- digits in words
|
|
||||||
|
|
||||||
- bug fixes (see ChangeLog)
|
|
||||||
|
|
||||||
2007-07-16: Hunspell 1.1.8 release:
|
|
||||||
- better Mac OS X/Cygwin and Windows compatibility
|
|
||||||
|
|
||||||
- fix Hunspell's Valgrind environment and memory handling errors
|
|
||||||
detected by Valgrind
|
|
||||||
|
|
||||||
- other bug fixes (see ChangeLog)
|
|
||||||
|
|
||||||
2007-07-06: Hunspell 1.1.7 release:
|
|
||||||
- fix warning messages of OpenOffice.org build
|
|
||||||
|
|
||||||
2007-06-29: Hunspell 1.1.6 release:
|
|
||||||
- check capitalization of the following word forms
|
|
||||||
- words with mixed capitalisation: OpenOffice.org - OPENOFFICE.ORG
|
|
||||||
- allcap words and suffixes: UNICEF's - UNICEF'S
|
|
||||||
- prefixes with apostrophe and proper names: Sant'Elia - SANT'ELIA
|
|
||||||
|
|
||||||
- suggestion for missing sentence spacing: something.The -> something. The
|
|
||||||
|
|
||||||
- Hunspell executable: improved locale support
|
|
||||||
- -i option: custom input encoding
|
|
||||||
- use locale data for default dictionary names.
|
|
||||||
- tools/hunspell.cxx: fix 8-bit tokenization (letters without
|
|
||||||
casing, like ß or Hebrew characters now are handled well)
|
|
||||||
- dictionary search path (automatic detection of OpenOffice.org directories)
|
|
||||||
- DICPATH environmental variable
|
|
||||||
- -D option: show directory path of loaded dictionary
|
|
||||||
|
|
||||||
- patches and bug fixes for Mozilla, OpenOffice.org.
|
|
||||||
|
|
||||||
2007-03-19: Hunspell 1.1.5 release:
|
|
||||||
- optimizations: 10-100% speed up, smaller code size and memory footprint
|
|
||||||
(conditional experimental code and warning messages)
|
|
||||||
|
|
||||||
- extended Unicode support:
|
|
||||||
- non BMP Unicode characters in dictionary words and affixes (except
|
|
||||||
affix rules and conditions)
|
|
||||||
- support BOM sequence in aff and dic files
|
|
||||||
|
|
||||||
- IGNORE feature for Arabic diacritics and other optional characters
|
|
||||||
|
|
||||||
- New edit distance suggestion methods:
|
|
||||||
- capitalisation: nasa -> NASA
|
|
||||||
- long swap: permenant -> permanent
|
|
||||||
- long move: Ghandi -> Gandhi, greatful -> grateful
|
|
||||||
- double two characters: vacacation -> vacation
|
|
||||||
- spaces in REP sug.: REP alot a_lot (NOTE: "a lot" must be a dictionary word)
|
|
||||||
|
|
||||||
- patches and bug fixes for Mozilla, OpenOffice.org, Emacs, MinGW, Aqua,
|
|
||||||
German and Arabic language, etc.
|
|
||||||
|
|
||||||
2006-02-01: Hunspell 1.1.4 release:
|
|
||||||
- Improved suggestion for typical OCR bugs (missing spaces between
|
|
||||||
capitalized words). For example: "aNew" -> "a New".
|
|
||||||
http://qa.openoffice.org/issues/show_bug.cgi?id=58202
|
|
||||||
|
|
||||||
- tokenization fixes (fix incomplete tokenization of input texts on big-endian
|
|
||||||
platforms, and locale-dependent tokenization of dictionary entries)
|
|
||||||
|
|
||||||
2006-01-06: Hunspell 1.1.3.2 release:
|
|
||||||
- fix Visual C++ compiling errors
|
|
||||||
|
|
||||||
2006-01-05: Hunspell 1.1.3 release:
|
|
||||||
- GPL/LGPL/MPL tri-license for Mozilla integration
|
|
||||||
|
|
||||||
- Alias compression of flag sets and morphological descriptions.
|
|
||||||
(For example, 16 MB Arabic dic file can be compressed to 1 MB.)
|
|
||||||
|
|
||||||
- Improved suggestion.
|
|
||||||
|
|
||||||
- Improved, language independent German sharp s casing with CHECKSHARPS
|
|
||||||
declaration.
|
|
||||||
|
|
||||||
- Unicode tokenization in Hunspell program.
|
|
||||||
|
|
||||||
- Bug fixes (at new and old compound word handling methods), etc.
|
|
||||||
|
|
||||||
2005-11-11: Hunspell 1.1.2 release:
|
|
||||||
|
|
||||||
- Bug fixes (MAP Unicode, COMPOUND pattern matching, ONLYINCOMPOUND
|
|
||||||
suggestions)
|
|
||||||
|
|
||||||
- Checked with 51 regression tests in Valgrind debugging environment,
|
|
||||||
and tested with 52 OOo dictionaries on i686-pc-linux platform.
|
|
||||||
|
|
||||||
2005-11-09: Hunspell 1.1.1 release:
|
|
||||||
|
|
||||||
- Compound word patterns for complex compound word handling and
|
|
||||||
simple word-level lexical scanning. Ideal for checking
|
|
||||||
Arabic and Roman numbers, ordinal numbers in English, affixed
|
|
||||||
numbers in agglutinative languages, etc.
|
|
||||||
http://qa.openoffice.org/issues/show_bug.cgi?id=53643
|
|
||||||
|
|
||||||
- Support ISO-8859-15 encoding for French (French oe ligatures are
|
|
||||||
missing from the latin-1 encoding).
|
|
||||||
http://qa.openoffice.org/issues/show_bug.cgi?id=54980
|
|
||||||
|
|
||||||
- Implemented a flag to forbid obscene word suggestion:
|
|
||||||
http://qa.openoffice.org/issues/show_bug.cgi?id=55498
|
|
||||||
|
|
||||||
- Checked with 50 regression tests in Valgrind debugging environment,
|
|
||||||
and tested with 52 OOo dictionaries.
|
|
||||||
|
|
||||||
- other improvements and bug fixes (see ChangeLog)
|
|
||||||
|
|
||||||
2005-09-19: Hunspell 1.1.0 release
|
|
||||||
|
|
||||||
* complete comparison with MySpell 3.2 (from OpenOffice.org 2 beta)
|
|
||||||
|
|
||||||
* improved ngram suggestion with swap character detection and
|
|
||||||
case insensitivity
|
|
||||||
|
|
||||||
------ examples for ngram improvement (input word and suggestions) -----
|
|
||||||
|
|
||||||
1. pernament (instead of permanent)
|
|
||||||
|
|
||||||
MySpell 3.2: tournaments, tournament, ornaments, ornament's, ornamenting, ornamented,
|
|
||||||
ornament, ornamentals, ornamental, ornamentally
|
|
||||||
|
|
||||||
Hunspell 1.0.9: ornamental, ornament, tournament
|
|
||||||
|
|
||||||
Hunspell 1.1.0: permanent
|
|
||||||
|
|
||||||
Note: swap character detection
|
|
||||||
|
|
||||||
|
|
||||||
2. PERNAMENT (instead of PERMANENT)
|
|
||||||
|
|
||||||
MySpell 3.2: -
|
|
||||||
|
|
||||||
Hunspell 1.0.9: -
|
|
||||||
|
|
||||||
Hunspell 1.1.0: PERMANENT
|
|
||||||
|
|
||||||
|
|
||||||
3. Unesco (instead of UNESCO)
|
|
||||||
|
|
||||||
MySpell 3.2: Genesco, Ionesco, Genesco's, Ionesco's, Frescoing, Fresco's,
|
|
||||||
Frescoed, Fresco, Escorts, Escorting
|
|
||||||
|
|
||||||
Hunspell 1.0.9: Genesco, Ionesco, Fresco
|
|
||||||
|
|
||||||
Hunspell 1.1.0: UNESCO
|
|
||||||
|
|
||||||
|
|
||||||
4. siggraph's (instead of SIGGRAPH's)
|
|
||||||
|
|
||||||
MySpell 3.2: serigraph's, photograph's, serigraphs, physiography's,
|
|
||||||
physiography, digraphs, serigraph, stratigraphy's, stratigraphy
|
|
||||||
epigraphs
|
|
||||||
|
|
||||||
Hunspell 1.0.9: serigraph's, epigraph's, digraph's
|
|
||||||
|
|
||||||
Hunspell 1.1.0: SIGGRAPH's
|
|
||||||
|
|
||||||
--------------- end of examples --------------------
|
|
||||||
|
|
||||||
* improved testing environment with suggestion checking and memory debugging
|
|
||||||
|
|
||||||
memory debugging of all tests with a simple command:
|
|
||||||
|
|
||||||
VALGRIND=memcheck make check
|
|
||||||
|
|
||||||
* lots of other improvements and bug fixes (see ChangeLog)
|
|
||||||
|
|
||||||
|
|
||||||
2005-08-26: Hunspell 1.0.9 release
|
|
||||||
|
|
||||||
* improved related character map suggestion
|
|
||||||
|
|
||||||
* improved ngram suggestion
|
|
||||||
|
|
||||||
------ examples for ngram improvement (O=old, N = new ngram suggestions) --
|
|
||||||
|
|
||||||
1. Permenant (instead of Permanent)
|
|
||||||
|
|
||||||
O: Endangerment, Ferment, Fermented, Deferment's, Empowerment,
|
|
||||||
Ferment's, Ferments, Fermenting, Countermen, Weathermen
|
|
||||||
|
|
||||||
N: Permanent, Supermen, Preferment
|
|
||||||
|
|
||||||
Note: Ngram suggestions was case sensitive.
|
|
||||||
|
|
||||||
2. permenant (instead of permanent)
|
|
||||||
|
|
||||||
O: supermen, newspapermen, empowerment, endangerment, preferments,
|
|
||||||
preferment, permanent, preferment's, permanently, impermanent
|
|
||||||
|
|
||||||
N: permanent, supermen, preferment
|
|
||||||
|
|
||||||
Note: new suggestions are also weighted with longest common subsequence,
|
|
||||||
first letter and common character positions
|
|
||||||
|
|
||||||
3. pernemant (instead of permanent)
|
|
||||||
|
|
||||||
O: pimpernel's, pimpernel, pimpernels, permanently, permanents, permanent,
|
|
||||||
supernatant, impermanent, semipermanent, impermanently
|
|
||||||
|
|
||||||
N: permanent, supernatant, pimpernel
|
|
||||||
|
|
||||||
Note: new method also prefers root word instead of not
|
|
||||||
relevant affixes ('s, s and ly)
|
|
||||||
|
|
||||||
|
|
||||||
4. pernament (instead of permanent)
|
|
||||||
|
|
||||||
O: tournaments, tournament, ornaments, ornament's, ornamenting, ornamented,
|
|
||||||
ornament, ornamentals, ornamental, ornamentally
|
|
||||||
|
|
||||||
N: ornamental, ornament, tournament
|
|
||||||
|
|
||||||
Note: Both ngram methods misses here.
|
|
||||||
|
|
||||||
|
|
||||||
5. obvus (instad of obvious):
|
|
||||||
|
|
||||||
O: obvious, Corvus, obverse, obviously, Jacobus, obtuser, obtuse,
|
|
||||||
obviates, obviate, Travus
|
|
||||||
|
|
||||||
N: obvious, obtuse, obverse
|
|
||||||
|
|
||||||
Note: new method also prefers common first letters.
|
|
||||||
|
|
||||||
|
|
||||||
6. unambigus (instead of unambiguous)
|
|
||||||
|
|
||||||
O: unambiguous, unambiguity, unambiguously, ambiguously, ambiguous,
|
|
||||||
unambitious, ambiguities, ambiguousness
|
|
||||||
|
|
||||||
N: unambiguous, unambiguity, unambitious
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
7. consecvence (instead of consequence)
|
|
||||||
|
|
||||||
O: consecutive, consecutively, consecutiveness, nonconsecutive, consequence,
|
|
||||||
consecutiveness's, convenience's, consistences, consistence
|
|
||||||
|
|
||||||
N: consequence, consecutive, consecrates
|
|
||||||
|
|
||||||
|
|
||||||
An example in a language with rich morphology:
|
|
||||||
|
|
||||||
8. Misisipiben (instead of Mississippiben [`in Mississippi' in Hungarian]):
|
|
||||||
|
|
||||||
O: Misikédéiben, Pisisedéiben, Misikéiéiben, Pisisekéiben, Misikéiben,
|
|
||||||
Misikéidéiben, Misikékéiben, Misikéikéiben, Misikéiméiben, Mississippiiben
|
|
||||||
|
|
||||||
N: Mississippiben, Mississippiiben, Misiiben
|
|
||||||
|
|
||||||
Note: Suggesting not relevant affixes was the biggest fault in ngram
|
|
||||||
suggestion for languages with a lot of affixes.
|
|
||||||
|
|
||||||
--------------- end of examples --------------------
|
|
||||||
|
|
||||||
* support twofold prefix cutting
|
|
||||||
|
|
||||||
* lots of other improvements and bug fixes (see ChangeLog)
|
|
||||||
|
|
||||||
* test Hunspell with 54 OpenOffice.org dictionaries:
|
|
||||||
|
|
||||||
source: ftp://ftp.services.openoffice.org/pub/OpenOffice.org/contrib/dictionaries
|
|
||||||
|
|
||||||
testing shell script:
|
|
||||||
-------------------------------------------------------
|
|
||||||
for i in `ls *zip | grep '^[a-z]*_[A-Z]*[.]'`
|
|
||||||
do
|
|
||||||
dic=`basename $i .zip`
|
|
||||||
mkdir $dic
|
|
||||||
echo unzip $dic
|
|
||||||
unzip -d $dic $i 2>/dev/null
|
|
||||||
cd $dic
|
|
||||||
echo unmunch and test $dic
|
|
||||||
unmunch $dic.dic $dic.aff 2>/dev/null | awk '{print$0"\t"}' |
|
|
||||||
hunspell -d $dic -l -1 >$dic.result 2>$dic.err || rm -f $dic.result
|
|
||||||
cd ..
|
|
||||||
done
|
|
||||||
--------------------------------------------------------
|
|
||||||
|
|
||||||
test result (0 size is o.k.):
|
|
||||||
|
|
||||||
$ for i in *_*/*.result; do wc -c $i; done
|
|
||||||
0 af_ZA/af_ZA.result
|
|
||||||
0 bg_BG/bg_BG.result
|
|
||||||
0 ca_ES/ca_ES.result
|
|
||||||
0 cy_GB/cy_GB.result
|
|
||||||
0 cs_CZ/cs_CZ.result
|
|
||||||
0 da_DK/da_DK.result
|
|
||||||
0 de_AT/de_AT.result
|
|
||||||
0 de_CH/de_CH.result
|
|
||||||
0 de_DE/de_DE.result
|
|
||||||
0 el_GR/el_GR.result
|
|
||||||
6 en_AU/en_AU.result
|
|
||||||
0 en_CA/en_CA.result
|
|
||||||
0 en_GB/en_GB.result
|
|
||||||
0 en_NZ/en_NZ.result
|
|
||||||
0 en_US/en_US.result
|
|
||||||
0 eo_EO/eo_EO.result
|
|
||||||
0 es_ES/es_ES.result
|
|
||||||
0 es_MX/es_MX.result
|
|
||||||
0 es_NEW/es_NEW.result
|
|
||||||
0 fo_FO/fo_FO.result
|
|
||||||
0 fr_FR/fr_FR.result
|
|
||||||
0 ga_IE/ga_IE.result
|
|
||||||
0 gd_GB/gd_GB.result
|
|
||||||
0 gl_ES/gl_ES.result
|
|
||||||
0 he_IL/he_IL.result
|
|
||||||
0 hr_HR/hr_HR.result
|
|
||||||
200694989 hu_HU/hu_HU.result
|
|
||||||
0 id_ID/id_ID.result
|
|
||||||
0 it_IT/it_IT.result
|
|
||||||
0 ku_TR/ku_TR.result
|
|
||||||
0 lt_LT/lt_LT.result
|
|
||||||
0 lv_LV/lv_LV.result
|
|
||||||
0 mg_MG/mg_MG.result
|
|
||||||
0 mi_NZ/mi_NZ.result
|
|
||||||
0 ms_MY/ms_MY.result
|
|
||||||
0 nb_NO/nb_NO.result
|
|
||||||
0 nl_NL/nl_NL.result
|
|
||||||
0 nn_NO/nn_NO.result
|
|
||||||
0 ny_MW/ny_MW.result
|
|
||||||
0 pl_PL/pl_PL.result
|
|
||||||
0 pt_BR/pt_BR.result
|
|
||||||
0 pt_PT/pt_PT.result
|
|
||||||
0 ro_RO/ro_RO.result
|
|
||||||
0 ru_RU/ru_RU.result
|
|
||||||
0 rw_RW/rw_RW.result
|
|
||||||
0 sk_SK/sk_SK.result
|
|
||||||
0 sl_SI/sl_SI.result
|
|
||||||
0 sv_SE/sv_SE.result
|
|
||||||
0 sw_KE/sw_KE.result
|
|
||||||
0 tet_ID/tet_ID.result
|
|
||||||
0 tl_PH/tl_PH.result
|
|
||||||
0 tn_ZA/tn_ZA.result
|
|
||||||
0 uk_UA/uk_UA.result
|
|
||||||
0 zu_ZA/zu_ZA.result
|
|
||||||
|
|
||||||
In en_AU dictionary, there is an abbrevation with two dots (`eqn..'), but
|
|
||||||
`eqn.' is missing. Presumably it is a dictionary bug. Myspell also
|
|
||||||
haven't accepted it.
|
|
||||||
|
|
||||||
Hungarian dictionary contains pseudoroots and forbidden words.
|
|
||||||
Unmunch haven't supported these features yet, and generates bad words, too.
|
|
||||||
|
|
||||||
* check affix rules and OOo dictionaries. Detected bugs in cs_CZ,
|
|
||||||
es_ES, es_NEW, es_MX, lt_LT, nn_NO, pt_PT, ro_RO, sk_SK and sv_SE dictionaries).
|
|
||||||
|
|
||||||
Details:
|
|
||||||
--------------------------------------------------------
|
|
||||||
cs_CZ
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX D us ech [^ighk]os
|
|
||||||
SFX D us y [^i]os
|
|
||||||
SFX Q os ech [^ghk]es
|
|
||||||
SFX M o ech [^ghkei]a
|
|
||||||
SFX J ém ej ám
|
|
||||||
SFX J ém ejme ám
|
|
||||||
SFX J ém ejte ám
|
|
||||||
SFX A ou¾it up oupit
|
|
||||||
SFX A ou¾it upme oupit
|
|
||||||
SFX A ou¾it upte oupit
|
|
||||||
SFX A nout l [aeiouyáéíóúýùìr][^aeiouyáéíóúýùìrl][^aeiouy
|
|
||||||
SFX A nout l [aeiouyáéíóúýùìr][^aeiouyáéíóúýùìrl][^aeiouy
|
|
||||||
|
|
||||||
es_ES
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX W umar úse [ae]husar
|
|
||||||
SFX W emir iñáis eñir
|
|
||||||
|
|
||||||
es_NEW
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX I unan únen unar
|
|
||||||
|
|
||||||
es_MX
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX A a ote e
|
|
||||||
SFX W umar úse [ae]husar
|
|
||||||
SFX W emir iñáis eñir
|
|
||||||
|
|
||||||
lt_LT
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX U ti siuosi tis
|
|
||||||
SFX U ti siuosi tis
|
|
||||||
SFX U ti siesi tis
|
|
||||||
SFX U ti siesi tis
|
|
||||||
SFX U ti sis tis
|
|
||||||
SFX U ti sis tis
|
|
||||||
SFX U ti simës tis
|
|
||||||
SFX U ti simës tis
|
|
||||||
SFX U ti sitës tis
|
|
||||||
SFX U ti sitës tis
|
|
||||||
|
|
||||||
nn_NO
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX D ar rar [^fmk]er
|
|
||||||
SFX U Øre orde ere
|
|
||||||
SFX U Øre ort ere
|
|
||||||
|
|
||||||
pt_PT
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX g ãos oas ão
|
|
||||||
SFX g ãos oas ão
|
|
||||||
|
|
||||||
ro_RO
|
|
||||||
warning - bad field number:
|
|
||||||
SFX L 0 le [^cg] i
|
|
||||||
SFX L 0 i [cg] i
|
|
||||||
SFX U 0 i [^i] ii
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX P l i l [<- there is an unnecessary tabulator here)
|
|
||||||
SFX I a ii [gc] a
|
|
||||||
warning - bad field number:
|
|
||||||
SFX I a ii [gc] a
|
|
||||||
SFX I a ei [^cg] a
|
|
||||||
|
|
||||||
sk_SK
|
|
||||||
warning - incompatible stripping characters and condition:
|
|
||||||
SFX T µa» olú kla»
|
|
||||||
SFX T µa» olúc kla»
|
|
||||||
SFX T sµa» ¹lú sla»
|
|
||||||
SFX T sµa» ¹lúc sla»
|
|
||||||
SFX R µc» lèiem åc»
|
|
||||||
SFX R iás» ätie mias»
|
|
||||||
SFX R iez» iem [^i]ez»
|
|
||||||
SFX R iez» ie¹ [^i]ez»
|
|
||||||
SFX R iez» ie [^i]ez»
|
|
||||||
SFX R iez» eme [^i]ez»
|
|
||||||
SFX R iez» ete [^i]ez»
|
|
||||||
SFX R iez» ú [^i]ez»
|
|
||||||
SFX R iez» úc [^i]ez»
|
|
||||||
SFX R iez» z [^i]ez»
|
|
||||||
SFX R iez» me [^i]ez»
|
|
||||||
SFX R iez» te [^i]ez»
|
|
||||||
|
|
||||||
sv_SE
|
|
||||||
warning - bad field number:
|
|
||||||
SFX C 0 net nets [^e]n
|
|
||||||
--------------------------------------------------------
|
|
||||||
|
|
||||||
2005-08-01: Hunspell 1.0.8 release
|
|
||||||
|
|
||||||
- improved compound word support
|
|
||||||
- fix German S handling
|
|
||||||
- port MySpell files and MAP feature
|
|
||||||
|
|
||||||
2005-07-22: Hunspell 1.0.7 release
|
|
||||||
|
|
||||||
2005-07-21: new home page: http://hunspell.sourceforge.net
|
|
|
@ -1,179 +0,0 @@
|
||||||
About Hunspell
|
|
||||||
--------------
|
|
||||||
|
|
||||||
Hunspell is a spell checker and morphological analyzer library and program
|
|
||||||
designed for languages with rich morphology and complex word compounding or
|
|
||||||
character encoding. Hunspell interfaces: Ispell-like terminal interface
|
|
||||||
using Curses library, Ispell pipe interface, OpenOffice.org UNO module.
|
|
||||||
|
|
||||||
Hunspell's code base comes from the OpenOffice.org MySpell
|
|
||||||
(http://lingucomponent.openoffice.org/MySpell-3.zip). See README.MYSPELL,
|
|
||||||
AUTHORS.MYSPELL and license.myspell files.
|
|
||||||
Hunspell is designed to eventually replace Myspell in OpenOffice.org.
|
|
||||||
|
|
||||||
Main features of Hunspell spell checker and morphological analyzer:
|
|
||||||
|
|
||||||
- Unicode support (affix rules work only with the first 65535 Unicode characters)
|
|
||||||
|
|
||||||
- Morphological analysis (in custom item and arrangement style) and stemming
|
|
||||||
|
|
||||||
- Max. 65535 affix classes and twofold affix stripping (for agglutinative
|
|
||||||
languages, like Azeri, Basque, Estonian, Finnish, Hungarian, Turkish, etc.)
|
|
||||||
|
|
||||||
- Support complex compoundings (for example, Hungarian and German)
|
|
||||||
|
|
||||||
- Support language specific features (for example, special casing of
|
|
||||||
Azeri and Turkish dotted i, or German sharp s)
|
|
||||||
|
|
||||||
- Handle conditional affixes, circumfixes, fogemorphemes,
|
|
||||||
forbidden words, pseudoroots and homonyms.
|
|
||||||
|
|
||||||
- Free software (LGPL, GPL, MPL tri-license)
|
|
||||||
|
|
||||||
Compiling on Unix/Linux
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
./configure
|
|
||||||
make
|
|
||||||
make install
|
|
||||||
|
|
||||||
For dictionary development, use the --with-warnings option of configure.
|
|
||||||
|
|
||||||
For interactive user interface of Hunspell executable, use the --with-ui option.
|
|
||||||
|
|
||||||
The developer packages you need to compile Hunspell's interface:
|
|
||||||
|
|
||||||
glibc-devel
|
|
||||||
|
|
||||||
optional developer packages:
|
|
||||||
|
|
||||||
ncurses (need for --with-ui)
|
|
||||||
readline (for fancy input line editing,
|
|
||||||
configure parameter: --with-readline)
|
|
||||||
locale and gettext (but you can also use the
|
|
||||||
--with-included-gettext configure parameter)
|
|
||||||
|
|
||||||
Hunspell distribution uses new Autoconf (2.59) and Automake (1.9).
|
|
||||||
|
|
||||||
Compiling on Windows
|
|
||||||
--------------------
|
|
||||||
|
|
||||||
1. Compiling with Windows SDK
|
|
||||||
|
|
||||||
Download the free Windows SDK of Microsoft, open a command prompt
|
|
||||||
window and cd into hunspell/src/win_api. Use the following command
|
|
||||||
to compile hunspell:
|
|
||||||
|
|
||||||
vcbuild
|
|
||||||
|
|
||||||
2. Compiling in Cygwin environment
|
|
||||||
|
|
||||||
Download and install Cygwin environment for Windows with the following
|
|
||||||
extra packages:
|
|
||||||
|
|
||||||
make
|
|
||||||
gcc-g++ development package
|
|
||||||
mingw development package (for cygwin.dll free native Windows compilation)
|
|
||||||
ncurses, readline (for user interface)
|
|
||||||
iconv (character conversion)
|
|
||||||
|
|
||||||
2.1. Cygwin1.dll dependent compiling
|
|
||||||
|
|
||||||
Open a Cygwin shell, cd into the hunspell root directory:
|
|
||||||
|
|
||||||
./configure
|
|
||||||
make
|
|
||||||
make install
|
|
||||||
|
|
||||||
For dictionary development, use the --with-warnings option of configure.
|
|
||||||
|
|
||||||
For interactive user interface of Hunspell executable, use the --with-ui option.
|
|
||||||
|
|
||||||
readline configure parameter: --with-readline (for fancy input line editing)
|
|
||||||
|
|
||||||
1.2. Cygwin1.dll free compiling
|
|
||||||
|
|
||||||
Open a Cygwin shell, cd into the hunspell/src/win_api and
|
|
||||||
|
|
||||||
make -f Makefile.cygwin
|
|
||||||
|
|
||||||
Testing
|
|
||||||
-------
|
|
||||||
|
|
||||||
Testing Hunspell (see tests in tests/ subdirectory):
|
|
||||||
|
|
||||||
make check
|
|
||||||
|
|
||||||
or with Valgrind debugger:
|
|
||||||
|
|
||||||
make check
|
|
||||||
VALGRIND=[Valgrind_tool] make check
|
|
||||||
|
|
||||||
For example:
|
|
||||||
|
|
||||||
make check
|
|
||||||
VALGRIND=memcheck make check
|
|
||||||
|
|
||||||
Documentation
|
|
||||||
-------------
|
|
||||||
|
|
||||||
features and dictionary format:
|
|
||||||
man 4 hunspell
|
|
||||||
|
|
||||||
man hunspell
|
|
||||||
hunspell -h
|
|
||||||
http://hunspell.sourceforge.net
|
|
||||||
|
|
||||||
Usage
|
|
||||||
-----
|
|
||||||
|
|
||||||
The src/tools dictionary contains ten executables after compiling
|
|
||||||
(or some of them are in the src/win_api):
|
|
||||||
|
|
||||||
affixcompress: dictionary generation from large (millions of words) vocabularies
|
|
||||||
analyze: example of spell checking, stemming and morphological analysis
|
|
||||||
chmorph: example of automatic morphological generation and conversion
|
|
||||||
example: example of spell checking and suggestion
|
|
||||||
hunspell: main program for spell checking and others (see manual)
|
|
||||||
hunzip: decompressor of hzip format
|
|
||||||
hzip: compressor of hzip format
|
|
||||||
makealias: alias compression (Hunspell only, not back compatible with MySpell)
|
|
||||||
munch: dictionary generation from vocabularies (it needs an affix file, too).
|
|
||||||
unmunch: list all recognized words of a MySpell dictionary
|
|
||||||
wordforms: word generation (Hunspell version of unmunch)
|
|
||||||
|
|
||||||
After compiling and installing (see INSTALL) you can
|
|
||||||
run the Hunspell spell checker (compiled with user interface)
|
|
||||||
with a Hunspell or Myspell dictionary:
|
|
||||||
|
|
||||||
hunspell -d en_US text.txt
|
|
||||||
|
|
||||||
or without interface:
|
|
||||||
|
|
||||||
hunspell
|
|
||||||
hunspell -d en_UK -l <text.txt
|
|
||||||
|
|
||||||
Dictionaries consist of an affix and dictionary file, see tests/
|
|
||||||
or http://wiki.services.openoffice.org/wiki/Dictionaries.
|
|
||||||
|
|
||||||
Using Hunspell library with GCC
|
|
||||||
-------------------------------
|
|
||||||
|
|
||||||
Including in your program:
|
|
||||||
#include <hunspell.hxx>
|
|
||||||
|
|
||||||
Linking with Hunspell static library:
|
|
||||||
g++ -lhunspell example.cxx
|
|
||||||
|
|
||||||
Dictionaries
|
|
||||||
------------
|
|
||||||
|
|
||||||
Myspell & Hunspell dictionaries:
|
|
||||||
http://wiki.services.openoffice.org/wiki/Dictionaries
|
|
||||||
|
|
||||||
Aspell dictionaries (need some conversion):
|
|
||||||
ftp://ftp.gnu.org/gnu/aspell/dict
|
|
||||||
Conversion steps: see relevant feature request at http://hunspell.sf.net.
|
|
||||||
|
|
||||||
László Németh
|
|
||||||
nemeth at OOo
|
|
|
@ -1,69 +0,0 @@
|
||||||
MySpell is a simple spell checker that uses affix
|
|
||||||
compression and is modelled after the spell checker
|
|
||||||
ispell.
|
|
||||||
|
|
||||||
MySpell was written to explore how affix compression
|
|
||||||
can be implemented.
|
|
||||||
|
|
||||||
The Main features of MySpell are:
|
|
||||||
|
|
||||||
1. written in C++ to make it easier to interface with
|
|
||||||
Pspell, OpenOffice, AbiWord, etc
|
|
||||||
|
|
||||||
2. it is stateless, uses no static variables and
|
|
||||||
should be completely reentrant with almost no
|
|
||||||
ifdefs
|
|
||||||
|
|
||||||
3. it tries to be as compatible with ispell to
|
|
||||||
the extent it can. It can read slightly modified
|
|
||||||
versions of munched ispell dictionaries (and it
|
|
||||||
comes with a munched english wordlist borrowed from
|
|
||||||
Kevin Atkinson's excellent Aspell.
|
|
||||||
|
|
||||||
4. it uses a heavily modified aff file format that
|
|
||||||
can be derived from ispell aff files but uses
|
|
||||||
the iso-8859-X character sets only
|
|
||||||
|
|
||||||
5. it is simple with *lots* of comments that
|
|
||||||
describes how the affixes are stored
|
|
||||||
and tested for (based on the approach used by
|
|
||||||
ispell).
|
|
||||||
|
|
||||||
6. it supports improved suggestions with replacement
|
|
||||||
tables and ngram-scoring based mechanisms in addition
|
|
||||||
to the main suggestion mechanisms
|
|
||||||
|
|
||||||
7. like ispell it has a BSD license (and no
|
|
||||||
advertising clause)
|
|
||||||
|
|
||||||
But ... it has *no* support for adding words
|
|
||||||
to a personal dictionary, *no* support for converting
|
|
||||||
between various text encodings, and *no* command line
|
|
||||||
interface (it is purely meant to be a library).
|
|
||||||
|
|
||||||
It can not (in any way) replace all of the functionality
|
|
||||||
of ispell or aspell/pspell. It is meant as a learning
|
|
||||||
tool for understanding affix compression and for
|
|
||||||
being used by front ends like OpenOffice, Abiword, etc.
|
|
||||||
|
|
||||||
MySpell has been tested under Linux and Solaris
|
|
||||||
and has the world's simplest Makefile and no
|
|
||||||
configure support.
|
|
||||||
|
|
||||||
It does come with a simple example program that
|
|
||||||
spell checks some words and returns suggestions.
|
|
||||||
|
|
||||||
To build a static library and an example
|
|
||||||
program under Linux simply type:
|
|
||||||
|
|
||||||
tar -zxvf myspell.tar.gz
|
|
||||||
cd myspell2
|
|
||||||
make
|
|
||||||
|
|
||||||
To run the example program:
|
|
||||||
./example ./en_US.aff ./en_US.dic checkme.lst
|
|
||||||
|
|
||||||
Please play around with it and let me know
|
|
||||||
what you think.
|
|
||||||
|
|
||||||
Please see the file CONTRIBUTORS for more info.
|
|
|
@ -1,132 +0,0 @@
|
||||||
Many thanks to the following contributors and supporters:
|
|
||||||
|
|
||||||
Mehmet Akin
|
|
||||||
Göran Andersson
|
|
||||||
Lars Aronsson
|
|
||||||
Ruud Baars
|
|
||||||
Bartkó Zoltán
|
|
||||||
Mathias Bauer
|
|
||||||
Bencsáth Boldizsár
|
|
||||||
Bíró Árpád
|
|
||||||
Ingo H. de Boer
|
|
||||||
Simon Brouwer
|
|
||||||
Jeppe Bundsgaard
|
|
||||||
Ginn Chen
|
|
||||||
Aaron Digulla
|
|
||||||
Dmitri Gabinski
|
|
||||||
Dvornik László
|
|
||||||
David Einstein
|
|
||||||
Rene Engelhard
|
|
||||||
Frederik Fouvry
|
|
||||||
Flemming Frandsen
|
|
||||||
Serge Gautherie
|
|
||||||
Marek Gleń
|
|
||||||
Gavins at OOo
|
|
||||||
Gefferth András
|
|
||||||
Godó Ferenc
|
|
||||||
Goldman Eleonóra
|
|
||||||
Steinar H. Gunderson
|
|
||||||
Halácsy Péter
|
|
||||||
Chris Halls
|
|
||||||
Khaled Hosny
|
|
||||||
Izsók András
|
|
||||||
Björn Jacke
|
|
||||||
Mike Tian-Jian Jiang
|
|
||||||
Dafydd Jones
|
|
||||||
Ryan Jones
|
|
||||||
Jean-Christophe Helary
|
|
||||||
Kevin Hendricks
|
|
||||||
Martin Hollmichel
|
|
||||||
Pavel Janík
|
|
||||||
John Winters
|
|
||||||
Mohamed Kebdani
|
|
||||||
Kelemen Gábor
|
|
||||||
Shewangizaw Gulilat
|
|
||||||
Kéménczy Kálmán
|
|
||||||
Dan Kenigsberg
|
|
||||||
Pham Ngoc Khanh
|
|
||||||
Khiraly László
|
|
||||||
Koblinger Egmont
|
|
||||||
Kornai András
|
|
||||||
Tor Lillqvist
|
|
||||||
Christian Lohmaier
|
|
||||||
Robert Longson
|
|
||||||
Marot at SF dot net
|
|
||||||
Mark McClain
|
|
||||||
Caolan McNamara
|
|
||||||
Michael Meeks
|
|
||||||
Moheb Mekhaiel
|
|
||||||
Laurie Mercer
|
|
||||||
Ladislav Michnovič
|
|
||||||
Ellis Miller
|
|
||||||
Giuseppe Modugno
|
|
||||||
János Mohácsi
|
|
||||||
Bram Moolenaar
|
|
||||||
Daniel Naber
|
|
||||||
Nagy Viktor
|
|
||||||
John Nisly
|
|
||||||
Noll János
|
|
||||||
S Page
|
|
||||||
Christophe Paris
|
|
||||||
Malcolm Parsons
|
|
||||||
Sylvain Paschein
|
|
||||||
Volkov Peter
|
|
||||||
Bryan Petty
|
|
||||||
Harri Pitkänen
|
|
||||||
Davide Prina
|
|
||||||
Kevin F. Quinn
|
|
||||||
Erdal Ronahi
|
|
||||||
Olivier Ronez
|
|
||||||
Bernhard Rosenkraenzer
|
|
||||||
Sarlós Tamás
|
|
||||||
Thobias Schlemmer
|
|
||||||
Jan Seeger
|
|
||||||
Jose da Silva
|
|
||||||
Paulo Ney de Souza
|
|
||||||
Roland Smith
|
|
||||||
Munzir Taha
|
|
||||||
Timeless at bemail dot org
|
|
||||||
Tímár András
|
|
||||||
Tonal at OOo
|
|
||||||
Török László
|
|
||||||
Trón Viktor
|
|
||||||
Gianluca Turconi
|
|
||||||
Ryan VanderMeulen
|
|
||||||
Varga Dániel
|
|
||||||
Elio Voci
|
|
||||||
Miha Vrhovnik
|
|
||||||
Martijn Wargers
|
|
||||||
Michel Weimerskirch
|
|
||||||
Brett Wilson
|
|
||||||
Friedel Wolff
|
|
||||||
Daniel Yacob
|
|
||||||
Gábor Zahemszky
|
|
||||||
Taha Zerrouki
|
|
||||||
and others (see also AUTHORS.myspell)
|
|
||||||
|
|
||||||
FSF.hu Foundation
|
|
||||||
http://www.fsf.hu
|
|
||||||
|
|
||||||
MOKK Research Centre
|
|
||||||
Budapest University of Technology and Economics
|
|
||||||
Sociology and Communications Department
|
|
||||||
http://www.mokk.bme.hu
|
|
||||||
|
|
||||||
Hungarian Ministry of Informatics and Telecommunications
|
|
||||||
|
|
||||||
IMEDIA Kft.
|
|
||||||
http://www.imedia.hu
|
|
||||||
|
|
||||||
OpenOffice.org community
|
|
||||||
http://www.openoffice.org
|
|
||||||
|
|
||||||
OpenTaal Foundation, Netherlands and
|
|
||||||
Dutch Language Union (Nederlandse Taalunie)
|
|
||||||
http://opentaal.org
|
|
||||||
|
|
||||||
UHU-Linux Kft.
|
|
||||||
|
|
||||||
Thanks,
|
|
||||||
|
|
||||||
Németh László
|
|
||||||
nemeth at OOo
|
|
|
@ -1,4 +0,0 @@
|
||||||
* shared dictionaries for multi-user environment
|
|
||||||
* improve compound handling
|
|
||||||
* Unicode unmunch (munch)
|
|
||||||
* forbiddenword and pseudoword support in unmunch
|
|
|
@ -1,984 +0,0 @@
|
||||||
# generated automatically by aclocal 1.11.1 -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
|
||||||
# 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
m4_ifndef([AC_AUTOCONF_VERSION],
|
|
||||||
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
|
|
||||||
m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.65],,
|
|
||||||
[m4_warning([this file was generated for autoconf 2.65.
|
|
||||||
You have another version of autoconf. It may work, but is not guaranteed to.
|
|
||||||
If you have problems, you may need to regenerate the build system entirely.
|
|
||||||
To do so, use the procedure documented by the package, typically `autoreconf'.])])
|
|
||||||
|
|
||||||
# Copyright (C) 2002, 2003, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_AUTOMAKE_VERSION(VERSION)
|
|
||||||
# ----------------------------
|
|
||||||
# Automake X.Y traces this macro to ensure aclocal.m4 has been
|
|
||||||
# generated from the m4 files accompanying Automake X.Y.
|
|
||||||
# (This private macro should not be called outside this file.)
|
|
||||||
AC_DEFUN([AM_AUTOMAKE_VERSION],
|
|
||||||
[am__api_version='1.11'
|
|
||||||
dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
|
|
||||||
dnl require some minimum version. Point them to the right macro.
|
|
||||||
m4_if([$1], [1.11.1], [],
|
|
||||||
[AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# _AM_AUTOCONF_VERSION(VERSION)
|
|
||||||
# -----------------------------
|
|
||||||
# aclocal traces this macro to find the Autoconf version.
|
|
||||||
# This is a private macro too. Using m4_define simplifies
|
|
||||||
# the logic in aclocal, which can simply ignore this definition.
|
|
||||||
m4_define([_AM_AUTOCONF_VERSION], [])
|
|
||||||
|
|
||||||
# AM_SET_CURRENT_AUTOMAKE_VERSION
|
|
||||||
# -------------------------------
|
|
||||||
# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
|
|
||||||
# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
|
|
||||||
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
|
|
||||||
[AM_AUTOMAKE_VERSION([1.11.1])dnl
|
|
||||||
m4_ifndef([AC_AUTOCONF_VERSION],
|
|
||||||
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
|
|
||||||
_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
|
|
||||||
|
|
||||||
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets
|
|
||||||
# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to
|
|
||||||
# `$srcdir', `$srcdir/..', or `$srcdir/../..'.
|
|
||||||
#
|
|
||||||
# Of course, Automake must honor this variable whenever it calls a
|
|
||||||
# tool from the auxiliary directory. The problem is that $srcdir (and
|
|
||||||
# therefore $ac_aux_dir as well) can be either absolute or relative,
|
|
||||||
# depending on how configure is run. This is pretty annoying, since
|
|
||||||
# it makes $ac_aux_dir quite unusable in subdirectories: in the top
|
|
||||||
# source directory, any form will work fine, but in subdirectories a
|
|
||||||
# relative path needs to be adjusted first.
|
|
||||||
#
|
|
||||||
# $ac_aux_dir/missing
|
|
||||||
# fails when called from a subdirectory if $ac_aux_dir is relative
|
|
||||||
# $top_srcdir/$ac_aux_dir/missing
|
|
||||||
# fails if $ac_aux_dir is absolute,
|
|
||||||
# fails when called from a subdirectory in a VPATH build with
|
|
||||||
# a relative $ac_aux_dir
|
|
||||||
#
|
|
||||||
# The reason of the latter failure is that $top_srcdir and $ac_aux_dir
|
|
||||||
# are both prefixed by $srcdir. In an in-source build this is usually
|
|
||||||
# harmless because $srcdir is `.', but things will broke when you
|
|
||||||
# start a VPATH build or use an absolute $srcdir.
|
|
||||||
#
|
|
||||||
# So we could use something similar to $top_srcdir/$ac_aux_dir/missing,
|
|
||||||
# iff we strip the leading $srcdir from $ac_aux_dir. That would be:
|
|
||||||
# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"`
|
|
||||||
# and then we would define $MISSING as
|
|
||||||
# MISSING="\${SHELL} $am_aux_dir/missing"
|
|
||||||
# This will work as long as MISSING is not called from configure, because
|
|
||||||
# unfortunately $(top_srcdir) has no meaning in configure.
|
|
||||||
# However there are other variables, like CC, which are often used in
|
|
||||||
# configure, and could therefore not use this "fixed" $ac_aux_dir.
|
|
||||||
#
|
|
||||||
# Another solution, used here, is to always expand $ac_aux_dir to an
|
|
||||||
# absolute PATH. The drawback is that using absolute paths prevent a
|
|
||||||
# configured tree to be moved without reconfiguration.
|
|
||||||
|
|
||||||
AC_DEFUN([AM_AUX_DIR_EXPAND],
|
|
||||||
[dnl Rely on autoconf to set up CDPATH properly.
|
|
||||||
AC_PREREQ([2.50])dnl
|
|
||||||
# expand $ac_aux_dir to an absolute path
|
|
||||||
am_aux_dir=`cd $ac_aux_dir && pwd`
|
|
||||||
])
|
|
||||||
|
|
||||||
# AM_CONDITIONAL -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005, 2006, 2008
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 9
|
|
||||||
|
|
||||||
# AM_CONDITIONAL(NAME, SHELL-CONDITION)
|
|
||||||
# -------------------------------------
|
|
||||||
# Define a conditional.
|
|
||||||
AC_DEFUN([AM_CONDITIONAL],
|
|
||||||
[AC_PREREQ(2.52)dnl
|
|
||||||
ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])],
|
|
||||||
[$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl
|
|
||||||
AC_SUBST([$1_TRUE])dnl
|
|
||||||
AC_SUBST([$1_FALSE])dnl
|
|
||||||
_AM_SUBST_NOTMAKE([$1_TRUE])dnl
|
|
||||||
_AM_SUBST_NOTMAKE([$1_FALSE])dnl
|
|
||||||
m4_define([_AM_COND_VALUE_$1], [$2])dnl
|
|
||||||
if $2; then
|
|
||||||
$1_TRUE=
|
|
||||||
$1_FALSE='#'
|
|
||||||
else
|
|
||||||
$1_TRUE='#'
|
|
||||||
$1_FALSE=
|
|
||||||
fi
|
|
||||||
AC_CONFIG_COMMANDS_PRE(
|
|
||||||
[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then
|
|
||||||
AC_MSG_ERROR([[conditional "$1" was never defined.
|
|
||||||
Usually this means the macro was only invoked conditionally.]])
|
|
||||||
fi])])
|
|
||||||
|
|
||||||
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2009
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 10
|
|
||||||
|
|
||||||
# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be
|
|
||||||
# written in clear, in which case automake, when reading aclocal.m4,
|
|
||||||
# will think it sees a *use*, and therefore will trigger all it's
|
|
||||||
# C support machinery. Also note that it means that autoscan, seeing
|
|
||||||
# CC etc. in the Makefile, will ask for an AC_PROG_CC use...
|
|
||||||
|
|
||||||
|
|
||||||
# _AM_DEPENDENCIES(NAME)
|
|
||||||
# ----------------------
|
|
||||||
# See how the compiler implements dependency checking.
|
|
||||||
# NAME is "CC", "CXX", "GCJ", or "OBJC".
|
|
||||||
# We try a few techniques and use that to set a single cache variable.
|
|
||||||
#
|
|
||||||
# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was
|
|
||||||
# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular
|
|
||||||
# dependency, and given that the user is not expected to run this macro,
|
|
||||||
# just rely on AC_PROG_CC.
|
|
||||||
AC_DEFUN([_AM_DEPENDENCIES],
|
|
||||||
[AC_REQUIRE([AM_SET_DEPDIR])dnl
|
|
||||||
AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl
|
|
||||||
AC_REQUIRE([AM_MAKE_INCLUDE])dnl
|
|
||||||
AC_REQUIRE([AM_DEP_TRACK])dnl
|
|
||||||
|
|
||||||
ifelse([$1], CC, [depcc="$CC" am_compiler_list=],
|
|
||||||
[$1], CXX, [depcc="$CXX" am_compiler_list=],
|
|
||||||
[$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'],
|
|
||||||
[$1], UPC, [depcc="$UPC" am_compiler_list=],
|
|
||||||
[$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'],
|
|
||||||
[depcc="$$1" am_compiler_list=])
|
|
||||||
|
|
||||||
AC_CACHE_CHECK([dependency style of $depcc],
|
|
||||||
[am_cv_$1_dependencies_compiler_type],
|
|
||||||
[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
|
|
||||||
# We make a subdir and do the tests there. Otherwise we can end up
|
|
||||||
# making bogus files that we don't know about and never remove. For
|
|
||||||
# instance it was reported that on HP-UX the gcc test will end up
|
|
||||||
# making a dummy file named `D' -- because `-MD' means `put the output
|
|
||||||
# in D'.
|
|
||||||
mkdir conftest.dir
|
|
||||||
# Copy depcomp to subdir because otherwise we won't find it if we're
|
|
||||||
# using a relative directory.
|
|
||||||
cp "$am_depcomp" conftest.dir
|
|
||||||
cd conftest.dir
|
|
||||||
# We will build objects and dependencies in a subdirectory because
|
|
||||||
# it helps to detect inapplicable dependency modes. For instance
|
|
||||||
# both Tru64's cc and ICC support -MD to output dependencies as a
|
|
||||||
# side effect of compilation, but ICC will put the dependencies in
|
|
||||||
# the current directory while Tru64 will put them in the object
|
|
||||||
# directory.
|
|
||||||
mkdir sub
|
|
||||||
|
|
||||||
am_cv_$1_dependencies_compiler_type=none
|
|
||||||
if test "$am_compiler_list" = ""; then
|
|
||||||
am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp`
|
|
||||||
fi
|
|
||||||
am__universal=false
|
|
||||||
m4_case([$1], [CC],
|
|
||||||
[case " $depcc " in #(
|
|
||||||
*\ -arch\ *\ -arch\ *) am__universal=true ;;
|
|
||||||
esac],
|
|
||||||
[CXX],
|
|
||||||
[case " $depcc " in #(
|
|
||||||
*\ -arch\ *\ -arch\ *) am__universal=true ;;
|
|
||||||
esac])
|
|
||||||
|
|
||||||
for depmode in $am_compiler_list; do
|
|
||||||
# Setup a source with many dependencies, because some compilers
|
|
||||||
# like to wrap large dependency lists on column 80 (with \), and
|
|
||||||
# we should not choose a depcomp mode which is confused by this.
|
|
||||||
#
|
|
||||||
# We need to recreate these files for each test, as the compiler may
|
|
||||||
# overwrite some of them when testing with obscure command lines.
|
|
||||||
# This happens at least with the AIX C compiler.
|
|
||||||
: > sub/conftest.c
|
|
||||||
for i in 1 2 3 4 5 6; do
|
|
||||||
echo '#include "conftst'$i'.h"' >> sub/conftest.c
|
|
||||||
# Using `: > sub/conftst$i.h' creates only sub/conftst1.h with
|
|
||||||
# Solaris 8's {/usr,}/bin/sh.
|
|
||||||
touch sub/conftst$i.h
|
|
||||||
done
|
|
||||||
echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf
|
|
||||||
|
|
||||||
# We check with `-c' and `-o' for the sake of the "dashmstdout"
|
|
||||||
# mode. It turns out that the SunPro C++ compiler does not properly
|
|
||||||
# handle `-M -o', and we need to detect this. Also, some Intel
|
|
||||||
# versions had trouble with output in subdirs
|
|
||||||
am__obj=sub/conftest.${OBJEXT-o}
|
|
||||||
am__minus_obj="-o $am__obj"
|
|
||||||
case $depmode in
|
|
||||||
gcc)
|
|
||||||
# This depmode causes a compiler race in universal mode.
|
|
||||||
test "$am__universal" = false || continue
|
|
||||||
;;
|
|
||||||
nosideeffect)
|
|
||||||
# after this tag, mechanisms are not by side-effect, so they'll
|
|
||||||
# only be used when explicitly requested
|
|
||||||
if test "x$enable_dependency_tracking" = xyes; then
|
|
||||||
continue
|
|
||||||
else
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
msvisualcpp | msvcmsys)
|
|
||||||
# This compiler won't grok `-c -o', but also, the minuso test has
|
|
||||||
# not run yet. These depmodes are late enough in the game, and
|
|
||||||
# so weak that their functioning should not be impacted.
|
|
||||||
am__obj=conftest.${OBJEXT-o}
|
|
||||||
am__minus_obj=
|
|
||||||
;;
|
|
||||||
none) break ;;
|
|
||||||
esac
|
|
||||||
if depmode=$depmode \
|
|
||||||
source=sub/conftest.c object=$am__obj \
|
|
||||||
depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \
|
|
||||||
$SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \
|
|
||||||
>/dev/null 2>conftest.err &&
|
|
||||||
grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 &&
|
|
||||||
grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 &&
|
|
||||||
grep $am__obj sub/conftest.Po > /dev/null 2>&1 &&
|
|
||||||
${MAKE-make} -s -f confmf > /dev/null 2>&1; then
|
|
||||||
# icc doesn't choke on unknown options, it will just issue warnings
|
|
||||||
# or remarks (even with -Werror). So we grep stderr for any message
|
|
||||||
# that says an option was ignored or not supported.
|
|
||||||
# When given -MP, icc 7.0 and 7.1 complain thusly:
|
|
||||||
# icc: Command line warning: ignoring option '-M'; no argument required
|
|
||||||
# The diagnosis changed in icc 8.0:
|
|
||||||
# icc: Command line remark: option '-MP' not supported
|
|
||||||
if (grep 'ignoring option' conftest.err ||
|
|
||||||
grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else
|
|
||||||
am_cv_$1_dependencies_compiler_type=$depmode
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
cd ..
|
|
||||||
rm -rf conftest.dir
|
|
||||||
else
|
|
||||||
am_cv_$1_dependencies_compiler_type=none
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type])
|
|
||||||
AM_CONDITIONAL([am__fastdep$1], [
|
|
||||||
test "x$enable_dependency_tracking" != xno \
|
|
||||||
&& test "$am_cv_$1_dependencies_compiler_type" = gcc3])
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
# AM_SET_DEPDIR
|
|
||||||
# -------------
|
|
||||||
# Choose a directory name for dependency files.
|
|
||||||
# This macro is AC_REQUIREd in _AM_DEPENDENCIES
|
|
||||||
AC_DEFUN([AM_SET_DEPDIR],
|
|
||||||
[AC_REQUIRE([AM_SET_LEADING_DOT])dnl
|
|
||||||
AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
# AM_DEP_TRACK
|
|
||||||
# ------------
|
|
||||||
AC_DEFUN([AM_DEP_TRACK],
|
|
||||||
[AC_ARG_ENABLE(dependency-tracking,
|
|
||||||
[ --disable-dependency-tracking speeds up one-time build
|
|
||||||
--enable-dependency-tracking do not reject slow dependency extractors])
|
|
||||||
if test "x$enable_dependency_tracking" != xno; then
|
|
||||||
am_depcomp="$ac_aux_dir/depcomp"
|
|
||||||
AMDEPBACKSLASH='\'
|
|
||||||
fi
|
|
||||||
AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno])
|
|
||||||
AC_SUBST([AMDEPBACKSLASH])dnl
|
|
||||||
_AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
# Generate code to set up dependency tracking. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2008
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
#serial 5
|
|
||||||
|
|
||||||
# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
|
||||||
# ------------------------------
|
|
||||||
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
|
||||||
[{
|
|
||||||
# Autoconf 2.62 quotes --file arguments for eval, but not when files
|
|
||||||
# are listed without --file. Let's play safe and only enable the eval
|
|
||||||
# if we detect the quoting.
|
|
||||||
case $CONFIG_FILES in
|
|
||||||
*\'*) eval set x "$CONFIG_FILES" ;;
|
|
||||||
*) set x $CONFIG_FILES ;;
|
|
||||||
esac
|
|
||||||
shift
|
|
||||||
for mf
|
|
||||||
do
|
|
||||||
# Strip MF so we end up with the name of the file.
|
|
||||||
mf=`echo "$mf" | sed -e 's/:.*$//'`
|
|
||||||
# Check whether this is an Automake generated Makefile or not.
|
|
||||||
# We used to match only the files named `Makefile.in', but
|
|
||||||
# some people rename them; so instead we look at the file content.
|
|
||||||
# Grep'ing the first line is not enough: some people post-process
|
|
||||||
# each Makefile.in and add a new line on top of each file to say so.
|
|
||||||
# Grep'ing the whole file is not good either: AIX grep has a line
|
|
||||||
# limit of 2048, but all sed's we know have understand at least 4000.
|
|
||||||
if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
|
|
||||||
dirpart=`AS_DIRNAME("$mf")`
|
|
||||||
else
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
# Extract the definition of DEPDIR, am__include, and am__quote
|
|
||||||
# from the Makefile without running `make'.
|
|
||||||
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
|
|
||||||
test -z "$DEPDIR" && continue
|
|
||||||
am__include=`sed -n 's/^am__include = //p' < "$mf"`
|
|
||||||
test -z "am__include" && continue
|
|
||||||
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
|
|
||||||
# When using ansi2knr, U may be empty or an underscore; expand it
|
|
||||||
U=`sed -n 's/^U = //p' < "$mf"`
|
|
||||||
# Find all dependency output files, they are included files with
|
|
||||||
# $(DEPDIR) in their names. We invoke sed twice because it is the
|
|
||||||
# simplest approach to changing $(DEPDIR) to its actual value in the
|
|
||||||
# expansion.
|
|
||||||
for file in `sed -n "
|
|
||||||
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
|
|
||||||
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do
|
|
||||||
# Make sure the directory exists.
|
|
||||||
test -f "$dirpart/$file" && continue
|
|
||||||
fdir=`AS_DIRNAME(["$file"])`
|
|
||||||
AS_MKDIR_P([$dirpart/$fdir])
|
|
||||||
# echo "creating $dirpart/$file"
|
|
||||||
echo '# dummy' > "$dirpart/$file"
|
|
||||||
done
|
|
||||||
done
|
|
||||||
}
|
|
||||||
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
|
||||||
|
|
||||||
|
|
||||||
# AM_OUTPUT_DEPENDENCY_COMMANDS
|
|
||||||
# -----------------------------
|
|
||||||
# This macro should only be invoked once -- use via AC_REQUIRE.
|
|
||||||
#
|
|
||||||
# This code is only required when automatic dependency tracking
|
|
||||||
# is enabled. FIXME. This creates each `.P' file that we will
|
|
||||||
# need in order to bootstrap the dependency handling code.
|
|
||||||
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
|
|
||||||
[AC_CONFIG_COMMANDS([depfiles],
|
|
||||||
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
|
|
||||||
[AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
|
|
||||||
])
|
|
||||||
|
|
||||||
# Do all the work for Automake. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
|
||||||
# 2005, 2006, 2008, 2009 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 16
|
|
||||||
|
|
||||||
# This macro actually does too much. Some checks are only needed if
|
|
||||||
# your package does certain things. But this isn't really a big deal.
|
|
||||||
|
|
||||||
# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE])
|
|
||||||
# AM_INIT_AUTOMAKE([OPTIONS])
|
|
||||||
# -----------------------------------------------
|
|
||||||
# The call with PACKAGE and VERSION arguments is the old style
|
|
||||||
# call (pre autoconf-2.50), which is being phased out. PACKAGE
|
|
||||||
# and VERSION should now be passed to AC_INIT and removed from
|
|
||||||
# the call to AM_INIT_AUTOMAKE.
|
|
||||||
# We support both call styles for the transition. After
|
|
||||||
# the next Automake release, Autoconf can make the AC_INIT
|
|
||||||
# arguments mandatory, and then we can depend on a new Autoconf
|
|
||||||
# release and drop the old call support.
|
|
||||||
AC_DEFUN([AM_INIT_AUTOMAKE],
|
|
||||||
[AC_PREREQ([2.62])dnl
|
|
||||||
dnl Autoconf wants to disallow AM_ names. We explicitly allow
|
|
||||||
dnl the ones we care about.
|
|
||||||
m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl
|
|
||||||
AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_INSTALL])dnl
|
|
||||||
if test "`cd $srcdir && pwd`" != "`pwd`"; then
|
|
||||||
# Use -I$(srcdir) only when $(srcdir) != ., so that make's output
|
|
||||||
# is not polluted with repeated "-I."
|
|
||||||
AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl
|
|
||||||
# test to see if srcdir already configured
|
|
||||||
if test -f $srcdir/config.status; then
|
|
||||||
AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# test whether we have cygpath
|
|
||||||
if test -z "$CYGPATH_W"; then
|
|
||||||
if (cygpath --version) >/dev/null 2>/dev/null; then
|
|
||||||
CYGPATH_W='cygpath -w'
|
|
||||||
else
|
|
||||||
CYGPATH_W=echo
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
AC_SUBST([CYGPATH_W])
|
|
||||||
|
|
||||||
# Define the identity of the package.
|
|
||||||
dnl Distinguish between old-style and new-style calls.
|
|
||||||
m4_ifval([$2],
|
|
||||||
[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl
|
|
||||||
AC_SUBST([PACKAGE], [$1])dnl
|
|
||||||
AC_SUBST([VERSION], [$2])],
|
|
||||||
[_AM_SET_OPTIONS([$1])dnl
|
|
||||||
dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT.
|
|
||||||
m4_if(m4_ifdef([AC_PACKAGE_NAME], 1)m4_ifdef([AC_PACKAGE_VERSION], 1), 11,,
|
|
||||||
[m4_fatal([AC_INIT should be called with package and version arguments])])dnl
|
|
||||||
AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl
|
|
||||||
AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl
|
|
||||||
|
|
||||||
_AM_IF_OPTION([no-define],,
|
|
||||||
[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package])
|
|
||||||
AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl
|
|
||||||
|
|
||||||
# Some tools Automake needs.
|
|
||||||
AC_REQUIRE([AM_SANITY_CHECK])dnl
|
|
||||||
AC_REQUIRE([AC_ARG_PROGRAM])dnl
|
|
||||||
AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version})
|
|
||||||
AM_MISSING_PROG(AUTOCONF, autoconf)
|
|
||||||
AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version})
|
|
||||||
AM_MISSING_PROG(AUTOHEADER, autoheader)
|
|
||||||
AM_MISSING_PROG(MAKEINFO, makeinfo)
|
|
||||||
AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
|
|
||||||
AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
|
|
||||||
AC_REQUIRE([AM_PROG_MKDIR_P])dnl
|
|
||||||
# We need awk for the "check" target. The system "awk" is bad on
|
|
||||||
# some platforms.
|
|
||||||
AC_REQUIRE([AC_PROG_AWK])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_MAKE_SET])dnl
|
|
||||||
AC_REQUIRE([AM_SET_LEADING_DOT])dnl
|
|
||||||
_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])],
|
|
||||||
[_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])],
|
|
||||||
[_AM_PROG_TAR([v7])])])
|
|
||||||
_AM_IF_OPTION([no-dependencies],,
|
|
||||||
[AC_PROVIDE_IFELSE([AC_PROG_CC],
|
|
||||||
[_AM_DEPENDENCIES(CC)],
|
|
||||||
[define([AC_PROG_CC],
|
|
||||||
defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl
|
|
||||||
AC_PROVIDE_IFELSE([AC_PROG_CXX],
|
|
||||||
[_AM_DEPENDENCIES(CXX)],
|
|
||||||
[define([AC_PROG_CXX],
|
|
||||||
defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl
|
|
||||||
AC_PROVIDE_IFELSE([AC_PROG_OBJC],
|
|
||||||
[_AM_DEPENDENCIES(OBJC)],
|
|
||||||
[define([AC_PROG_OBJC],
|
|
||||||
defn([AC_PROG_OBJC])[_AM_DEPENDENCIES(OBJC)])])dnl
|
|
||||||
])
|
|
||||||
_AM_IF_OPTION([silent-rules], [AC_REQUIRE([AM_SILENT_RULES])])dnl
|
|
||||||
dnl The `parallel-tests' driver may need to know about EXEEXT, so add the
|
|
||||||
dnl `am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This macro
|
|
||||||
dnl is hooked onto _AC_COMPILER_EXEEXT early, see below.
|
|
||||||
AC_CONFIG_COMMANDS_PRE(dnl
|
|
||||||
[m4_provide_if([_AM_COMPILER_EXEEXT],
|
|
||||||
[AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl Hook into `_AC_COMPILER_EXEEXT' early to learn its expansion. Do not
|
|
||||||
dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further
|
|
||||||
dnl mangled by Autoconf and run in a shell conditional statement.
|
|
||||||
m4_define([_AC_COMPILER_EXEEXT],
|
|
||||||
m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])])
|
|
||||||
|
|
||||||
|
|
||||||
# When config.status generates a header, we must update the stamp-h file.
|
|
||||||
# This file resides in the same directory as the config header
|
|
||||||
# that is generated. The stamp files are numbered to have different names.
|
|
||||||
|
|
||||||
# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the
|
|
||||||
# loop where config.status creates the headers, so we can generate
|
|
||||||
# our stamp files there.
|
|
||||||
AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK],
|
|
||||||
[# Compute $1's index in $config_headers.
|
|
||||||
_am_arg=$1
|
|
||||||
_am_stamp_count=1
|
|
||||||
for _am_header in $config_headers :; do
|
|
||||||
case $_am_header in
|
|
||||||
$_am_arg | $_am_arg:* )
|
|
||||||
break ;;
|
|
||||||
* )
|
|
||||||
_am_stamp_count=`expr $_am_stamp_count + 1` ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2003, 2005, 2008 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_PROG_INSTALL_SH
|
|
||||||
# ------------------
|
|
||||||
# Define $install_sh.
|
|
||||||
AC_DEFUN([AM_PROG_INSTALL_SH],
|
|
||||||
[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
|
|
||||||
if test x"${install_sh}" != xset; then
|
|
||||||
case $am_aux_dir in
|
|
||||||
*\ * | *\ *)
|
|
||||||
install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;;
|
|
||||||
*)
|
|
||||||
install_sh="\${SHELL} $am_aux_dir/install-sh"
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
AC_SUBST(install_sh)])
|
|
||||||
|
|
||||||
# Copyright (C) 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 2
|
|
||||||
|
|
||||||
# Check whether the underlying file-system supports filenames
|
|
||||||
# with a leading dot. For instance MS-DOS doesn't.
|
|
||||||
AC_DEFUN([AM_SET_LEADING_DOT],
|
|
||||||
[rm -rf .tst 2>/dev/null
|
|
||||||
mkdir .tst 2>/dev/null
|
|
||||||
if test -d .tst; then
|
|
||||||
am__leading_dot=.
|
|
||||||
else
|
|
||||||
am__leading_dot=_
|
|
||||||
fi
|
|
||||||
rmdir .tst 2>/dev/null
|
|
||||||
AC_SUBST([am__leading_dot])])
|
|
||||||
|
|
||||||
# Check to see how 'make' treats includes. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2002, 2003, 2005, 2009 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 4
|
|
||||||
|
|
||||||
# AM_MAKE_INCLUDE()
|
|
||||||
# -----------------
|
|
||||||
# Check to see how make treats includes.
|
|
||||||
AC_DEFUN([AM_MAKE_INCLUDE],
|
|
||||||
[am_make=${MAKE-make}
|
|
||||||
cat > confinc << 'END'
|
|
||||||
am__doit:
|
|
||||||
@echo this is the am__doit target
|
|
||||||
.PHONY: am__doit
|
|
||||||
END
|
|
||||||
# If we don't find an include directive, just comment out the code.
|
|
||||||
AC_MSG_CHECKING([for style of include used by $am_make])
|
|
||||||
am__include="#"
|
|
||||||
am__quote=
|
|
||||||
_am_result=none
|
|
||||||
# First try GNU make style include.
|
|
||||||
echo "include confinc" > confmf
|
|
||||||
# Ignore all kinds of additional output from `make'.
|
|
||||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
|
||||||
*the\ am__doit\ target*)
|
|
||||||
am__include=include
|
|
||||||
am__quote=
|
|
||||||
_am_result=GNU
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
# Now try BSD make style include.
|
|
||||||
if test "$am__include" = "#"; then
|
|
||||||
echo '.include "confinc"' > confmf
|
|
||||||
case `$am_make -s -f confmf 2> /dev/null` in #(
|
|
||||||
*the\ am__doit\ target*)
|
|
||||||
am__include=.include
|
|
||||||
am__quote="\""
|
|
||||||
_am_result=BSD
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
AC_SUBST([am__include])
|
|
||||||
AC_SUBST([am__quote])
|
|
||||||
AC_MSG_RESULT([$_am_result])
|
|
||||||
rm -f confinc confmf
|
|
||||||
])
|
|
||||||
|
|
||||||
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2004, 2005, 2008
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 6
|
|
||||||
|
|
||||||
# AM_MISSING_PROG(NAME, PROGRAM)
|
|
||||||
# ------------------------------
|
|
||||||
AC_DEFUN([AM_MISSING_PROG],
|
|
||||||
[AC_REQUIRE([AM_MISSING_HAS_RUN])
|
|
||||||
$1=${$1-"${am_missing_run}$2"}
|
|
||||||
AC_SUBST($1)])
|
|
||||||
|
|
||||||
|
|
||||||
# AM_MISSING_HAS_RUN
|
|
||||||
# ------------------
|
|
||||||
# Define MISSING if not defined so far and test if it supports --run.
|
|
||||||
# If it does, set am_missing_run to use it, otherwise, to nothing.
|
|
||||||
AC_DEFUN([AM_MISSING_HAS_RUN],
|
|
||||||
[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
|
|
||||||
AC_REQUIRE_AUX_FILE([missing])dnl
|
|
||||||
if test x"${MISSING+set}" != xset; then
|
|
||||||
case $am_aux_dir in
|
|
||||||
*\ * | *\ *)
|
|
||||||
MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;;
|
|
||||||
*)
|
|
||||||
MISSING="\${SHELL} $am_aux_dir/missing" ;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
# Use eval to expand $SHELL
|
|
||||||
if eval "$MISSING --run true"; then
|
|
||||||
am_missing_run="$MISSING --run "
|
|
||||||
else
|
|
||||||
am_missing_run=
|
|
||||||
AC_MSG_WARN([`missing' script is too old or missing])
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
|
|
||||||
# Copyright (C) 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_PROG_MKDIR_P
|
|
||||||
# ---------------
|
|
||||||
# Check for `mkdir -p'.
|
|
||||||
AC_DEFUN([AM_PROG_MKDIR_P],
|
|
||||||
[AC_PREREQ([2.60])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_MKDIR_P])dnl
|
|
||||||
dnl Automake 1.8 to 1.9.6 used to define mkdir_p. We now use MKDIR_P,
|
|
||||||
dnl while keeping a definition of mkdir_p for backward compatibility.
|
|
||||||
dnl @MKDIR_P@ is magic: AC_OUTPUT adjusts its value for each Makefile.
|
|
||||||
dnl However we cannot define mkdir_p as $(MKDIR_P) for the sake of
|
|
||||||
dnl Makefile.ins that do not define MKDIR_P, so we do our own
|
|
||||||
dnl adjustment using top_builddir (which is defined more often than
|
|
||||||
dnl MKDIR_P).
|
|
||||||
AC_SUBST([mkdir_p], ["$MKDIR_P"])dnl
|
|
||||||
case $mkdir_p in
|
|
||||||
[[\\/$]]* | ?:[[\\/]]*) ;;
|
|
||||||
*/*) mkdir_p="\$(top_builddir)/$mkdir_p" ;;
|
|
||||||
esac
|
|
||||||
])
|
|
||||||
|
|
||||||
# Helper functions for option handling. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2002, 2003, 2005, 2008 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 4
|
|
||||||
|
|
||||||
# _AM_MANGLE_OPTION(NAME)
|
|
||||||
# -----------------------
|
|
||||||
AC_DEFUN([_AM_MANGLE_OPTION],
|
|
||||||
[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])])
|
|
||||||
|
|
||||||
# _AM_SET_OPTION(NAME)
|
|
||||||
# ------------------------------
|
|
||||||
# Set option NAME. Presently that only means defining a flag for this option.
|
|
||||||
AC_DEFUN([_AM_SET_OPTION],
|
|
||||||
[m4_define(_AM_MANGLE_OPTION([$1]), 1)])
|
|
||||||
|
|
||||||
# _AM_SET_OPTIONS(OPTIONS)
|
|
||||||
# ----------------------------------
|
|
||||||
# OPTIONS is a space-separated list of Automake options.
|
|
||||||
AC_DEFUN([_AM_SET_OPTIONS],
|
|
||||||
[m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])])
|
|
||||||
|
|
||||||
# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET])
|
|
||||||
# -------------------------------------------
|
|
||||||
# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
|
|
||||||
AC_DEFUN([_AM_IF_OPTION],
|
|
||||||
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
|
|
||||||
|
|
||||||
# Check to make sure that the build environment is sane. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005, 2008
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 5
|
|
||||||
|
|
||||||
# AM_SANITY_CHECK
|
|
||||||
# ---------------
|
|
||||||
AC_DEFUN([AM_SANITY_CHECK],
|
|
||||||
[AC_MSG_CHECKING([whether build environment is sane])
|
|
||||||
# Just in case
|
|
||||||
sleep 1
|
|
||||||
echo timestamp > conftest.file
|
|
||||||
# Reject unsafe characters in $srcdir or the absolute working directory
|
|
||||||
# name. Accept space and tab only in the latter.
|
|
||||||
am_lf='
|
|
||||||
'
|
|
||||||
case `pwd` in
|
|
||||||
*[[\\\"\#\$\&\'\`$am_lf]]*)
|
|
||||||
AC_MSG_ERROR([unsafe absolute working directory name]);;
|
|
||||||
esac
|
|
||||||
case $srcdir in
|
|
||||||
*[[\\\"\#\$\&\'\`$am_lf\ \ ]]*)
|
|
||||||
AC_MSG_ERROR([unsafe srcdir value: `$srcdir']);;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Do `set' in a subshell so we don't clobber the current shell's
|
|
||||||
# arguments. Must try -L first in case configure is actually a
|
|
||||||
# symlink; some systems play weird games with the mod time of symlinks
|
|
||||||
# (eg FreeBSD returns the mod time of the symlink's containing
|
|
||||||
# directory).
|
|
||||||
if (
|
|
||||||
set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null`
|
|
||||||
if test "$[*]" = "X"; then
|
|
||||||
# -L didn't work.
|
|
||||||
set X `ls -t "$srcdir/configure" conftest.file`
|
|
||||||
fi
|
|
||||||
rm -f conftest.file
|
|
||||||
if test "$[*]" != "X $srcdir/configure conftest.file" \
|
|
||||||
&& test "$[*]" != "X conftest.file $srcdir/configure"; then
|
|
||||||
|
|
||||||
# If neither matched, then we have a broken ls. This can happen
|
|
||||||
# if, for instance, CONFIG_SHELL is bash and it inherits a
|
|
||||||
# broken ls alias from the environment. This has actually
|
|
||||||
# happened. Such a system could not be considered "sane".
|
|
||||||
AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken
|
|
||||||
alias in your environment])
|
|
||||||
fi
|
|
||||||
|
|
||||||
test "$[2]" = conftest.file
|
|
||||||
)
|
|
||||||
then
|
|
||||||
# Ok.
|
|
||||||
:
|
|
||||||
else
|
|
||||||
AC_MSG_ERROR([newly created file is older than distributed files!
|
|
||||||
Check your system clock])
|
|
||||||
fi
|
|
||||||
AC_MSG_RESULT(yes)])
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_PROG_INSTALL_STRIP
|
|
||||||
# ---------------------
|
|
||||||
# One issue with vendor `install' (even GNU) is that you can't
|
|
||||||
# specify the program used to strip binaries. This is especially
|
|
||||||
# annoying in cross-compiling environments, where the build's strip
|
|
||||||
# is unlikely to handle the host's binaries.
|
|
||||||
# Fortunately install-sh will honor a STRIPPROG variable, so we
|
|
||||||
# always use install-sh in `make install-strip', and initialize
|
|
||||||
# STRIPPROG with the value of the STRIP variable (set by the user).
|
|
||||||
AC_DEFUN([AM_PROG_INSTALL_STRIP],
|
|
||||||
[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
|
|
||||||
# Installed binaries are usually stripped using `strip' when the user
|
|
||||||
# run `make install-strip'. However `strip' might not be the right
|
|
||||||
# tool to use in cross-compilation environments, therefore Automake
|
|
||||||
# will honor the `STRIP' environment variable to overrule this program.
|
|
||||||
dnl Don't test for $cross_compiling = yes, because it might be `maybe'.
|
|
||||||
if test "$cross_compiling" != no; then
|
|
||||||
AC_CHECK_TOOL([STRIP], [strip], :)
|
|
||||||
fi
|
|
||||||
INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
|
|
||||||
AC_SUBST([INSTALL_STRIP_PROGRAM])])
|
|
||||||
|
|
||||||
# Copyright (C) 2006, 2008 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 2
|
|
||||||
|
|
||||||
# _AM_SUBST_NOTMAKE(VARIABLE)
|
|
||||||
# ---------------------------
|
|
||||||
# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in.
|
|
||||||
# This macro is traced by Automake.
|
|
||||||
AC_DEFUN([_AM_SUBST_NOTMAKE])
|
|
||||||
|
|
||||||
# AM_SUBST_NOTMAKE(VARIABLE)
|
|
||||||
# ---------------------------
|
|
||||||
# Public sister of _AM_SUBST_NOTMAKE.
|
|
||||||
AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
|
|
||||||
|
|
||||||
# Check how to create a tarball. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2004, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 2
|
|
||||||
|
|
||||||
# _AM_PROG_TAR(FORMAT)
|
|
||||||
# --------------------
|
|
||||||
# Check how to create a tarball in format FORMAT.
|
|
||||||
# FORMAT should be one of `v7', `ustar', or `pax'.
|
|
||||||
#
|
|
||||||
# Substitute a variable $(am__tar) that is a command
|
|
||||||
# writing to stdout a FORMAT-tarball containing the directory
|
|
||||||
# $tardir.
|
|
||||||
# tardir=directory && $(am__tar) > result.tar
|
|
||||||
#
|
|
||||||
# Substitute a variable $(am__untar) that extract such
|
|
||||||
# a tarball read from stdin.
|
|
||||||
# $(am__untar) < result.tar
|
|
||||||
AC_DEFUN([_AM_PROG_TAR],
|
|
||||||
[# Always define AMTAR for backward compatibility.
|
|
||||||
AM_MISSING_PROG([AMTAR], [tar])
|
|
||||||
m4_if([$1], [v7],
|
|
||||||
[am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -'],
|
|
||||||
[m4_case([$1], [ustar],, [pax],,
|
|
||||||
[m4_fatal([Unknown tar format])])
|
|
||||||
AC_MSG_CHECKING([how to create a $1 tar archive])
|
|
||||||
# Loop over all known methods to create a tar archive until one works.
|
|
||||||
_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none'
|
|
||||||
_am_tools=${am_cv_prog_tar_$1-$_am_tools}
|
|
||||||
# Do not fold the above two line into one, because Tru64 sh and
|
|
||||||
# Solaris sh will not grok spaces in the rhs of `-'.
|
|
||||||
for _am_tool in $_am_tools
|
|
||||||
do
|
|
||||||
case $_am_tool in
|
|
||||||
gnutar)
|
|
||||||
for _am_tar in tar gnutar gtar;
|
|
||||||
do
|
|
||||||
AM_RUN_LOG([$_am_tar --version]) && break
|
|
||||||
done
|
|
||||||
am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"'
|
|
||||||
am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"'
|
|
||||||
am__untar="$_am_tar -xf -"
|
|
||||||
;;
|
|
||||||
plaintar)
|
|
||||||
# Must skip GNU tar: if it does not support --format= it doesn't create
|
|
||||||
# ustar tarball either.
|
|
||||||
(tar --version) >/dev/null 2>&1 && continue
|
|
||||||
am__tar='tar chf - "$$tardir"'
|
|
||||||
am__tar_='tar chf - "$tardir"'
|
|
||||||
am__untar='tar xf -'
|
|
||||||
;;
|
|
||||||
pax)
|
|
||||||
am__tar='pax -L -x $1 -w "$$tardir"'
|
|
||||||
am__tar_='pax -L -x $1 -w "$tardir"'
|
|
||||||
am__untar='pax -r'
|
|
||||||
;;
|
|
||||||
cpio)
|
|
||||||
am__tar='find "$$tardir" -print | cpio -o -H $1 -L'
|
|
||||||
am__tar_='find "$tardir" -print | cpio -o -H $1 -L'
|
|
||||||
am__untar='cpio -i -H $1 -d'
|
|
||||||
;;
|
|
||||||
none)
|
|
||||||
am__tar=false
|
|
||||||
am__tar_=false
|
|
||||||
am__untar=false
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# If the value was cached, stop now. We just wanted to have am__tar
|
|
||||||
# and am__untar set.
|
|
||||||
test -n "${am_cv_prog_tar_$1}" && break
|
|
||||||
|
|
||||||
# tar/untar a dummy directory, and stop if the command works
|
|
||||||
rm -rf conftest.dir
|
|
||||||
mkdir conftest.dir
|
|
||||||
echo GrepMe > conftest.dir/file
|
|
||||||
AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar])
|
|
||||||
rm -rf conftest.dir
|
|
||||||
if test -s conftest.tar; then
|
|
||||||
AM_RUN_LOG([$am__untar <conftest.tar])
|
|
||||||
grep GrepMe conftest.dir/file >/dev/null 2>&1 && break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
rm -rf conftest.dir
|
|
||||||
|
|
||||||
AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool])
|
|
||||||
AC_MSG_RESULT([$am_cv_prog_tar_$1])])
|
|
||||||
AC_SUBST([am__tar])
|
|
||||||
AC_SUBST([am__untar])
|
|
||||||
]) # _AM_PROG_TAR
|
|
||||||
|
|
||||||
m4_include([m4/codeset.m4])
|
|
||||||
m4_include([m4/gettext.m4])
|
|
||||||
m4_include([m4/glibc2.m4])
|
|
||||||
m4_include([m4/glibc21.m4])
|
|
||||||
m4_include([m4/iconv.m4])
|
|
||||||
m4_include([m4/intdiv0.m4])
|
|
||||||
m4_include([m4/intl.m4])
|
|
||||||
m4_include([m4/intlmacosx.m4])
|
|
||||||
m4_include([m4/intmax.m4])
|
|
||||||
m4_include([m4/inttypes-pri.m4])
|
|
||||||
m4_include([m4/inttypes_h.m4])
|
|
||||||
m4_include([m4/lcmessage.m4])
|
|
||||||
m4_include([m4/lib-ld.m4])
|
|
||||||
m4_include([m4/lib-link.m4])
|
|
||||||
m4_include([m4/lib-prefix.m4])
|
|
||||||
m4_include([m4/libtool.m4])
|
|
||||||
m4_include([m4/lock.m4])
|
|
||||||
m4_include([m4/longlong.m4])
|
|
||||||
m4_include([m4/ltoptions.m4])
|
|
||||||
m4_include([m4/ltsugar.m4])
|
|
||||||
m4_include([m4/ltversion.m4])
|
|
||||||
m4_include([m4/lt~obsolete.m4])
|
|
||||||
m4_include([m4/nls.m4])
|
|
||||||
m4_include([m4/po.m4])
|
|
||||||
m4_include([m4/printf-posix.m4])
|
|
||||||
m4_include([m4/progtest.m4])
|
|
||||||
m4_include([m4/size_max.m4])
|
|
||||||
m4_include([m4/stdint_h.m4])
|
|
||||||
m4_include([m4/uintmax_t.m4])
|
|
||||||
m4_include([m4/visibility.m4])
|
|
||||||
m4_include([m4/wchar_t.m4])
|
|
||||||
m4_include([m4/wint_t.m4])
|
|
||||||
m4_include([m4/xsize.m4])
|
|
|
@ -1,97 +0,0 @@
|
||||||
{
|
|
||||||
'target_defaults': {
|
|
||||||
'default_configuration': 'Debug',
|
|
||||||
'configurations': {
|
|
||||||
'Debug': {
|
|
||||||
'defines': [ 'DEBUG', '_DEBUG' ],
|
|
||||||
'msvs_settings': {
|
|
||||||
'VCCLCompilerTool': {
|
|
||||||
'RuntimeLibrary': 1, # static debug
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'Release': {
|
|
||||||
'defines': [ 'NDEBUG' ],
|
|
||||||
'msvs_settings': {
|
|
||||||
'VCCLCompilerTool': {
|
|
||||||
'RuntimeLibrary': 0, # static release
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
'msvs_settings': {
|
|
||||||
'VCCLCompilerTool': {
|
|
||||||
},
|
|
||||||
'VCLibrarianTool': {
|
|
||||||
},
|
|
||||||
'VCLinkerTool': {
|
|
||||||
'GenerateDebugInformation': 'true',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'conditions': [
|
|
||||||
['OS == "win"', {
|
|
||||||
'defines': [
|
|
||||||
'WIN32'
|
|
||||||
],
|
|
||||||
}]
|
|
||||||
],
|
|
||||||
},
|
|
||||||
|
|
||||||
'targets': [
|
|
||||||
{
|
|
||||||
'target_name': 'hunspell',
|
|
||||||
'type': 'static_library',
|
|
||||||
'include_dirs': [ 'src/hunspell' ],
|
|
||||||
'defines': [ 'HUNSPELL_STATIC' ],
|
|
||||||
'direct_dependent_settings': {
|
|
||||||
'include_dirs': [ 'src/hunspell' ],
|
|
||||||
'defines': [ 'HUNSPELL_STATIC' ],
|
|
||||||
},
|
|
||||||
'cflags': [ '-O3' ],
|
|
||||||
'sources': [
|
|
||||||
'src/hunspell/affentry.cxx',
|
|
||||||
'src/hunspell/affentry.hxx',
|
|
||||||
'src/hunspell/affixmgr.cxx',
|
|
||||||
'src/hunspell/affixmgr.hxx',
|
|
||||||
'src/hunspell/atypes.hxx',
|
|
||||||
'src/hunspell/baseaffix.hxx',
|
|
||||||
'src/hunspell/csutil.cxx',
|
|
||||||
'src/hunspell/csutil.hxx',
|
|
||||||
'src/hunspell/dictmgr.cxx',
|
|
||||||
'src/hunspell/dictmgr.hxx',
|
|
||||||
'src/hunspell/filemgr.cxx',
|
|
||||||
'src/hunspell/filemgr.hxx',
|
|
||||||
'src/hunspell/hashmgr.cxx',
|
|
||||||
'src/hunspell/hashmgr.hxx',
|
|
||||||
'src/hunspell/htypes.hxx',
|
|
||||||
'src/hunspell/hunspell.cxx',
|
|
||||||
'src/hunspell/hunspell.hxx',
|
|
||||||
'src/hunspell/hunzip.cxx',
|
|
||||||
'src/hunspell/hunzip.hxx',
|
|
||||||
'src/hunspell/istrmgr.hxx',
|
|
||||||
'src/hunspell/langnum.hxx',
|
|
||||||
'src/hunspell/phonet.cxx',
|
|
||||||
'src/hunspell/phonet.hxx',
|
|
||||||
'src/hunspell/replist.cxx',
|
|
||||||
'src/hunspell/replist.hxx',
|
|
||||||
'src/hunspell/strmgr.cxx',
|
|
||||||
'src/hunspell/strmgr.hxx',
|
|
||||||
'src/hunspell/suggestmgr.cxx',
|
|
||||||
'src/hunspell/suggestmgr.hxx',
|
|
||||||
'src/hunspell/w_char.hxx',
|
|
||||||
],
|
|
||||||
'conditions': [
|
|
||||||
['OS=="win"', {
|
|
||||||
'include_dirs': [ 'src/win_api' ],
|
|
||||||
'sources': [
|
|
||||||
'src/win_api/config.h',
|
|
||||||
],
|
|
||||||
}, {
|
|
||||||
'sources': [
|
|
||||||
'src/hunspell/config.h',
|
|
||||||
],
|
|
||||||
}],
|
|
||||||
],
|
|
||||||
},
|
|
||||||
]
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,426 +0,0 @@
|
||||||
/* config.h.in. Generated from configure.ac by autoheader. */
|
|
||||||
|
|
||||||
/* Define to one of `_getb67', `GETB67', `getb67' for Cray-2 and Cray-YMP
|
|
||||||
systems. This function is required for `alloca.c' support on those systems.
|
|
||||||
*/
|
|
||||||
#undef CRAY_STACKSEG_END
|
|
||||||
|
|
||||||
/* Define to 1 if using `alloca.c'. */
|
|
||||||
#undef C_ALLOCA
|
|
||||||
|
|
||||||
/* Define to 1 if translation of program messages to the user's native
|
|
||||||
language is requested. */
|
|
||||||
#undef ENABLE_NLS
|
|
||||||
|
|
||||||
/* Define to 1 if you have `alloca', as a function or macro. */
|
|
||||||
#undef HAVE_ALLOCA
|
|
||||||
|
|
||||||
/* Define to 1 if you have <alloca.h> and it should be used (not on Ultrix).
|
|
||||||
*/
|
|
||||||
#undef HAVE_ALLOCA_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `argz_count' function. */
|
|
||||||
#undef HAVE_ARGZ_COUNT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <argz.h> header file. */
|
|
||||||
#undef HAVE_ARGZ_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `argz_next' function. */
|
|
||||||
#undef HAVE_ARGZ_NEXT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `argz_stringify' function. */
|
|
||||||
#undef HAVE_ARGZ_STRINGIFY
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `asprintf' function. */
|
|
||||||
#undef HAVE_ASPRINTF
|
|
||||||
|
|
||||||
/* Define to 1 if the compiler understands __builtin_expect. */
|
|
||||||
#undef HAVE_BUILTIN_EXPECT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the MacOS X function CFLocaleCopyCurrent in the
|
|
||||||
CoreFoundation framework. */
|
|
||||||
#undef HAVE_CFLOCALECOPYCURRENT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the MacOS X function CFPreferencesCopyAppValue in
|
|
||||||
the CoreFoundation framework. */
|
|
||||||
#undef HAVE_CFPREFERENCESCOPYAPPVALUE
|
|
||||||
|
|
||||||
/* "Define if you have the <curses.h> header" */
|
|
||||||
#undef HAVE_CURSES_H
|
|
||||||
|
|
||||||
/* Define if the GNU dcgettext() function is already present or preinstalled.
|
|
||||||
*/
|
|
||||||
#undef HAVE_DCGETTEXT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `feof_unlocked', and to 0 if you
|
|
||||||
don't. */
|
|
||||||
#undef HAVE_DECL_FEOF_UNLOCKED
|
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `fgets_unlocked', and to 0 if
|
|
||||||
you don't. */
|
|
||||||
#undef HAVE_DECL_FGETS_UNLOCKED
|
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `getc_unlocked', and to 0 if you
|
|
||||||
don't. */
|
|
||||||
#undef HAVE_DECL_GETC_UNLOCKED
|
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `_snprintf', and to 0 if you
|
|
||||||
don't. */
|
|
||||||
#undef HAVE_DECL__SNPRINTF
|
|
||||||
|
|
||||||
/* Define to 1 if you have the declaration of `_snwprintf', and to 0 if you
|
|
||||||
don't. */
|
|
||||||
#undef HAVE_DECL__SNWPRINTF
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <dlfcn.h> header file. */
|
|
||||||
#undef HAVE_DLFCN_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <error.h> header file. */
|
|
||||||
#undef HAVE_ERROR_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <fcntl.h> header file. */
|
|
||||||
#undef HAVE_FCNTL_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `fwprintf' function. */
|
|
||||||
#undef HAVE_FWPRINTF
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `getcwd' function. */
|
|
||||||
#undef HAVE_GETCWD
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `getegid' function. */
|
|
||||||
#undef HAVE_GETEGID
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `geteuid' function. */
|
|
||||||
#undef HAVE_GETEUID
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `getgid' function. */
|
|
||||||
#undef HAVE_GETGID
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `getpagesize' function. */
|
|
||||||
#undef HAVE_GETPAGESIZE
|
|
||||||
|
|
||||||
/* Define if the GNU gettext() function is already present or preinstalled. */
|
|
||||||
#undef HAVE_GETTEXT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `getuid' function. */
|
|
||||||
#undef HAVE_GETUID
|
|
||||||
|
|
||||||
/* Define if you have the iconv() function and it works. */
|
|
||||||
#undef HAVE_ICONV
|
|
||||||
|
|
||||||
/* Define if you have the 'intmax_t' type in <stdint.h> or <inttypes.h>. */
|
|
||||||
#undef HAVE_INTMAX_T
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <inttypes.h> header file. */
|
|
||||||
#undef HAVE_INTTYPES_H
|
|
||||||
|
|
||||||
/* Define if <inttypes.h> exists, doesn't clash with <sys/types.h>, and
|
|
||||||
declares uintmax_t. */
|
|
||||||
#undef HAVE_INTTYPES_H_WITH_UINTMAX
|
|
||||||
|
|
||||||
/* Define if you have <langinfo.h> and nl_langinfo(CODESET). */
|
|
||||||
#undef HAVE_LANGINFO_CODESET
|
|
||||||
|
|
||||||
/* Define if your <locale.h> file defines LC_MESSAGES. */
|
|
||||||
#undef HAVE_LC_MESSAGES
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <libintl.h> header file. */
|
|
||||||
#undef HAVE_LIBINTL_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <limits.h> header file. */
|
|
||||||
#undef HAVE_LIMITS_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <locale.h> header file. */
|
|
||||||
#undef HAVE_LOCALE_H
|
|
||||||
|
|
||||||
/* Define to 1 if the system has the type `long long int'. */
|
|
||||||
#undef HAVE_LONG_LONG_INT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `memchr' function. */
|
|
||||||
#undef HAVE_MEMCHR
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <memory.h> header file. */
|
|
||||||
#undef HAVE_MEMORY_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `mempcpy' function. */
|
|
||||||
#undef HAVE_MEMPCPY
|
|
||||||
|
|
||||||
/* Define to 1 if you have a working `mmap' system call. */
|
|
||||||
#undef HAVE_MMAP
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `munmap' function. */
|
|
||||||
#undef HAVE_MUNMAP
|
|
||||||
|
|
||||||
/* "Define if you have the <ncursesw/curses.h> header" */
|
|
||||||
#undef HAVE_NCURSESW_H
|
|
||||||
|
|
||||||
/* Define if you have <langinfo.h> and it defines the NL_LOCALE_NAME macro if
|
|
||||||
_GNU_SOURCE is defined. */
|
|
||||||
#undef HAVE_NL_LOCALE_NAME
|
|
||||||
|
|
||||||
/* Define if your printf() function supports format strings with positions. */
|
|
||||||
#undef HAVE_POSIX_PRINTF
|
|
||||||
|
|
||||||
/* Define if the <pthread.h> defines PTHREAD_MUTEX_RECURSIVE. */
|
|
||||||
#undef HAVE_PTHREAD_MUTEX_RECURSIVE
|
|
||||||
|
|
||||||
/* Define if the POSIX multithreading library has read/write locks. */
|
|
||||||
#undef HAVE_PTHREAD_RWLOCK
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `putenv' function. */
|
|
||||||
#undef HAVE_PUTENV
|
|
||||||
|
|
||||||
/* "Define if you have fancy command input editing with Readline" */
|
|
||||||
#undef HAVE_READLINE
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `setenv' function. */
|
|
||||||
#undef HAVE_SETENV
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `setlocale' function. */
|
|
||||||
#undef HAVE_SETLOCALE
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `snprintf' function. */
|
|
||||||
#undef HAVE_SNPRINTF
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stddef.h> header file. */
|
|
||||||
#undef HAVE_STDDEF_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stdint.h> header file. */
|
|
||||||
#undef HAVE_STDINT_H
|
|
||||||
|
|
||||||
/* Define if <stdint.h> exists, doesn't clash with <sys/types.h>, and declares
|
|
||||||
uintmax_t. */
|
|
||||||
#undef HAVE_STDINT_H_WITH_UINTMAX
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stdlib.h> header file. */
|
|
||||||
#undef HAVE_STDLIB_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `stpcpy' function. */
|
|
||||||
#undef HAVE_STPCPY
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strcasecmp' function. */
|
|
||||||
#undef HAVE_STRCASECMP
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strchr' function. */
|
|
||||||
#undef HAVE_STRCHR
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strdup' function. */
|
|
||||||
#undef HAVE_STRDUP
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <strings.h> header file. */
|
|
||||||
#undef HAVE_STRINGS_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <string.h> header file. */
|
|
||||||
#undef HAVE_STRING_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strstr' function. */
|
|
||||||
#undef HAVE_STRSTR
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strtoul' function. */
|
|
||||||
#undef HAVE_STRTOUL
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/param.h> header file. */
|
|
||||||
#undef HAVE_SYS_PARAM_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/stat.h> header file. */
|
|
||||||
#undef HAVE_SYS_STAT_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/types.h> header file. */
|
|
||||||
#undef HAVE_SYS_TYPES_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `tsearch' function. */
|
|
||||||
#undef HAVE_TSEARCH
|
|
||||||
|
|
||||||
/* Define if you have the 'uintmax_t' type in <stdint.h> or <inttypes.h>. */
|
|
||||||
#undef HAVE_UINTMAX_T
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <unistd.h> header file. */
|
|
||||||
#undef HAVE_UNISTD_H
|
|
||||||
|
|
||||||
/* Define to 1 if the system has the type `unsigned long long int'. */
|
|
||||||
#undef HAVE_UNSIGNED_LONG_LONG_INT
|
|
||||||
|
|
||||||
/* Define to 1 or 0, depending whether the compiler supports simple visibility
|
|
||||||
declarations. */
|
|
||||||
#undef HAVE_VISIBILITY
|
|
||||||
|
|
||||||
/* Define if you have the 'wchar_t' type. */
|
|
||||||
#undef HAVE_WCHAR_T
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `wcslen' function. */
|
|
||||||
#undef HAVE_WCSLEN
|
|
||||||
|
|
||||||
/* Define if you have the 'wint_t' type. */
|
|
||||||
#undef HAVE_WINT_T
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `__fsetlocking' function. */
|
|
||||||
#undef HAVE___FSETLOCKING
|
|
||||||
|
|
||||||
/* "Define if you use exterimental functions" */
|
|
||||||
#undef HUNSPELL_EXPERIMENTAL
|
|
||||||
|
|
||||||
/* "Define if you need warning messages" */
|
|
||||||
#undef HUNSPELL_WARNING_ON
|
|
||||||
|
|
||||||
/* Define as const if the declaration of iconv() needs const. */
|
|
||||||
#undef ICONV_CONST
|
|
||||||
|
|
||||||
/* Define if integer division by zero raises signal SIGFPE. */
|
|
||||||
#undef INTDIV0_RAISES_SIGFPE
|
|
||||||
|
|
||||||
/* Define to the sub-directory in which libtool stores uninstalled libraries.
|
|
||||||
*/
|
|
||||||
#undef LT_OBJDIR
|
|
||||||
|
|
||||||
/* Name of package */
|
|
||||||
#undef PACKAGE
|
|
||||||
|
|
||||||
/* Define to the address where bug reports for this package should be sent. */
|
|
||||||
#undef PACKAGE_BUGREPORT
|
|
||||||
|
|
||||||
/* Define to the full name of this package. */
|
|
||||||
#undef PACKAGE_NAME
|
|
||||||
|
|
||||||
/* Define to the full name and version of this package. */
|
|
||||||
#undef PACKAGE_STRING
|
|
||||||
|
|
||||||
/* Define to the one symbol short name of this package. */
|
|
||||||
#undef PACKAGE_TARNAME
|
|
||||||
|
|
||||||
/* Define to the home page for this package. */
|
|
||||||
#undef PACKAGE_URL
|
|
||||||
|
|
||||||
/* Define to the version of this package. */
|
|
||||||
#undef PACKAGE_VERSION
|
|
||||||
|
|
||||||
/* Define if <inttypes.h> exists and defines unusable PRI* macros. */
|
|
||||||
#undef PRI_MACROS_BROKEN
|
|
||||||
|
|
||||||
/* Define if the pthread_in_use() detection is hard. */
|
|
||||||
#undef PTHREAD_IN_USE_DETECTION_HARD
|
|
||||||
|
|
||||||
/* Define as the maximum value of type 'size_t', if the system doesn't define
|
|
||||||
it. */
|
|
||||||
#undef SIZE_MAX
|
|
||||||
|
|
||||||
/* If using the C implementation of alloca, define if you know the
|
|
||||||
direction of stack growth for your system; otherwise it will be
|
|
||||||
automatically deduced at runtime.
|
|
||||||
STACK_DIRECTION > 0 => grows toward higher addresses
|
|
||||||
STACK_DIRECTION < 0 => grows toward lower addresses
|
|
||||||
STACK_DIRECTION = 0 => direction of growth unknown */
|
|
||||||
#undef STACK_DIRECTION
|
|
||||||
|
|
||||||
/* Define to 1 if you have the ANSI C header files. */
|
|
||||||
#undef STDC_HEADERS
|
|
||||||
|
|
||||||
/* Define if the POSIX multithreading library can be used. */
|
|
||||||
#undef USE_POSIX_THREADS
|
|
||||||
|
|
||||||
/* Define if references to the POSIX multithreading library should be made
|
|
||||||
weak. */
|
|
||||||
#undef USE_POSIX_THREADS_WEAK
|
|
||||||
|
|
||||||
/* Define if the GNU Pth multithreading library can be used. */
|
|
||||||
#undef USE_PTH_THREADS
|
|
||||||
|
|
||||||
/* Define if references to the GNU Pth multithreading library should be made
|
|
||||||
weak. */
|
|
||||||
#undef USE_PTH_THREADS_WEAK
|
|
||||||
|
|
||||||
/* Define if the old Solaris multithreading library can be used. */
|
|
||||||
#undef USE_SOLARIS_THREADS
|
|
||||||
|
|
||||||
/* Define if references to the old Solaris multithreading library should be
|
|
||||||
made weak. */
|
|
||||||
#undef USE_SOLARIS_THREADS_WEAK
|
|
||||||
|
|
||||||
/* Enable extensions on AIX 3, Interix. */
|
|
||||||
#ifndef _ALL_SOURCE
|
|
||||||
# undef _ALL_SOURCE
|
|
||||||
#endif
|
|
||||||
/* Enable GNU extensions on systems that have them. */
|
|
||||||
#ifndef _GNU_SOURCE
|
|
||||||
# undef _GNU_SOURCE
|
|
||||||
#endif
|
|
||||||
/* Enable threading extensions on Solaris. */
|
|
||||||
#ifndef _POSIX_PTHREAD_SEMANTICS
|
|
||||||
# undef _POSIX_PTHREAD_SEMANTICS
|
|
||||||
#endif
|
|
||||||
/* Enable extensions on HP NonStop. */
|
|
||||||
#ifndef _TANDEM_SOURCE
|
|
||||||
# undef _TANDEM_SOURCE
|
|
||||||
#endif
|
|
||||||
/* Enable general extensions on Solaris. */
|
|
||||||
#ifndef __EXTENSIONS__
|
|
||||||
# undef __EXTENSIONS__
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Define if the Win32 multithreading API can be used. */
|
|
||||||
#undef USE_WIN32_THREADS
|
|
||||||
|
|
||||||
/* Version number of package */
|
|
||||||
#undef VERSION
|
|
||||||
|
|
||||||
/* Define to 1 if on MINIX. */
|
|
||||||
#undef _MINIX
|
|
||||||
|
|
||||||
/* Define to 2 if the system does not provide POSIX.1 features except with
|
|
||||||
this defined. */
|
|
||||||
#undef _POSIX_1_SOURCE
|
|
||||||
|
|
||||||
/* Define to 1 if you need to in order for `stat' and other things to work. */
|
|
||||||
#undef _POSIX_SOURCE
|
|
||||||
|
|
||||||
/* Define to empty if `const' does not conform to ANSI C. */
|
|
||||||
#undef const
|
|
||||||
|
|
||||||
/* Define to `__inline__' or `__inline' if that's what the C compiler
|
|
||||||
calls it, or to nothing if 'inline' is not supported under any name. */
|
|
||||||
#ifndef __cplusplus
|
|
||||||
#undef inline
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Define as the type of the result of subtracting two pointers, if the system
|
|
||||||
doesn't define it. */
|
|
||||||
#undef ptrdiff_t
|
|
||||||
|
|
||||||
/* Define to `unsigned int' if <sys/types.h> does not define. */
|
|
||||||
#undef size_t
|
|
||||||
|
|
||||||
/* Define to unsigned long or unsigned long long if <stdint.h> and
|
|
||||||
<inttypes.h> don't define. */
|
|
||||||
#undef uintmax_t
|
|
||||||
|
|
||||||
|
|
||||||
#define __libc_lock_t gl_lock_t
|
|
||||||
#define __libc_lock_define gl_lock_define
|
|
||||||
#define __libc_lock_define_initialized gl_lock_define_initialized
|
|
||||||
#define __libc_lock_init gl_lock_init
|
|
||||||
#define __libc_lock_lock gl_lock_lock
|
|
||||||
#define __libc_lock_unlock gl_lock_unlock
|
|
||||||
#define __libc_lock_recursive_t gl_recursive_lock_t
|
|
||||||
#define __libc_lock_define_recursive gl_recursive_lock_define
|
|
||||||
#define __libc_lock_define_initialized_recursive gl_recursive_lock_define_initialized
|
|
||||||
#define __libc_lock_init_recursive gl_recursive_lock_init
|
|
||||||
#define __libc_lock_lock_recursive gl_recursive_lock_lock
|
|
||||||
#define __libc_lock_unlock_recursive gl_recursive_lock_unlock
|
|
||||||
#define glthread_in_use libintl_thread_in_use
|
|
||||||
#define glthread_lock_init libintl_lock_init
|
|
||||||
#define glthread_lock_lock libintl_lock_lock
|
|
||||||
#define glthread_lock_unlock libintl_lock_unlock
|
|
||||||
#define glthread_lock_destroy libintl_lock_destroy
|
|
||||||
#define glthread_rwlock_init libintl_rwlock_init
|
|
||||||
#define glthread_rwlock_rdlock libintl_rwlock_rdlock
|
|
||||||
#define glthread_rwlock_wrlock libintl_rwlock_wrlock
|
|
||||||
#define glthread_rwlock_unlock libintl_rwlock_unlock
|
|
||||||
#define glthread_rwlock_destroy libintl_rwlock_destroy
|
|
||||||
#define glthread_recursive_lock_init libintl_recursive_lock_init
|
|
||||||
#define glthread_recursive_lock_lock libintl_recursive_lock_lock
|
|
||||||
#define glthread_recursive_lock_unlock libintl_recursive_lock_unlock
|
|
||||||
#define glthread_recursive_lock_destroy libintl_recursive_lock_destroy
|
|
||||||
#define glthread_once libintl_once
|
|
||||||
#define glthread_once_call libintl_once_call
|
|
||||||
#define glthread_once_singlethreaded libintl_once_singlethreaded
|
|
||||||
|
|
|
@ -1,666 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
# Output a system dependent set of variables, describing how to set the
|
|
||||||
# run time search path of shared libraries in an executable.
|
|
||||||
#
|
|
||||||
# Copyright 1996-2007 Free Software Foundation, Inc.
|
|
||||||
# Taken from GNU libtool, 2001
|
|
||||||
# Originally by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation gives
|
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
|
||||||
# modifications, as long as this notice is preserved.
|
|
||||||
#
|
|
||||||
# The first argument passed to this file is the canonical host specification,
|
|
||||||
# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM
|
|
||||||
# or
|
|
||||||
# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
|
|
||||||
# The environment variables CC, GCC, LDFLAGS, LD, with_gnu_ld
|
|
||||||
# should be set by the caller.
|
|
||||||
#
|
|
||||||
# The set of defined variables is at the end of this script.
|
|
||||||
|
|
||||||
# Known limitations:
|
|
||||||
# - On IRIX 6.5 with CC="cc", the run time search patch must not be longer
|
|
||||||
# than 256 bytes, otherwise the compiler driver will dump core. The only
|
|
||||||
# known workaround is to choose shorter directory names for the build
|
|
||||||
# directory and/or the installation directory.
|
|
||||||
|
|
||||||
# All known linkers require a `.a' archive for static linking (except MSVC,
|
|
||||||
# which needs '.lib').
|
|
||||||
libext=a
|
|
||||||
shrext=.so
|
|
||||||
|
|
||||||
host="$1"
|
|
||||||
host_cpu=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'`
|
|
||||||
host_vendor=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'`
|
|
||||||
host_os=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'`
|
|
||||||
|
|
||||||
# Code taken from libtool.m4's _LT_CC_BASENAME.
|
|
||||||
|
|
||||||
for cc_temp in $CC""; do
|
|
||||||
case $cc_temp in
|
|
||||||
compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
|
|
||||||
distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
|
|
||||||
\-*) ;;
|
|
||||||
*) break;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
cc_basename=`echo "$cc_temp" | sed -e 's%^.*/%%'`
|
|
||||||
|
|
||||||
# Code taken from libtool.m4's AC_LIBTOOL_PROG_COMPILER_PIC.
|
|
||||||
|
|
||||||
wl=
|
|
||||||
if test "$GCC" = yes; then
|
|
||||||
wl='-Wl,'
|
|
||||||
else
|
|
||||||
case "$host_os" in
|
|
||||||
aix*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
darwin*)
|
|
||||||
case $cc_basename in
|
|
||||||
xlc*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
mingw* | cygwin* | pw32* | os2*)
|
|
||||||
;;
|
|
||||||
hpux9* | hpux10* | hpux11*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
irix5* | irix6* | nonstopux*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
newsos6)
|
|
||||||
;;
|
|
||||||
linux* | k*bsd*-gnu)
|
|
||||||
case $cc_basename in
|
|
||||||
icc* | ecc*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
pgcc | pgf77 | pgf90)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
ccc*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
como)
|
|
||||||
wl='-lopt='
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
case `$CC -V 2>&1 | sed 5q` in
|
|
||||||
*Sun\ C*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
osf3* | osf4* | osf5*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
rdos*)
|
|
||||||
;;
|
|
||||||
solaris*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
sunos4*)
|
|
||||||
wl='-Qoption ld '
|
|
||||||
;;
|
|
||||||
sysv4 | sysv4.2uw2* | sysv4.3*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
sysv4*MP*)
|
|
||||||
;;
|
|
||||||
sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
unicos*)
|
|
||||||
wl='-Wl,'
|
|
||||||
;;
|
|
||||||
uts4*)
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Code taken from libtool.m4's AC_LIBTOOL_PROG_LD_SHLIBS.
|
|
||||||
|
|
||||||
hardcode_libdir_flag_spec=
|
|
||||||
hardcode_libdir_separator=
|
|
||||||
hardcode_direct=no
|
|
||||||
hardcode_minus_L=no
|
|
||||||
|
|
||||||
case "$host_os" in
|
|
||||||
cygwin* | mingw* | pw32*)
|
|
||||||
# FIXME: the MSVC++ port hasn't been tested in a loooong time
|
|
||||||
# When not using gcc, we currently assume that we are using
|
|
||||||
# Microsoft Visual C++.
|
|
||||||
if test "$GCC" != yes; then
|
|
||||||
with_gnu_ld=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
interix*)
|
|
||||||
# we just hope/assume this is gcc and not c89 (= MSVC++)
|
|
||||||
with_gnu_ld=yes
|
|
||||||
;;
|
|
||||||
openbsd*)
|
|
||||||
with_gnu_ld=no
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
ld_shlibs=yes
|
|
||||||
if test "$with_gnu_ld" = yes; then
|
|
||||||
# Set some defaults for GNU ld with shared library support. These
|
|
||||||
# are reset later if shared libraries are not supported. Putting them
|
|
||||||
# here allows them to be overridden if necessary.
|
|
||||||
# Unlike libtool, we use -rpath here, not --rpath, since the documented
|
|
||||||
# option of GNU ld is called -rpath, not --rpath.
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
|
|
||||||
case "$host_os" in
|
|
||||||
aix3* | aix4* | aix5*)
|
|
||||||
# On AIX/PPC, the GNU linker is very broken
|
|
||||||
if test "$host_cpu" != ia64; then
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
amigaos*)
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
# Samuel A. Falvo II <kc5tja@dolphin.openprojects.net> reports
|
|
||||||
# that the semantics of dynamic libraries on AmigaOS, at least up
|
|
||||||
# to version 4, is to share data among multiple programs linked
|
|
||||||
# with the same dynamic library. Since this doesn't match the
|
|
||||||
# behavior of shared libraries on other platforms, we cannot use
|
|
||||||
# them.
|
|
||||||
ld_shlibs=no
|
|
||||||
;;
|
|
||||||
beos*)
|
|
||||||
if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
cygwin* | mingw* | pw32*)
|
|
||||||
# hardcode_libdir_flag_spec is actually meaningless, as there is
|
|
||||||
# no search path for DLLs.
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
interix[3-9]*)
|
|
||||||
hardcode_direct=no
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
|
|
||||||
;;
|
|
||||||
gnu* | linux* | k*bsd*-gnu)
|
|
||||||
if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
netbsd*)
|
|
||||||
;;
|
|
||||||
solaris*)
|
|
||||||
if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then
|
|
||||||
ld_shlibs=no
|
|
||||||
elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*)
|
|
||||||
case `$LD -v 2>&1` in
|
|
||||||
*\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*)
|
|
||||||
ld_shlibs=no
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
|
|
||||||
hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`'
|
|
||||||
else
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
sunos4*)
|
|
||||||
hardcode_direct=yes
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
if test "$ld_shlibs" = no; then
|
|
||||||
hardcode_libdir_flag_spec=
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
case "$host_os" in
|
|
||||||
aix3*)
|
|
||||||
# Note: this linker hardcodes the directories in LIBPATH if there
|
|
||||||
# are no directories specified by -L.
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
if test "$GCC" = yes; then
|
|
||||||
# Neither direct hardcoding nor static linking is supported with a
|
|
||||||
# broken collect2.
|
|
||||||
hardcode_direct=unsupported
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
aix4* | aix5*)
|
|
||||||
if test "$host_cpu" = ia64; then
|
|
||||||
# On IA64, the linker does run time linking by default, so we don't
|
|
||||||
# have to do anything special.
|
|
||||||
aix_use_runtimelinking=no
|
|
||||||
else
|
|
||||||
aix_use_runtimelinking=no
|
|
||||||
# Test if we are trying to use run time linking or normal
|
|
||||||
# AIX style linking. If -brtl is somewhere in LDFLAGS, we
|
|
||||||
# need to do runtime linking.
|
|
||||||
case $host_os in aix4.[23]|aix4.[23].*|aix5*)
|
|
||||||
for ld_flag in $LDFLAGS; do
|
|
||||||
if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
|
|
||||||
aix_use_runtimelinking=yes
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
hardcode_direct=yes
|
|
||||||
hardcode_libdir_separator=':'
|
|
||||||
if test "$GCC" = yes; then
|
|
||||||
case $host_os in aix4.[012]|aix4.[012].*)
|
|
||||||
collect2name=`${CC} -print-prog-name=collect2`
|
|
||||||
if test -f "$collect2name" && \
|
|
||||||
strings "$collect2name" | grep resolve_lib_name >/dev/null
|
|
||||||
then
|
|
||||||
# We have reworked collect2
|
|
||||||
:
|
|
||||||
else
|
|
||||||
# We have old collect2
|
|
||||||
hardcode_direct=unsupported
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
hardcode_libdir_separator=
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
# Begin _LT_AC_SYS_LIBPATH_AIX.
|
|
||||||
echo 'int main () { return 0; }' > conftest.c
|
|
||||||
${CC} ${LDFLAGS} conftest.c -o conftest
|
|
||||||
aix_libpath=`dump -H conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; }
|
|
||||||
}'`
|
|
||||||
if test -z "$aix_libpath"; then
|
|
||||||
aix_libpath=`dump -HX64 conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; }
|
|
||||||
}'`
|
|
||||||
fi
|
|
||||||
if test -z "$aix_libpath"; then
|
|
||||||
aix_libpath="/usr/lib:/lib"
|
|
||||||
fi
|
|
||||||
rm -f conftest.c conftest
|
|
||||||
# End _LT_AC_SYS_LIBPATH_AIX.
|
|
||||||
if test "$aix_use_runtimelinking" = yes; then
|
|
||||||
hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
|
|
||||||
else
|
|
||||||
if test "$host_cpu" = ia64; then
|
|
||||||
hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib'
|
|
||||||
else
|
|
||||||
hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
amigaos*)
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
# see comment about different semantics on the GNU ld section
|
|
||||||
ld_shlibs=no
|
|
||||||
;;
|
|
||||||
bsdi[45]*)
|
|
||||||
;;
|
|
||||||
cygwin* | mingw* | pw32*)
|
|
||||||
# When not using gcc, we currently assume that we are using
|
|
||||||
# Microsoft Visual C++.
|
|
||||||
# hardcode_libdir_flag_spec is actually meaningless, as there is
|
|
||||||
# no search path for DLLs.
|
|
||||||
hardcode_libdir_flag_spec=' '
|
|
||||||
libext=lib
|
|
||||||
;;
|
|
||||||
darwin* | rhapsody*)
|
|
||||||
hardcode_direct=no
|
|
||||||
if test "$GCC" = yes ; then
|
|
||||||
:
|
|
||||||
else
|
|
||||||
case $cc_basename in
|
|
||||||
xlc*)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
ld_shlibs=no
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
dgux*)
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
;;
|
|
||||||
freebsd1*)
|
|
||||||
ld_shlibs=no
|
|
||||||
;;
|
|
||||||
freebsd2.2*)
|
|
||||||
hardcode_libdir_flag_spec='-R$libdir'
|
|
||||||
hardcode_direct=yes
|
|
||||||
;;
|
|
||||||
freebsd2*)
|
|
||||||
hardcode_direct=yes
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
;;
|
|
||||||
freebsd* | dragonfly*)
|
|
||||||
hardcode_libdir_flag_spec='-R$libdir'
|
|
||||||
hardcode_direct=yes
|
|
||||||
;;
|
|
||||||
hpux9*)
|
|
||||||
hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
|
|
||||||
hardcode_libdir_separator=:
|
|
||||||
hardcode_direct=yes
|
|
||||||
# hardcode_minus_L: Not really in the search PATH,
|
|
||||||
# but as the default location of the library.
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
;;
|
|
||||||
hpux10*)
|
|
||||||
if test "$with_gnu_ld" = no; then
|
|
||||||
hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
|
|
||||||
hardcode_libdir_separator=:
|
|
||||||
hardcode_direct=yes
|
|
||||||
# hardcode_minus_L: Not really in the search PATH,
|
|
||||||
# but as the default location of the library.
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
hpux11*)
|
|
||||||
if test "$with_gnu_ld" = no; then
|
|
||||||
hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
|
|
||||||
hardcode_libdir_separator=:
|
|
||||||
case $host_cpu in
|
|
||||||
hppa*64*|ia64*)
|
|
||||||
hardcode_direct=no
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
hardcode_direct=yes
|
|
||||||
# hardcode_minus_L: Not really in the search PATH,
|
|
||||||
# but as the default location of the library.
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
irix5* | irix6* | nonstopux*)
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
|
|
||||||
hardcode_libdir_separator=:
|
|
||||||
;;
|
|
||||||
netbsd*)
|
|
||||||
hardcode_libdir_flag_spec='-R$libdir'
|
|
||||||
hardcode_direct=yes
|
|
||||||
;;
|
|
||||||
newsos6)
|
|
||||||
hardcode_direct=yes
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
|
|
||||||
hardcode_libdir_separator=:
|
|
||||||
;;
|
|
||||||
openbsd*)
|
|
||||||
if test -f /usr/libexec/ld.so; then
|
|
||||||
hardcode_direct=yes
|
|
||||||
if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
|
|
||||||
else
|
|
||||||
case "$host_os" in
|
|
||||||
openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*)
|
|
||||||
hardcode_libdir_flag_spec='-R$libdir'
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
ld_shlibs=no
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
os2*)
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
;;
|
|
||||||
osf3*)
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
|
|
||||||
hardcode_libdir_separator=:
|
|
||||||
;;
|
|
||||||
osf4* | osf5*)
|
|
||||||
if test "$GCC" = yes; then
|
|
||||||
hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
|
|
||||||
else
|
|
||||||
# Both cc and cxx compiler support -rpath directly
|
|
||||||
hardcode_libdir_flag_spec='-rpath $libdir'
|
|
||||||
fi
|
|
||||||
hardcode_libdir_separator=:
|
|
||||||
;;
|
|
||||||
solaris*)
|
|
||||||
hardcode_libdir_flag_spec='-R$libdir'
|
|
||||||
;;
|
|
||||||
sunos4*)
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
hardcode_direct=yes
|
|
||||||
hardcode_minus_L=yes
|
|
||||||
;;
|
|
||||||
sysv4)
|
|
||||||
case $host_vendor in
|
|
||||||
sni)
|
|
||||||
hardcode_direct=yes # is this really true???
|
|
||||||
;;
|
|
||||||
siemens)
|
|
||||||
hardcode_direct=no
|
|
||||||
;;
|
|
||||||
motorola)
|
|
||||||
hardcode_direct=no #Motorola manual says yes, but my tests say they lie
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
sysv4.3*)
|
|
||||||
;;
|
|
||||||
sysv4*MP*)
|
|
||||||
if test -d /usr/nec; then
|
|
||||||
ld_shlibs=yes
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*)
|
|
||||||
;;
|
|
||||||
sysv5* | sco3.2v5* | sco5v6*)
|
|
||||||
hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`'
|
|
||||||
hardcode_libdir_separator=':'
|
|
||||||
;;
|
|
||||||
uts4*)
|
|
||||||
hardcode_libdir_flag_spec='-L$libdir'
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
ld_shlibs=no
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check dynamic linker characteristics
|
|
||||||
# Code taken from libtool.m4's AC_LIBTOOL_SYS_DYNAMIC_LINKER.
|
|
||||||
# Unlike libtool.m4, here we don't care about _all_ names of the library, but
|
|
||||||
# only about the one the linker finds when passed -lNAME. This is the last
|
|
||||||
# element of library_names_spec in libtool.m4, or possibly two of them if the
|
|
||||||
# linker has special search rules.
|
|
||||||
library_names_spec= # the last element of library_names_spec in libtool.m4
|
|
||||||
libname_spec='lib$name'
|
|
||||||
case "$host_os" in
|
|
||||||
aix3*)
|
|
||||||
library_names_spec='$libname.a'
|
|
||||||
;;
|
|
||||||
aix4* | aix5*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
amigaos*)
|
|
||||||
library_names_spec='$libname.a'
|
|
||||||
;;
|
|
||||||
beos*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
bsdi[45]*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
cygwin* | mingw* | pw32*)
|
|
||||||
shrext=.dll
|
|
||||||
library_names_spec='$libname.dll.a $libname.lib'
|
|
||||||
;;
|
|
||||||
darwin* | rhapsody*)
|
|
||||||
shrext=.dylib
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
dgux*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
freebsd1*)
|
|
||||||
;;
|
|
||||||
freebsd* | dragonfly*)
|
|
||||||
case "$host_os" in
|
|
||||||
freebsd[123]*)
|
|
||||||
library_names_spec='$libname$shrext$versuffix' ;;
|
|
||||||
*)
|
|
||||||
library_names_spec='$libname$shrext' ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
gnu*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
hpux9* | hpux10* | hpux11*)
|
|
||||||
case $host_cpu in
|
|
||||||
ia64*)
|
|
||||||
shrext=.so
|
|
||||||
;;
|
|
||||||
hppa*64*)
|
|
||||||
shrext=.sl
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
shrext=.sl
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
interix[3-9]*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
irix5* | irix6* | nonstopux*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
case "$host_os" in
|
|
||||||
irix5* | nonstopux*)
|
|
||||||
libsuff= shlibsuff=
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
case $LD in
|
|
||||||
*-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= ;;
|
|
||||||
*-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 ;;
|
|
||||||
*-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 ;;
|
|
||||||
*) libsuff= shlibsuff= ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
linux*oldld* | linux*aout* | linux*coff*)
|
|
||||||
;;
|
|
||||||
linux* | k*bsd*-gnu)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
knetbsd*-gnu)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
netbsd*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
newsos6)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
nto-qnx*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
openbsd*)
|
|
||||||
library_names_spec='$libname$shrext$versuffix'
|
|
||||||
;;
|
|
||||||
os2*)
|
|
||||||
libname_spec='$name'
|
|
||||||
shrext=.dll
|
|
||||||
library_names_spec='$libname.a'
|
|
||||||
;;
|
|
||||||
osf3* | osf4* | osf5*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
rdos*)
|
|
||||||
;;
|
|
||||||
solaris*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
sunos4*)
|
|
||||||
library_names_spec='$libname$shrext$versuffix'
|
|
||||||
;;
|
|
||||||
sysv4 | sysv4.3*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
sysv4*MP*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
uts4*)
|
|
||||||
library_names_spec='$libname$shrext'
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
sed_quote_subst='s/\(["`$\\]\)/\\\1/g'
|
|
||||||
escaped_wl=`echo "X$wl" | sed -e 's/^X//' -e "$sed_quote_subst"`
|
|
||||||
shlibext=`echo "$shrext" | sed -e 's,^\.,,'`
|
|
||||||
escaped_libname_spec=`echo "X$libname_spec" | sed -e 's/^X//' -e "$sed_quote_subst"`
|
|
||||||
escaped_library_names_spec=`echo "X$library_names_spec" | sed -e 's/^X//' -e "$sed_quote_subst"`
|
|
||||||
escaped_hardcode_libdir_flag_spec=`echo "X$hardcode_libdir_flag_spec" | sed -e 's/^X//' -e "$sed_quote_subst"`
|
|
||||||
|
|
||||||
LC_ALL=C sed -e 's/^\([a-zA-Z0-9_]*\)=/acl_cv_\1=/' <<EOF
|
|
||||||
|
|
||||||
# How to pass a linker flag through the compiler.
|
|
||||||
wl="$escaped_wl"
|
|
||||||
|
|
||||||
# Static library suffix (normally "a").
|
|
||||||
libext="$libext"
|
|
||||||
|
|
||||||
# Shared library suffix (normally "so").
|
|
||||||
shlibext="$shlibext"
|
|
||||||
|
|
||||||
# Format of library name prefix.
|
|
||||||
libname_spec="$escaped_libname_spec"
|
|
||||||
|
|
||||||
# Library names that the linker finds when passed -lNAME.
|
|
||||||
library_names_spec="$escaped_library_names_spec"
|
|
||||||
|
|
||||||
# Flag to hardcode \$libdir into a binary during linking.
|
|
||||||
# This must work even if \$libdir does not exist.
|
|
||||||
hardcode_libdir_flag_spec="$escaped_hardcode_libdir_flag_spec"
|
|
||||||
|
|
||||||
# Whether we need a single -rpath flag with a separated argument.
|
|
||||||
hardcode_libdir_separator="$hardcode_libdir_separator"
|
|
||||||
|
|
||||||
# Set to yes if using DIR/libNAME.so during linking hardcodes DIR into the
|
|
||||||
# resulting binary.
|
|
||||||
hardcode_direct="$hardcode_direct"
|
|
||||||
|
|
||||||
# Set to yes if using the -LDIR flag during linking hardcodes DIR into the
|
|
||||||
# resulting binary.
|
|
||||||
hardcode_minus_L="$hardcode_minus_L"
|
|
||||||
|
|
||||||
EOF
|
|
File diff suppressed because it is too large
Load diff
23301
NodeJsProjects/SpellChecker/nodehun/src/hunspell/configure
vendored
23301
NodeJsProjects/SpellChecker/nodehun/src/hunspell/configure
vendored
File diff suppressed because it is too large
Load diff
|
@ -1,118 +0,0 @@
|
||||||
# -*- Autoconf -*-
|
|
||||||
# Process this file with autoconf to produce a configure script.
|
|
||||||
|
|
||||||
m4_pattern_allow
|
|
||||||
|
|
||||||
AC_PREREQ(2.59)
|
|
||||||
AC_INIT([hunspell],[1.3.2],[nemeth@numbertext.org])
|
|
||||||
|
|
||||||
AC_CANONICAL_SYSTEM
|
|
||||||
AC_SUBST(XFAILED)
|
|
||||||
|
|
||||||
AM_INIT_AUTOMAKE(hunspell, 1.3.2)
|
|
||||||
HUNSPELL_VERSION_MAJOR=`echo $VERSION | cut -d"." -f1`
|
|
||||||
HUNSPELL_VERSION_MINOR=`echo $VERSION | cut -d"." -f2`
|
|
||||||
AC_SUBST(HUNSPELL_VERSION_MAJOR)
|
|
||||||
AC_SUBST(HUNSPELL_VERSION_MINOR)
|
|
||||||
|
|
||||||
AC_CONFIG_SRCDIR([config.h.in])
|
|
||||||
AC_CONFIG_HEADER([config.h])
|
|
||||||
|
|
||||||
# Checks for programs.
|
|
||||||
AC_PROG_CXX
|
|
||||||
AC_PROG_CC
|
|
||||||
AC_PROG_LIBTOOL
|
|
||||||
AC_LIBTOOL_WIN32_DLL
|
|
||||||
|
|
||||||
# Checks for libraries.
|
|
||||||
|
|
||||||
# Checks for header files.
|
|
||||||
|
|
||||||
AC_CHECK_HEADERS([fcntl.h libintl.h locale.h unistd.h error.h])
|
|
||||||
|
|
||||||
# Checks for typedefs, structures, and compiler characteristics.
|
|
||||||
AC_C_CONST
|
|
||||||
AC_C_INLINE
|
|
||||||
|
|
||||||
# Checks for library functions.
|
|
||||||
AC_FUNC_ERROR_AT_LINE
|
|
||||||
AC_HEADER_STDC
|
|
||||||
AC_CHECK_FUNCS([memchr setlocale strchr strstr])
|
|
||||||
|
|
||||||
dnl internationalization macros
|
|
||||||
AM_GNU_GETTEXT
|
|
||||||
AM_GNU_GETTEXT_VERSION(0.17)
|
|
||||||
|
|
||||||
AC_ARG_WITH(warnings,[ --with-warnings compile with warning messages], [
|
|
||||||
AC_DEFINE(HUNSPELL_WARNING_ON,1,"Define if you need warning messages")
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_ARG_WITH(experimental,[ --with-experimental compile with some extra functions], [
|
|
||||||
AC_DEFINE(HUNSPELL_EXPERIMENTAL,1,"Define if you use exterimental functions")
|
|
||||||
])
|
|
||||||
|
|
||||||
CURSESLIB=""
|
|
||||||
AC_ARG_WITH(
|
|
||||||
[ui],
|
|
||||||
[AS_HELP_STRING([--with-ui],[support Curses user interface])],
|
|
||||||
[],
|
|
||||||
[with_ui=no]
|
|
||||||
)
|
|
||||||
AS_IF(
|
|
||||||
[test "x$with_ui" != xno],
|
|
||||||
[AC_CHECK_LIB(ncursesw,tparm,CURSESLIB=-lncursesw,
|
|
||||||
AC_CHECK_LIB(curses,tparm,CURSESLIB=-lcurses,
|
|
||||||
AC_CHECK_LIB(ncurses,tparm,CURSESLIB=-lncurses)))
|
|
||||||
if test "$CURSESLIB" != "" ; then
|
|
||||||
echo Compiling with curses user interface.
|
|
||||||
AC_DEFINE(HAVE_CURSES_H,1,"Define if you have the <curses.h> header")
|
|
||||||
if test "$CURSESLIB" != "-lncursesw" ; then
|
|
||||||
echo "No Unicode support on interactive console. (Install Ncursesw library.)"
|
|
||||||
else
|
|
||||||
AC_DEFINE(HAVE_NCURSESW_H,1,"Define if you have the <ncursesw/curses.h> header")
|
|
||||||
fi
|
|
||||||
AC_DEFINE(HUNSPELL_WARNING_ON,1,"Define if you need warning messages")
|
|
||||||
fi]
|
|
||||||
)
|
|
||||||
AC_SUBST(CURSESLIB)
|
|
||||||
|
|
||||||
AC_ARG_WITH(
|
|
||||||
[readline],
|
|
||||||
[AS_HELP_STRING([--with-readline],[support fancy command input editing])],
|
|
||||||
[],
|
|
||||||
[with_readline=no]
|
|
||||||
)
|
|
||||||
rl=n
|
|
||||||
AS_IF([test "x$with_readline" != xno],
|
|
||||||
[AC_CHECK_LIB(curses,tparm,TERMLIB=-lncurses,
|
|
||||||
AC_CHECK_LIB(termcap,tgetent,TERMLIB=-ltermcap))
|
|
||||||
LDSAVE=$LDFLAGS
|
|
||||||
LDFLAGS="$LDFLAGS $TERMLIB"
|
|
||||||
AC_CHECK_LIB(readline,readline,
|
|
||||||
[AC_CHECK_HEADER(readline/readline.h,
|
|
||||||
READLINELIB="-lreadline $TERMLIB";rl=y)],
|
|
||||||
READLINELIB="")
|
|
||||||
if test "$rl" = "y" ; then
|
|
||||||
echo Using the readline library.
|
|
||||||
AC_DEFINE(HAVE_READLINE,1,"Define if you have fancy command input editing with Readline")
|
|
||||||
fi
|
|
||||||
LDFLAGS=$LDSAVE]
|
|
||||||
)
|
|
||||||
AC_SUBST(READLINELIB)
|
|
||||||
|
|
||||||
AC_CONFIG_FILES([Makefile
|
|
||||||
hunspell.pc
|
|
||||||
man/Makefile
|
|
||||||
man/hu/Makefile
|
|
||||||
intl/Makefile
|
|
||||||
po/Makefile.in
|
|
||||||
m4/Makefile
|
|
||||||
src/Makefile
|
|
||||||
src/hunspell/Makefile
|
|
||||||
src/hunspell/hunvisapi.h
|
|
||||||
src/parsers/Makefile
|
|
||||||
src/tools/Makefile
|
|
||||||
src/win_api/Makefile
|
|
||||||
tests/Makefile
|
|
||||||
tests/suggestiontest/Makefile])
|
|
||||||
AC_OUTPUT
|
|
|
@ -1,522 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
# depcomp - compile a program generating dependencies as side-effects
|
|
||||||
|
|
||||||
scriptversion=2004-05-31.23
|
|
||||||
|
|
||||||
# Copyright (C) 1999, 2000, 2003, 2004 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
# 02111-1307, USA.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
'')
|
|
||||||
echo "$0: No command. Try \`$0 --help' for more information." 1>&2
|
|
||||||
exit 1;
|
|
||||||
;;
|
|
||||||
-h | --h*)
|
|
||||||
cat <<\EOF
|
|
||||||
Usage: depcomp [--help] [--version] PROGRAM [ARGS]
|
|
||||||
|
|
||||||
Run PROGRAMS ARGS to compile a file, generating dependencies
|
|
||||||
as side-effects.
|
|
||||||
|
|
||||||
Environment variables:
|
|
||||||
depmode Dependency tracking mode.
|
|
||||||
source Source file read by `PROGRAMS ARGS'.
|
|
||||||
object Object file output by `PROGRAMS ARGS'.
|
|
||||||
DEPDIR directory where to store dependencies.
|
|
||||||
depfile Dependency file to output.
|
|
||||||
tmpdepfile Temporary file to use when outputing dependencies.
|
|
||||||
libtool Whether libtool is used (yes/no).
|
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
|
||||||
EOF
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
-v | --v*)
|
|
||||||
echo "depcomp $scriptversion"
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
|
||||||
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po.
|
|
||||||
depfile=${depfile-`echo "$object" |
|
|
||||||
sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`}
|
|
||||||
tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
|
|
||||||
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
|
|
||||||
# Some modes work just like other modes, but use different flags. We
|
|
||||||
# parameterize here, but still list the modes in the big case below,
|
|
||||||
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
|
||||||
# here, because this file can only contain one case statement.
|
|
||||||
if test "$depmode" = hp; then
|
|
||||||
# HP compiler uses -M and no extra arg.
|
|
||||||
gccflag=-M
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = dashXmstdout; then
|
|
||||||
# This is just like dashmstdout with a different argument.
|
|
||||||
dashmflag=-xM
|
|
||||||
depmode=dashmstdout
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$depmode" in
|
|
||||||
gcc3)
|
|
||||||
## gcc 3 implements dependency tracking that does exactly what
|
|
||||||
## we want. Yay! Note: for some reason libtool 1.4 doesn't like
|
|
||||||
## it if -MD -MP comes after the -MF stuff. Hmm.
|
|
||||||
"$@" -MT "$object" -MD -MP -MF "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
mv "$tmpdepfile" "$depfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
gcc)
|
|
||||||
## There are various ways to get dependency output from gcc. Here's
|
|
||||||
## why we pick this rather obscure method:
|
|
||||||
## - Don't want to use -MD because we'd like the dependencies to end
|
|
||||||
## up in a subdir. Having to rename by hand is ugly.
|
|
||||||
## (We might end up doing this anyway to support other compilers.)
|
|
||||||
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
|
||||||
## -MM, not -M (despite what the docs say).
|
|
||||||
## - Using -M directly means running the compiler twice (even worse
|
|
||||||
## than renaming).
|
|
||||||
if test -z "$gccflag"; then
|
|
||||||
gccflag=-MD,
|
|
||||||
fi
|
|
||||||
"$@" -Wp,"$gccflag$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
|
|
||||||
## The second -e expression handles DOS-style file names with drive letters.
|
|
||||||
sed -e 's/^[^:]*: / /' \
|
|
||||||
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
|
||||||
## This next piece of magic avoids the `deleted header file' problem.
|
|
||||||
## The problem is that when a header file which appears in a .P file
|
|
||||||
## is deleted, the dependency causes make to die (because there is
|
|
||||||
## typically no way to rebuild the header). We avoid this by adding
|
|
||||||
## dummy dependencies for each header file. Too bad gcc doesn't do
|
|
||||||
## this for us directly.
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" |
|
|
||||||
## Some versions of gcc put a space before the `:'. On the theory
|
|
||||||
## that the space means something, we add a space to the output as
|
|
||||||
## well.
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
sgi)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
"$@" "-Wp,-MDupdate,$tmpdepfile"
|
|
||||||
else
|
|
||||||
"$@" -MDupdate "$tmpdepfile"
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
|
|
||||||
# Clip off the initial element (the dependent). Don't try to be
|
|
||||||
# clever and replace this with sed code, as IRIX sed won't handle
|
|
||||||
# lines with more than a fixed number of characters (4096 in
|
|
||||||
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
|
||||||
# the IRIX cc adds comments like `#:fec' to the end of the
|
|
||||||
# dependency line.
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
|
|
||||||
tr '
|
|
||||||
' ' ' >> $depfile
|
|
||||||
echo >> $depfile
|
|
||||||
|
|
||||||
# The second pass generates a dummy entry for each header file.
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
|
||||||
>> $depfile
|
|
||||||
else
|
|
||||||
# The sourcefile does not contain any dependencies, so just
|
|
||||||
# store a dummy comment line, to avoid errors with the Makefile
|
|
||||||
# "include basename.Plo" scheme.
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
aix)
|
|
||||||
# The C for AIX Compiler uses -M and outputs the dependencies
|
|
||||||
# in a .u file. In older versions, this file always lives in the
|
|
||||||
# current directory. Also, the AIX compiler puts `$object:' at the
|
|
||||||
# start of each line; $object doesn't have directory information.
|
|
||||||
# Version 6 uses the directory in both cases.
|
|
||||||
stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'`
|
|
||||||
tmpdepfile="$stripped.u"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
"$@" -Wc,-M
|
|
||||||
else
|
|
||||||
"$@" -M
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then :
|
|
||||||
else
|
|
||||||
stripped=`echo "$stripped" | sed 's,^.*/,,'`
|
|
||||||
tmpdepfile="$stripped.u"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
outname="$stripped.o"
|
|
||||||
# Each line is of the form `foo.o: dependent.h'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
|
||||||
sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile"
|
|
||||||
sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
|
|
||||||
else
|
|
||||||
# The sourcefile does not contain any dependencies, so just
|
|
||||||
# store a dummy comment line, to avoid errors with the Makefile
|
|
||||||
# "include basename.Plo" scheme.
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
icc)
|
|
||||||
# Intel's C compiler understands `-MD -MF file'. However on
|
|
||||||
# icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
|
|
||||||
# ICC 7.0 will fill foo.d with something like
|
|
||||||
# foo.o: sub/foo.c
|
|
||||||
# foo.o: sub/foo.h
|
|
||||||
# which is wrong. We want:
|
|
||||||
# sub/foo.o: sub/foo.c
|
|
||||||
# sub/foo.o: sub/foo.h
|
|
||||||
# sub/foo.c:
|
|
||||||
# sub/foo.h:
|
|
||||||
# ICC 7.1 will output
|
|
||||||
# foo.o: sub/foo.c sub/foo.h
|
|
||||||
# and will wrap long lines using \ :
|
|
||||||
# foo.o: sub/foo.c ... \
|
|
||||||
# sub/foo.h ... \
|
|
||||||
# ...
|
|
||||||
|
|
||||||
"$@" -MD -MF "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each line is of the form `foo.o: dependent.h',
|
|
||||||
# or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
|
||||||
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" |
|
|
||||||
sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
tru64)
|
|
||||||
# The Tru64 compiler uses -MD to generate dependencies as a side
|
|
||||||
# effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
|
|
||||||
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
|
||||||
# dependencies in `foo.d' instead, so we check for that too.
|
|
||||||
# Subdirectories are respected.
|
|
||||||
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
|
||||||
test "x$dir" = "x$object" && dir=
|
|
||||||
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
|
||||||
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
# Dependencies are output in .lo.d with libtool 1.4.
|
|
||||||
# With libtool 1.5 they are output both in $dir.libs/$base.o.d
|
|
||||||
# and in $dir.libs/$base.o.d and $dir$base.o.d. We process the
|
|
||||||
# latter, because the former will be cleaned when $dir.libs is
|
|
||||||
# erased.
|
|
||||||
tmpdepfile1="$dir.libs/$base.lo.d"
|
|
||||||
tmpdepfile2="$dir$base.o.d"
|
|
||||||
tmpdepfile3="$dir.libs/$base.d"
|
|
||||||
"$@" -Wc,-MD
|
|
||||||
else
|
|
||||||
tmpdepfile1="$dir$base.o.d"
|
|
||||||
tmpdepfile2="$dir$base.d"
|
|
||||||
tmpdepfile3="$dir$base.d"
|
|
||||||
"$@" -MD
|
|
||||||
fi
|
|
||||||
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile1"; then
|
|
||||||
tmpdepfile="$tmpdepfile1"
|
|
||||||
elif test -f "$tmpdepfile2"; then
|
|
||||||
tmpdepfile="$tmpdepfile2"
|
|
||||||
else
|
|
||||||
tmpdepfile="$tmpdepfile3"
|
|
||||||
fi
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
|
||||||
# That's a tab and a space in the [].
|
|
||||||
sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
|
||||||
else
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
#nosideeffect)
|
|
||||||
# This comment above is used by automake to tell side-effect
|
|
||||||
# dependency tracking mechanisms from slower ones.
|
|
||||||
|
|
||||||
dashmstdout)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout, regardless of -o.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test $1 != '--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove `-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
test -z "$dashmflag" && dashmflag=-M
|
|
||||||
# Require at least two characters before searching for `:'
|
|
||||||
# in the target name. This is to cope with DOS-style filenames:
|
|
||||||
# a dependency such as `c:/foo/bar' could be seen as target `c' otherwise.
|
|
||||||
"$@" $dashmflag |
|
|
||||||
sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" | \
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
dashXmstdout)
|
|
||||||
# This case only exists to satisfy depend.m4. It is never actually
|
|
||||||
# run, as this mode is specially recognized in the preamble.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
makedepend)
|
|
||||||
"$@" || exit $?
|
|
||||||
# Remove any Libtool call
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test $1 != '--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
# X makedepend
|
|
||||||
shift
|
|
||||||
cleared=no
|
|
||||||
for arg in "$@"; do
|
|
||||||
case $cleared in
|
|
||||||
no)
|
|
||||||
set ""; shift
|
|
||||||
cleared=yes ;;
|
|
||||||
esac
|
|
||||||
case "$arg" in
|
|
||||||
-D*|-I*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
# Strip any option that makedepend may not understand. Remove
|
|
||||||
# the object too, otherwise makedepend will parse it as a source file.
|
|
||||||
-*|$object)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
obj_suffix="`echo $object | sed 's/^.*\././'`"
|
|
||||||
touch "$tmpdepfile"
|
|
||||||
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
|
||||||
rm -f "$depfile"
|
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
|
||||||
sed '1,2d' "$tmpdepfile" | tr ' ' '
|
|
||||||
' | \
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
|
||||||
;;
|
|
||||||
|
|
||||||
cpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test $1 != '--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove `-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
"$@" -E |
|
|
||||||
sed -n '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
|
|
||||||
sed '$ s: \\$::' > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
cat < "$tmpdepfile" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvisualcpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout, regardless of -o,
|
|
||||||
# because we must use -o when running libtool.
|
|
||||||
"$@" || exit $?
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case "$arg" in
|
|
||||||
"-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
|
|
||||||
set fnord "$@"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
"$@" -E |
|
|
||||||
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
. "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile"
|
|
||||||
echo " " >> "$depfile"
|
|
||||||
. "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
none)
|
|
||||||
exec "$@"
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo "Unknown depmode $depmode" 1>&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-end: "$"
|
|
||||||
# End:
|
|
|
@ -1,10 +0,0 @@
|
||||||
prefix=@prefix@
|
|
||||||
exec_prefix=${prefix}
|
|
||||||
libdir=@libdir@
|
|
||||||
includedir=@includedir@
|
|
||||||
|
|
||||||
Name: hunspell
|
|
||||||
Description: Hunspell spellchecking library
|
|
||||||
Version: @VERSION@
|
|
||||||
Libs: -L${libdir} -lhunspell-@HUNSPELL_VERSION_MAJOR@.@HUNSPELL_VERSION_MINOR@
|
|
||||||
Cflags: -I${includedir}/hunspell
|
|
|
@ -1,322 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
# install - install a program, script, or datafile
|
|
||||||
|
|
||||||
scriptversion=2004-07-05.00
|
|
||||||
|
|
||||||
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
|
||||||
# later released in X11R6 (xc/config/util/install.sh) with the
|
|
||||||
# following copyright and license.
|
|
||||||
#
|
|
||||||
# Copyright (C) 1994 X Consortium
|
|
||||||
#
|
|
||||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
# of this software and associated documentation files (the "Software"), to
|
|
||||||
# deal in the Software without restriction, including without limitation the
|
|
||||||
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
||||||
# sell copies of the Software, and to permit persons to whom the Software is
|
|
||||||
# furnished to do so, subject to the following conditions:
|
|
||||||
#
|
|
||||||
# The above copyright notice and this permission notice shall be included in
|
|
||||||
# all copies or substantial portions of the Software.
|
|
||||||
#
|
|
||||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
||||||
# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
|
|
||||||
# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
#
|
|
||||||
# Except as contained in this notice, the name of the X Consortium shall not
|
|
||||||
# be used in advertising or otherwise to promote the sale, use or other deal-
|
|
||||||
# ings in this Software without prior written authorization from the X Consor-
|
|
||||||
# tium.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# FSF changes to this file are in the public domain.
|
|
||||||
#
|
|
||||||
# Calling this script install-sh is preferred over install.sh, to prevent
|
|
||||||
# `make' implicit rules from creating a file called install from it
|
|
||||||
# when there is no Makefile.
|
|
||||||
#
|
|
||||||
# This script is compatible with the BSD install script, but was written
|
|
||||||
# from scratch. It can only install one file at a time, a restriction
|
|
||||||
# shared with many OS's install programs.
|
|
||||||
|
|
||||||
# set DOITPROG to echo to test this script
|
|
||||||
|
|
||||||
# Don't use :- since 4.3BSD and earlier shells don't like it.
|
|
||||||
doit="${DOITPROG-}"
|
|
||||||
|
|
||||||
# put in absolute paths if you don't have them in your path; or use env. vars.
|
|
||||||
|
|
||||||
mvprog="${MVPROG-mv}"
|
|
||||||
cpprog="${CPPROG-cp}"
|
|
||||||
chmodprog="${CHMODPROG-chmod}"
|
|
||||||
chownprog="${CHOWNPROG-chown}"
|
|
||||||
chgrpprog="${CHGRPPROG-chgrp}"
|
|
||||||
stripprog="${STRIPPROG-strip}"
|
|
||||||
rmprog="${RMPROG-rm}"
|
|
||||||
mkdirprog="${MKDIRPROG-mkdir}"
|
|
||||||
|
|
||||||
chmodcmd="$chmodprog 0755"
|
|
||||||
chowncmd=
|
|
||||||
chgrpcmd=
|
|
||||||
stripcmd=
|
|
||||||
rmcmd="$rmprog -f"
|
|
||||||
mvcmd="$mvprog"
|
|
||||||
src=
|
|
||||||
dst=
|
|
||||||
dir_arg=
|
|
||||||
dstarg=
|
|
||||||
no_target_directory=
|
|
||||||
|
|
||||||
usage="Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
|
|
||||||
or: $0 [OPTION]... SRCFILES... DIRECTORY
|
|
||||||
or: $0 [OPTION]... -t DIRECTORY SRCFILES...
|
|
||||||
or: $0 [OPTION]... -d DIRECTORIES...
|
|
||||||
|
|
||||||
In the 1st form, copy SRCFILE to DSTFILE.
|
|
||||||
In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
|
|
||||||
In the 4th, create DIRECTORIES.
|
|
||||||
|
|
||||||
Options:
|
|
||||||
-c (ignored)
|
|
||||||
-d create directories instead of installing files.
|
|
||||||
-g GROUP $chgrpprog installed files to GROUP.
|
|
||||||
-m MODE $chmodprog installed files to MODE.
|
|
||||||
-o USER $chownprog installed files to USER.
|
|
||||||
-s $stripprog installed files.
|
|
||||||
-t DIRECTORY install into DIRECTORY.
|
|
||||||
-T report an error if DSTFILE is a directory.
|
|
||||||
--help display this help and exit.
|
|
||||||
--version display version info and exit.
|
|
||||||
|
|
||||||
Environment variables override the default commands:
|
|
||||||
CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG
|
|
||||||
"
|
|
||||||
|
|
||||||
while test -n "$1"; do
|
|
||||||
case $1 in
|
|
||||||
-c) shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-d) dir_arg=true
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-g) chgrpcmd="$chgrpprog $2"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
--help) echo "$usage"; exit 0;;
|
|
||||||
|
|
||||||
-m) chmodcmd="$chmodprog $2"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-o) chowncmd="$chownprog $2"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-s) stripcmd=$stripprog
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-t) dstarg=$2
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-T) no_target_directory=true
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
--version) echo "$0 $scriptversion"; exit 0;;
|
|
||||||
|
|
||||||
*) # When -d is used, all remaining arguments are directories to create.
|
|
||||||
# When -t is used, the destination is already specified.
|
|
||||||
test -n "$dir_arg$dstarg" && break
|
|
||||||
# Otherwise, the last argument is the destination. Remove it from $@.
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$dstarg"; then
|
|
||||||
# $@ is not empty: it contains at least $arg.
|
|
||||||
set fnord "$@" "$dstarg"
|
|
||||||
shift # fnord
|
|
||||||
fi
|
|
||||||
shift # arg
|
|
||||||
dstarg=$arg
|
|
||||||
done
|
|
||||||
break;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
if test -z "$1"; then
|
|
||||||
if test -z "$dir_arg"; then
|
|
||||||
echo "$0: no input file specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
# It's OK to call `install-sh -d' without argument.
|
|
||||||
# This can happen when creating conditional directories.
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
for src
|
|
||||||
do
|
|
||||||
# Protect names starting with `-'.
|
|
||||||
case $src in
|
|
||||||
-*) src=./$src ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
dst=$src
|
|
||||||
src=
|
|
||||||
|
|
||||||
if test -d "$dst"; then
|
|
||||||
mkdircmd=:
|
|
||||||
chmodcmd=
|
|
||||||
else
|
|
||||||
mkdircmd=$mkdirprog
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
# Waiting for this to be detected by the "$cpprog $src $dsttmp" command
|
|
||||||
# might cause directories to be created, which would be especially bad
|
|
||||||
# if $src (and thus $dsttmp) contains '*'.
|
|
||||||
if test ! -f "$src" && test ! -d "$src"; then
|
|
||||||
echo "$0: $src does not exist." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z "$dstarg"; then
|
|
||||||
echo "$0: no destination specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
dst=$dstarg
|
|
||||||
# Protect names starting with `-'.
|
|
||||||
case $dst in
|
|
||||||
-*) dst=./$dst ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# If destination is a directory, append the input filename; won't work
|
|
||||||
# if double slashes aren't ignored.
|
|
||||||
if test -d "$dst"; then
|
|
||||||
if test -n "$no_target_directory"; then
|
|
||||||
echo "$0: $dstarg: Is a directory" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
dst=$dst/`basename "$src"`
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# This sed command emulates the dirname command.
|
|
||||||
dstdir=`echo "$dst" | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'`
|
|
||||||
|
|
||||||
# Make sure that the destination directory exists.
|
|
||||||
|
|
||||||
# Skip lots of stat calls in the usual case.
|
|
||||||
if test ! -d "$dstdir"; then
|
|
||||||
defaultIFS='
|
|
||||||
'
|
|
||||||
IFS="${IFS-$defaultIFS}"
|
|
||||||
|
|
||||||
oIFS=$IFS
|
|
||||||
# Some sh's can't handle IFS=/ for some reason.
|
|
||||||
IFS='%'
|
|
||||||
set - `echo "$dstdir" | sed -e 's@/@%@g' -e 's@^%@/@'`
|
|
||||||
IFS=$oIFS
|
|
||||||
|
|
||||||
pathcomp=
|
|
||||||
|
|
||||||
while test $# -ne 0 ; do
|
|
||||||
pathcomp=$pathcomp$1
|
|
||||||
shift
|
|
||||||
if test ! -d "$pathcomp"; then
|
|
||||||
$mkdirprog "$pathcomp"
|
|
||||||
# mkdir can fail with a `File exist' error in case several
|
|
||||||
# install-sh are creating the directory concurrently. This
|
|
||||||
# is OK.
|
|
||||||
test -d "$pathcomp" || exit
|
|
||||||
fi
|
|
||||||
pathcomp=$pathcomp/
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
$doit $mkdircmd "$dst" \
|
|
||||||
&& { test -z "$chowncmd" || $doit $chowncmd "$dst"; } \
|
|
||||||
&& { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } \
|
|
||||||
&& { test -z "$stripcmd" || $doit $stripcmd "$dst"; } \
|
|
||||||
&& { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; }
|
|
||||||
|
|
||||||
else
|
|
||||||
dstfile=`basename "$dst"`
|
|
||||||
|
|
||||||
# Make a couple of temp file names in the proper directory.
|
|
||||||
dsttmp=$dstdir/_inst.$$_
|
|
||||||
rmtmp=$dstdir/_rm.$$_
|
|
||||||
|
|
||||||
# Trap to clean up those temp files at exit.
|
|
||||||
trap 'status=$?; rm -f "$dsttmp" "$rmtmp" && exit $status' 0
|
|
||||||
trap '(exit $?); exit' 1 2 13 15
|
|
||||||
|
|
||||||
# Copy the file name to the temp name.
|
|
||||||
$doit $cpprog "$src" "$dsttmp" &&
|
|
||||||
|
|
||||||
# and set any options; do chmod last to preserve setuid bits.
|
|
||||||
#
|
|
||||||
# If any of these fail, we abort the whole thing. If we want to
|
|
||||||
# ignore errors from any of these, just make sure not to ignore
|
|
||||||
# errors from the above "$doit $cpprog $src $dsttmp" command.
|
|
||||||
#
|
|
||||||
{ test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \
|
|
||||||
&& { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \
|
|
||||||
&& { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \
|
|
||||||
&& { test -z "$chmodcmd" || $doit $chmodcmd "$dsttmp"; } &&
|
|
||||||
|
|
||||||
# Now rename the file to the real destination.
|
|
||||||
{ $doit $mvcmd -f "$dsttmp" "$dstdir/$dstfile" 2>/dev/null \
|
|
||||||
|| {
|
|
||||||
# The rename failed, perhaps because mv can't rename something else
|
|
||||||
# to itself, or perhaps because mv is so ancient that it does not
|
|
||||||
# support -f.
|
|
||||||
|
|
||||||
# Now remove or move aside any old file at destination location.
|
|
||||||
# We try this two ways since rm can't unlink itself on some
|
|
||||||
# systems and the destination file might be busy for other
|
|
||||||
# reasons. In this case, the final cleanup might fail but the new
|
|
||||||
# file should still install successfully.
|
|
||||||
{
|
|
||||||
if test -f "$dstdir/$dstfile"; then
|
|
||||||
$doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null \
|
|
||||||
|| $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null \
|
|
||||||
|| {
|
|
||||||
echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2
|
|
||||||
(exit 1); exit
|
|
||||||
}
|
|
||||||
else
|
|
||||||
:
|
|
||||||
fi
|
|
||||||
} &&
|
|
||||||
|
|
||||||
# Now rename the file to the real destination.
|
|
||||||
$doit $mvcmd "$dsttmp" "$dstdir/$dstfile"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fi || { (exit 1); exit; }
|
|
||||||
done
|
|
||||||
|
|
||||||
# The final little trick to "correctly" pass the exit status to the exit trap.
|
|
||||||
{
|
|
||||||
(exit 0); exit
|
|
||||||
}
|
|
||||||
|
|
||||||
# Local variables:
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-end: "$"
|
|
||||||
# End:
|
|
|
@ -1,4 +0,0 @@
|
||||||
2007-11-07 GNU <bug-gnu-gettext@gnu.org>
|
|
||||||
|
|
||||||
* Version 0.17 released.
|
|
||||||
|
|
|
@ -1,587 +0,0 @@
|
||||||
# Makefile for directory with message catalog handling library of GNU gettext
|
|
||||||
# Copyright (C) 1995-1998, 2000-2007 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify it
|
|
||||||
# under the terms of the GNU Library General Public License as published
|
|
||||||
# by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
# Library General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU Library General Public
|
|
||||||
# License along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
# USA.
|
|
||||||
|
|
||||||
PACKAGE = @PACKAGE@
|
|
||||||
VERSION = @VERSION@
|
|
||||||
|
|
||||||
SHELL = /bin/sh
|
|
||||||
|
|
||||||
srcdir = @srcdir@
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
top_builddir = ..
|
|
||||||
|
|
||||||
# The VPATH variables allows builds with $builddir != $srcdir, assuming a
|
|
||||||
# 'make' program that supports VPATH (such as GNU make). This line is removed
|
|
||||||
# by autoconf automatically when "$(srcdir)" = ".".
|
|
||||||
# In this directory, the VPATH handling is particular:
|
|
||||||
# 1. If INTL_LIBTOOL_SUFFIX_PREFIX is 'l' (indicating a build with libtool),
|
|
||||||
# the .c -> .lo rules carefully use $(srcdir), so that VPATH can be omitted.
|
|
||||||
# 2. If PACKAGE = gettext-tools, VPATH _must_ be omitted, because otherwise
|
|
||||||
# 'make' does the wrong thing if GNU gettext was configured with
|
|
||||||
# "./configure --srcdir=`pwd`", namely it gets confused by the .lo and .la
|
|
||||||
# files it finds in srcdir = ../../gettext-runtime/intl.
|
|
||||||
VPATH = $(srcdir)
|
|
||||||
|
|
||||||
prefix = @prefix@
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
transform = @program_transform_name@
|
|
||||||
libdir = @libdir@
|
|
||||||
includedir = @includedir@
|
|
||||||
datarootdir = @datarootdir@
|
|
||||||
datadir = @datadir@
|
|
||||||
localedir = $(datadir)/locale
|
|
||||||
gettextsrcdir = $(datadir)/gettext/intl
|
|
||||||
aliaspath = $(localedir)
|
|
||||||
subdir = intl
|
|
||||||
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
|
|
||||||
# We use $(mkdir_p).
|
|
||||||
# In automake <= 1.9.x, $(mkdir_p) is defined either as "mkdir -p --" or as
|
|
||||||
# "$(mkinstalldirs)" or as "$(install_sh) -d". For these automake versions,
|
|
||||||
# @install_sh@ does not start with $(SHELL), so we add it.
|
|
||||||
# In automake >= 1.10, @mkdir_p@ is derived from ${MKDIR_P}, which is defined
|
|
||||||
# either as "/path/to/mkdir -p" or ".../install-sh -c -d". For these automake
|
|
||||||
# versions, $(mkinstalldirs) and $(install_sh) are unused.
|
|
||||||
mkinstalldirs = $(SHELL) @install_sh@ -d
|
|
||||||
install_sh = $(SHELL) @install_sh@
|
|
||||||
MKDIR_P = @MKDIR_P@
|
|
||||||
mkdir_p = @mkdir_p@
|
|
||||||
|
|
||||||
l = @INTL_LIBTOOL_SUFFIX_PREFIX@
|
|
||||||
|
|
||||||
AR = ar
|
|
||||||
CC = @CC@
|
|
||||||
LIBTOOL = @LIBTOOL@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
YACC = @INTLBISON@ -y -d
|
|
||||||
YFLAGS = --name-prefix=__gettext
|
|
||||||
WINDRES = @WINDRES@
|
|
||||||
|
|
||||||
# -DBUILDING_LIBINTL: Change expansion of LIBINTL_DLL_EXPORTED macro.
|
|
||||||
# -DBUILDING_DLL: Change expansion of RELOCATABLE_DLL_EXPORTED macro.
|
|
||||||
DEFS = -DLOCALEDIR=\"$(localedir)\" -DLOCALE_ALIAS_PATH=\"$(aliaspath)\" \
|
|
||||||
-DLIBDIR=\"$(libdir)\" -DBUILDING_LIBINTL -DBUILDING_DLL -DIN_LIBINTL \
|
|
||||||
-DENABLE_RELOCATABLE=1 -DIN_LIBRARY -DINSTALLDIR=\"$(libdir)\" -DNO_XMALLOC \
|
|
||||||
-Dset_relocation_prefix=libintl_set_relocation_prefix \
|
|
||||||
-Drelocate=libintl_relocate \
|
|
||||||
-DDEPENDS_ON_LIBICONV=1 @DEFS@
|
|
||||||
CPPFLAGS = @CPPFLAGS@
|
|
||||||
CFLAGS = @CFLAGS@ @CFLAG_VISIBILITY@
|
|
||||||
LDFLAGS = @LDFLAGS@ $(LDFLAGS_@WOE32DLL@)
|
|
||||||
LDFLAGS_yes = -Wl,--export-all-symbols
|
|
||||||
LDFLAGS_no =
|
|
||||||
LIBS = @LIBS@
|
|
||||||
|
|
||||||
COMPILE = $(CC) -c $(DEFS) $(INCLUDES) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS)
|
|
||||||
|
|
||||||
HEADERS = \
|
|
||||||
gmo.h \
|
|
||||||
gettextP.h \
|
|
||||||
hash-string.h \
|
|
||||||
loadinfo.h \
|
|
||||||
plural-exp.h \
|
|
||||||
eval-plural.h \
|
|
||||||
localcharset.h \
|
|
||||||
lock.h \
|
|
||||||
relocatable.h \
|
|
||||||
tsearch.h tsearch.c \
|
|
||||||
xsize.h \
|
|
||||||
printf-args.h printf-args.c \
|
|
||||||
printf-parse.h wprintf-parse.h printf-parse.c \
|
|
||||||
vasnprintf.h vasnwprintf.h vasnprintf.c \
|
|
||||||
os2compat.h \
|
|
||||||
libgnuintl.h.in
|
|
||||||
SOURCES = \
|
|
||||||
bindtextdom.c \
|
|
||||||
dcgettext.c \
|
|
||||||
dgettext.c \
|
|
||||||
gettext.c \
|
|
||||||
finddomain.c \
|
|
||||||
hash-string.c \
|
|
||||||
loadmsgcat.c \
|
|
||||||
localealias.c \
|
|
||||||
textdomain.c \
|
|
||||||
l10nflist.c \
|
|
||||||
explodename.c \
|
|
||||||
dcigettext.c \
|
|
||||||
dcngettext.c \
|
|
||||||
dngettext.c \
|
|
||||||
ngettext.c \
|
|
||||||
plural.y \
|
|
||||||
plural-exp.c \
|
|
||||||
localcharset.c \
|
|
||||||
lock.c \
|
|
||||||
relocatable.c \
|
|
||||||
langprefs.c \
|
|
||||||
localename.c \
|
|
||||||
log.c \
|
|
||||||
printf.c \
|
|
||||||
version.c \
|
|
||||||
osdep.c \
|
|
||||||
os2compat.c \
|
|
||||||
intl-exports.c \
|
|
||||||
intl-compat.c
|
|
||||||
OBJECTS = \
|
|
||||||
bindtextdom.$lo \
|
|
||||||
dcgettext.$lo \
|
|
||||||
dgettext.$lo \
|
|
||||||
gettext.$lo \
|
|
||||||
finddomain.$lo \
|
|
||||||
hash-string.$lo \
|
|
||||||
loadmsgcat.$lo \
|
|
||||||
localealias.$lo \
|
|
||||||
textdomain.$lo \
|
|
||||||
l10nflist.$lo \
|
|
||||||
explodename.$lo \
|
|
||||||
dcigettext.$lo \
|
|
||||||
dcngettext.$lo \
|
|
||||||
dngettext.$lo \
|
|
||||||
ngettext.$lo \
|
|
||||||
plural.$lo \
|
|
||||||
plural-exp.$lo \
|
|
||||||
localcharset.$lo \
|
|
||||||
lock.$lo \
|
|
||||||
relocatable.$lo \
|
|
||||||
langprefs.$lo \
|
|
||||||
localename.$lo \
|
|
||||||
log.$lo \
|
|
||||||
printf.$lo \
|
|
||||||
version.$lo \
|
|
||||||
osdep.$lo \
|
|
||||||
intl-compat.$lo
|
|
||||||
OBJECTS_RES_yes = libintl.res
|
|
||||||
OBJECTS_RES_no =
|
|
||||||
DISTFILES.common = Makefile.in \
|
|
||||||
config.charset locale.alias ref-add.sin ref-del.sin export.h libintl.rc \
|
|
||||||
$(HEADERS) $(SOURCES)
|
|
||||||
DISTFILES.generated = plural.c
|
|
||||||
DISTFILES.normal = VERSION
|
|
||||||
DISTFILES.gettext = COPYING.LIB-2.0 COPYING.LIB-2.1 libintl.glibc README.woe32
|
|
||||||
DISTFILES.obsolete = xopen-msg.sed linux-msg.sed po2tbl.sed.in cat-compat.c \
|
|
||||||
COPYING.LIB-2 gettext.h libgettext.h plural-eval.c libgnuintl.h \
|
|
||||||
libgnuintl.h_vms Makefile.vms libgnuintl.h.msvc-static \
|
|
||||||
libgnuintl.h.msvc-shared Makefile.msvc
|
|
||||||
|
|
||||||
all: all-@USE_INCLUDED_LIBINTL@
|
|
||||||
all-yes: libintl.$la libintl.h charset.alias ref-add.sed ref-del.sed
|
|
||||||
all-no: all-no-@BUILD_INCLUDED_LIBINTL@
|
|
||||||
all-no-yes: libgnuintl.$la
|
|
||||||
all-no-no:
|
|
||||||
|
|
||||||
libintl.a libgnuintl.a: $(OBJECTS)
|
|
||||||
rm -f $@
|
|
||||||
$(AR) cru $@ $(OBJECTS)
|
|
||||||
$(RANLIB) $@
|
|
||||||
|
|
||||||
libintl.la libgnuintl.la: $(OBJECTS) $(OBJECTS_RES_@WOE32@)
|
|
||||||
$(LIBTOOL) --mode=link \
|
|
||||||
$(CC) $(CPPFLAGS) $(CFLAGS) $(XCFLAGS) $(LDFLAGS) -o $@ \
|
|
||||||
$(OBJECTS) @LTLIBICONV@ @INTL_MACOSX_LIBS@ $(LIBS) @LTLIBTHREAD@ @LTLIBC@ \
|
|
||||||
$(OBJECTS_RES_@WOE32@) \
|
|
||||||
-version-info $(LTV_CURRENT):$(LTV_REVISION):$(LTV_AGE) \
|
|
||||||
-rpath $(libdir) \
|
|
||||||
-no-undefined
|
|
||||||
|
|
||||||
# Libtool's library version information for libintl.
|
|
||||||
# Before making a gettext release, the gettext maintainer must change this
|
|
||||||
# according to the libtool documentation, section "Library interface versions".
|
|
||||||
# Maintainers of other packages that include the intl directory must *not*
|
|
||||||
# change these values.
|
|
||||||
LTV_CURRENT=8
|
|
||||||
LTV_REVISION=2
|
|
||||||
LTV_AGE=0
|
|
||||||
|
|
||||||
.SUFFIXES:
|
|
||||||
.SUFFIXES: .c .y .o .lo .sin .sed
|
|
||||||
|
|
||||||
.c.o:
|
|
||||||
$(COMPILE) $<
|
|
||||||
|
|
||||||
.y.c:
|
|
||||||
$(YACC) $(YFLAGS) --output $@ $<
|
|
||||||
rm -f $*.h
|
|
||||||
|
|
||||||
bindtextdom.lo: $(srcdir)/bindtextdom.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/bindtextdom.c
|
|
||||||
dcgettext.lo: $(srcdir)/dcgettext.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcgettext.c
|
|
||||||
dgettext.lo: $(srcdir)/dgettext.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dgettext.c
|
|
||||||
gettext.lo: $(srcdir)/gettext.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/gettext.c
|
|
||||||
finddomain.lo: $(srcdir)/finddomain.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/finddomain.c
|
|
||||||
hash-string.lo: $(srcdir)/hash-string.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/hash-string.c
|
|
||||||
loadmsgcat.lo: $(srcdir)/loadmsgcat.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/loadmsgcat.c
|
|
||||||
localealias.lo: $(srcdir)/localealias.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localealias.c
|
|
||||||
textdomain.lo: $(srcdir)/textdomain.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/textdomain.c
|
|
||||||
l10nflist.lo: $(srcdir)/l10nflist.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/l10nflist.c
|
|
||||||
explodename.lo: $(srcdir)/explodename.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/explodename.c
|
|
||||||
dcigettext.lo: $(srcdir)/dcigettext.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcigettext.c
|
|
||||||
dcngettext.lo: $(srcdir)/dcngettext.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dcngettext.c
|
|
||||||
dngettext.lo: $(srcdir)/dngettext.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/dngettext.c
|
|
||||||
ngettext.lo: $(srcdir)/ngettext.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/ngettext.c
|
|
||||||
plural.lo: $(srcdir)/plural.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/plural.c
|
|
||||||
plural-exp.lo: $(srcdir)/plural-exp.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/plural-exp.c
|
|
||||||
localcharset.lo: $(srcdir)/localcharset.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localcharset.c
|
|
||||||
lock.lo: $(srcdir)/lock.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/lock.c
|
|
||||||
relocatable.lo: $(srcdir)/relocatable.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/relocatable.c
|
|
||||||
langprefs.lo: $(srcdir)/langprefs.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/langprefs.c
|
|
||||||
localename.lo: $(srcdir)/localename.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/localename.c
|
|
||||||
log.lo: $(srcdir)/log.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/log.c
|
|
||||||
printf.lo: $(srcdir)/printf.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/printf.c
|
|
||||||
version.lo: $(srcdir)/version.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/version.c
|
|
||||||
osdep.lo: $(srcdir)/osdep.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/osdep.c
|
|
||||||
intl-compat.lo: $(srcdir)/intl-compat.c
|
|
||||||
$(LIBTOOL) --mode=compile $(COMPILE) $(srcdir)/intl-compat.c
|
|
||||||
|
|
||||||
# This rule is executed only on Woe32 systems.
|
|
||||||
# The following sed expressions come from the windres-options script. They are
|
|
||||||
# inlined here, so that they can be written in a Makefile without requiring a
|
|
||||||
# temporary file. They must contain literal newlines rather than semicolons,
|
|
||||||
# so that they work with the sed-3.02 that is shipped with MSYS. We can use
|
|
||||||
# GNU bash's $'\n' syntax to obtain such a newline.
|
|
||||||
libintl.res: $(srcdir)/libintl.rc
|
|
||||||
nl=$$'\n'; \
|
|
||||||
sed_extract_major='/^[0-9]/{'$${nl}'s/^\([0-9]*\).*/\1/p'$${nl}q$${nl}'}'$${nl}'c\'$${nl}0$${nl}q; \
|
|
||||||
sed_extract_minor='/^[0-9][0-9]*[.][0-9]/{'$${nl}'s/^[0-9]*[.]\([0-9]*\).*/\1/p'$${nl}q$${nl}'}'$${nl}'c\'$${nl}0$${nl}q; \
|
|
||||||
sed_extract_subminor='/^[0-9][0-9]*[.][0-9][0-9]*[.][0-9]/{'$${nl}'s/^[0-9]*[.][0-9]*[.]\([0-9]*\).*/\1/p'$${nl}q$${nl}'}'$${nl}'c\'$${nl}0$${nl}q; \
|
|
||||||
$(WINDRES) \
|
|
||||||
"-DPACKAGE_VERSION_STRING=\\\"$(VERSION)\\\"" \
|
|
||||||
"-DPACKAGE_VERSION_MAJOR="`echo '$(VERSION)' | sed -n -e "$$sed_extract_major"` \
|
|
||||||
"-DPACKAGE_VERSION_MINOR="`echo '$(VERSION)' | sed -n -e "$$sed_extract_minor"` \
|
|
||||||
"-DPACKAGE_VERSION_SUBMINOR="`echo '$(VERSION)' | sed -n -e "$$sed_extract_subminor"` \
|
|
||||||
-i $(srcdir)/libintl.rc -o libintl.res --output-format=coff
|
|
||||||
|
|
||||||
ref-add.sed: $(srcdir)/ref-add.sin
|
|
||||||
sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $(srcdir)/ref-add.sin > t-ref-add.sed
|
|
||||||
mv t-ref-add.sed ref-add.sed
|
|
||||||
ref-del.sed: $(srcdir)/ref-del.sin
|
|
||||||
sed -e '/^#/d' -e 's/@''PACKAGE''@/@PACKAGE@/g' $(srcdir)/ref-del.sin > t-ref-del.sed
|
|
||||||
mv t-ref-del.sed ref-del.sed
|
|
||||||
|
|
||||||
INCLUDES = -I. -I$(srcdir) -I..
|
|
||||||
|
|
||||||
libgnuintl.h: $(srcdir)/libgnuintl.h.in
|
|
||||||
sed -e '/IN_LIBGLOCALE/d' \
|
|
||||||
-e 's,@''HAVE_POSIX_PRINTF''@,@HAVE_POSIX_PRINTF@,g' \
|
|
||||||
-e 's,@''HAVE_ASPRINTF''@,@HAVE_ASPRINTF@,g' \
|
|
||||||
-e 's,@''HAVE_SNPRINTF''@,@HAVE_SNPRINTF@,g' \
|
|
||||||
-e 's,@''HAVE_WPRINTF''@,@HAVE_WPRINTF@,g' \
|
|
||||||
< $(srcdir)/libgnuintl.h.in \
|
|
||||||
| if test '@WOE32DLL@' = yes; then \
|
|
||||||
sed -e 's/extern \([^()]*\);/extern __declspec (dllimport) \1;/'; \
|
|
||||||
else \
|
|
||||||
cat; \
|
|
||||||
fi \
|
|
||||||
| sed -e 's/extern \([^"]\)/extern LIBINTL_DLL_EXPORTED \1/' \
|
|
||||||
-e "/#define _LIBINTL_H/r $(srcdir)/export.h" \
|
|
||||||
| sed -e 's,@''HAVE_VISIBILITY''@,@HAVE_VISIBILITY@,g' \
|
|
||||||
> libgnuintl.h
|
|
||||||
|
|
||||||
libintl.h: $(srcdir)/libgnuintl.h.in
|
|
||||||
sed -e '/IN_LIBGLOCALE/d' \
|
|
||||||
-e 's,@''HAVE_POSIX_PRINTF''@,@HAVE_POSIX_PRINTF@,g' \
|
|
||||||
-e 's,@''HAVE_ASPRINTF''@,@HAVE_ASPRINTF@,g' \
|
|
||||||
-e 's,@''HAVE_SNPRINTF''@,@HAVE_SNPRINTF@,g' \
|
|
||||||
-e 's,@''HAVE_WPRINTF''@,@HAVE_WPRINTF@,g' \
|
|
||||||
< $(srcdir)/libgnuintl.h.in > libintl.h
|
|
||||||
|
|
||||||
charset.alias: $(srcdir)/config.charset
|
|
||||||
$(SHELL) $(srcdir)/config.charset '@host@' > t-$@
|
|
||||||
mv t-$@ $@
|
|
||||||
|
|
||||||
check: all
|
|
||||||
|
|
||||||
# We must not install the libintl.h/libintl.a files if we are on a
|
|
||||||
# system which has the GNU gettext() function in its C library or in a
|
|
||||||
# separate library.
|
|
||||||
# If you want to use the one which comes with this version of the
|
|
||||||
# package, you have to use `configure --with-included-gettext'.
|
|
||||||
install: install-exec install-data
|
|
||||||
install-exec: all
|
|
||||||
if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
|
|
||||||
&& test '@USE_INCLUDED_LIBINTL@' = yes; then \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir); \
|
|
||||||
$(INSTALL_DATA) libintl.h $(DESTDIR)$(includedir)/libintl.h; \
|
|
||||||
$(LIBTOOL) --mode=install \
|
|
||||||
$(INSTALL_DATA) libintl.$la $(DESTDIR)$(libdir)/libintl.$la; \
|
|
||||||
if test "@RELOCATABLE@" = yes; then \
|
|
||||||
dependencies=`sed -n -e 's,^dependency_libs=\(.*\),\1,p' < $(DESTDIR)$(libdir)/libintl.la | sed -e "s,^',," -e "s,'\$$,,"`; \
|
|
||||||
if test -n "$$dependencies"; then \
|
|
||||||
rm -f $(DESTDIR)$(libdir)/libintl.la; \
|
|
||||||
fi; \
|
|
||||||
fi; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test "$(PACKAGE)" = "gettext-tools" \
|
|
||||||
&& test '@USE_INCLUDED_LIBINTL@' = no \
|
|
||||||
&& test @GLIBC2@ != no; then \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(libdir); \
|
|
||||||
$(LIBTOOL) --mode=install \
|
|
||||||
$(INSTALL_DATA) libgnuintl.$la $(DESTDIR)$(libdir)/libgnuintl.$la; \
|
|
||||||
rm -f $(DESTDIR)$(libdir)/preloadable_libintl.so; \
|
|
||||||
$(INSTALL_DATA) $(DESTDIR)$(libdir)/libgnuintl.so $(DESTDIR)$(libdir)/preloadable_libintl.so; \
|
|
||||||
$(LIBTOOL) --mode=uninstall \
|
|
||||||
rm -f $(DESTDIR)$(libdir)/libgnuintl.$la; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test '@USE_INCLUDED_LIBINTL@' = yes; then \
|
|
||||||
test @GLIBC21@ != no || $(mkdir_p) $(DESTDIR)$(libdir); \
|
|
||||||
temp=$(DESTDIR)$(libdir)/t-charset.alias; \
|
|
||||||
dest=$(DESTDIR)$(libdir)/charset.alias; \
|
|
||||||
if test -f $(DESTDIR)$(libdir)/charset.alias; then \
|
|
||||||
orig=$(DESTDIR)$(libdir)/charset.alias; \
|
|
||||||
sed -f ref-add.sed $$orig > $$temp; \
|
|
||||||
$(INSTALL_DATA) $$temp $$dest; \
|
|
||||||
rm -f $$temp; \
|
|
||||||
else \
|
|
||||||
if test @GLIBC21@ = no; then \
|
|
||||||
orig=charset.alias; \
|
|
||||||
sed -f ref-add.sed $$orig > $$temp; \
|
|
||||||
$(INSTALL_DATA) $$temp $$dest; \
|
|
||||||
rm -f $$temp; \
|
|
||||||
fi; \
|
|
||||||
fi; \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(localedir); \
|
|
||||||
test -f $(DESTDIR)$(localedir)/locale.alias \
|
|
||||||
&& orig=$(DESTDIR)$(localedir)/locale.alias \
|
|
||||||
|| orig=$(srcdir)/locale.alias; \
|
|
||||||
temp=$(DESTDIR)$(localedir)/t-locale.alias; \
|
|
||||||
dest=$(DESTDIR)$(localedir)/locale.alias; \
|
|
||||||
sed -f ref-add.sed $$orig > $$temp; \
|
|
||||||
$(INSTALL_DATA) $$temp $$dest; \
|
|
||||||
rm -f $$temp; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
install-data: all
|
|
||||||
if test "$(PACKAGE)" = "gettext-tools"; then \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(gettextsrcdir); \
|
|
||||||
$(INSTALL_DATA) VERSION $(DESTDIR)$(gettextsrcdir)/VERSION; \
|
|
||||||
$(INSTALL_DATA) ChangeLog.inst $(DESTDIR)$(gettextsrcdir)/ChangeLog; \
|
|
||||||
dists="COPYING.LIB-2.0 COPYING.LIB-2.1 $(DISTFILES.common)"; \
|
|
||||||
for file in $$dists; do \
|
|
||||||
$(INSTALL_DATA) $(srcdir)/$$file \
|
|
||||||
$(DESTDIR)$(gettextsrcdir)/$$file; \
|
|
||||||
done; \
|
|
||||||
chmod a+x $(DESTDIR)$(gettextsrcdir)/config.charset; \
|
|
||||||
dists="$(DISTFILES.generated)"; \
|
|
||||||
for file in $$dists; do \
|
|
||||||
if test -f $$file; then dir=.; else dir=$(srcdir); fi; \
|
|
||||||
$(INSTALL_DATA) $$dir/$$file \
|
|
||||||
$(DESTDIR)$(gettextsrcdir)/$$file; \
|
|
||||||
done; \
|
|
||||||
dists="$(DISTFILES.obsolete)"; \
|
|
||||||
for file in $$dists; do \
|
|
||||||
rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
|
|
||||||
done; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
install-strip: install
|
|
||||||
|
|
||||||
install-dvi install-html install-info install-ps install-pdf:
|
|
||||||
|
|
||||||
installdirs:
|
|
||||||
if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
|
|
||||||
&& test '@USE_INCLUDED_LIBINTL@' = yes; then \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(libdir) $(DESTDIR)$(includedir); \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test "$(PACKAGE)" = "gettext-tools" \
|
|
||||||
&& test '@USE_INCLUDED_LIBINTL@' = no \
|
|
||||||
&& test @GLIBC2@ != no; then \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(libdir); \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test '@USE_INCLUDED_LIBINTL@' = yes; then \
|
|
||||||
test @GLIBC21@ != no || $(mkdir_p) $(DESTDIR)$(libdir); \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(localedir); \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test "$(PACKAGE)" = "gettext-tools"; then \
|
|
||||||
$(mkdir_p) $(DESTDIR)$(gettextsrcdir); \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Define this as empty until I found a useful application.
|
|
||||||
installcheck:
|
|
||||||
|
|
||||||
uninstall:
|
|
||||||
if { test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; } \
|
|
||||||
&& test '@USE_INCLUDED_LIBINTL@' = yes; then \
|
|
||||||
rm -f $(DESTDIR)$(includedir)/libintl.h; \
|
|
||||||
$(LIBTOOL) --mode=uninstall \
|
|
||||||
rm -f $(DESTDIR)$(libdir)/libintl.$la; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test "$(PACKAGE)" = "gettext-tools" \
|
|
||||||
&& test '@USE_INCLUDED_LIBINTL@' = no \
|
|
||||||
&& test @GLIBC2@ != no; then \
|
|
||||||
rm -f $(DESTDIR)$(libdir)/preloadable_libintl.so; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test '@USE_INCLUDED_LIBINTL@' = yes; then \
|
|
||||||
if test -f $(DESTDIR)$(libdir)/charset.alias; then \
|
|
||||||
temp=$(DESTDIR)$(libdir)/t-charset.alias; \
|
|
||||||
dest=$(DESTDIR)$(libdir)/charset.alias; \
|
|
||||||
sed -f ref-del.sed $$dest > $$temp; \
|
|
||||||
if grep '^# Packages using this file: $$' $$temp > /dev/null; then \
|
|
||||||
rm -f $$dest; \
|
|
||||||
else \
|
|
||||||
$(INSTALL_DATA) $$temp $$dest; \
|
|
||||||
fi; \
|
|
||||||
rm -f $$temp; \
|
|
||||||
fi; \
|
|
||||||
if test -f $(DESTDIR)$(localedir)/locale.alias; then \
|
|
||||||
temp=$(DESTDIR)$(localedir)/t-locale.alias; \
|
|
||||||
dest=$(DESTDIR)$(localedir)/locale.alias; \
|
|
||||||
sed -f ref-del.sed $$dest > $$temp; \
|
|
||||||
if grep '^# Packages using this file: $$' $$temp > /dev/null; then \
|
|
||||||
rm -f $$dest; \
|
|
||||||
else \
|
|
||||||
$(INSTALL_DATA) $$temp $$dest; \
|
|
||||||
fi; \
|
|
||||||
rm -f $$temp; \
|
|
||||||
fi; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
if test "$(PACKAGE)" = "gettext-tools"; then \
|
|
||||||
for file in VERSION ChangeLog COPYING.LIB-2.0 COPYING.LIB-2.1 $(DISTFILES.common) $(DISTFILES.generated); do \
|
|
||||||
rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \
|
|
||||||
done; \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
info dvi ps pdf html:
|
|
||||||
|
|
||||||
$(OBJECTS): ../config.h libgnuintl.h
|
|
||||||
bindtextdom.$lo dcgettext.$lo dcigettext.$lo dcngettext.$lo dgettext.$lo dngettext.$lo finddomain.$lo gettext.$lo intl-compat.$lo loadmsgcat.$lo localealias.$lo ngettext.$lo textdomain.$lo: $(srcdir)/gettextP.h $(srcdir)/gmo.h $(srcdir)/loadinfo.h
|
|
||||||
hash-string.$lo dcigettext.$lo loadmsgcat.$lo: $(srcdir)/hash-string.h
|
|
||||||
explodename.$lo l10nflist.$lo: $(srcdir)/loadinfo.h
|
|
||||||
dcigettext.$lo loadmsgcat.$lo plural.$lo plural-exp.$lo: $(srcdir)/plural-exp.h
|
|
||||||
dcigettext.$lo: $(srcdir)/eval-plural.h
|
|
||||||
localcharset.$lo: $(srcdir)/localcharset.h
|
|
||||||
bindtextdom.$lo dcigettext.$lo finddomain.$lo loadmsgcat.$lo localealias.$lo lock.$lo log.$lo: $(srcdir)/lock.h
|
|
||||||
localealias.$lo localcharset.$lo relocatable.$lo: $(srcdir)/relocatable.h
|
|
||||||
printf.$lo: $(srcdir)/printf-args.h $(srcdir)/printf-args.c $(srcdir)/printf-parse.h $(srcdir)/wprintf-parse.h $(srcdir)/xsize.h $(srcdir)/printf-parse.c $(srcdir)/vasnprintf.h $(srcdir)/vasnwprintf.h $(srcdir)/vasnprintf.c
|
|
||||||
|
|
||||||
# A bison-2.1 generated plural.c includes <libintl.h> if ENABLE_NLS.
|
|
||||||
PLURAL_DEPS_yes = libintl.h
|
|
||||||
PLURAL_DEPS_no =
|
|
||||||
plural.$lo: $(PLURAL_DEPS_@USE_INCLUDED_LIBINTL@)
|
|
||||||
|
|
||||||
tags: TAGS
|
|
||||||
|
|
||||||
TAGS: $(HEADERS) $(SOURCES)
|
|
||||||
here=`pwd`; cd $(srcdir) && etags -o $$here/TAGS $(HEADERS) $(SOURCES)
|
|
||||||
|
|
||||||
ctags: CTAGS
|
|
||||||
|
|
||||||
CTAGS: $(HEADERS) $(SOURCES)
|
|
||||||
here=`pwd`; cd $(srcdir) && ctags -o $$here/CTAGS $(HEADERS) $(SOURCES)
|
|
||||||
|
|
||||||
id: ID
|
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES)
|
|
||||||
here=`pwd`; cd $(srcdir) && mkid -f$$here/ID $(HEADERS) $(SOURCES)
|
|
||||||
|
|
||||||
|
|
||||||
mostlyclean:
|
|
||||||
rm -f *.a *.la *.o *.obj *.lo libintl.res core core.*
|
|
||||||
rm -f libgnuintl.h libintl.h charset.alias ref-add.sed ref-del.sed
|
|
||||||
rm -f -r .libs _libs
|
|
||||||
|
|
||||||
clean: mostlyclean
|
|
||||||
|
|
||||||
distclean: clean
|
|
||||||
rm -f Makefile ID TAGS
|
|
||||||
if test "$(PACKAGE)" = "gettext-runtime" || test "$(PACKAGE)" = "gettext-tools"; then \
|
|
||||||
rm -f ChangeLog.inst $(DISTFILES.normal); \
|
|
||||||
else \
|
|
||||||
: ; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
maintainer-clean: distclean
|
|
||||||
@echo "This command is intended for maintainers to use;"
|
|
||||||
@echo "it deletes files that may require special tools to rebuild."
|
|
||||||
|
|
||||||
|
|
||||||
# GNU gettext needs not contain the file `VERSION' but contains some
|
|
||||||
# other files which should not be distributed in other packages.
|
|
||||||
distdir = ../$(PACKAGE)-$(VERSION)/$(subdir)
|
|
||||||
dist distdir: Makefile
|
|
||||||
if test "$(PACKAGE)" = "gettext-tools"; then \
|
|
||||||
: ; \
|
|
||||||
else \
|
|
||||||
if test "$(PACKAGE)" = "gettext-runtime"; then \
|
|
||||||
additional="$(DISTFILES.gettext)"; \
|
|
||||||
else \
|
|
||||||
additional="$(DISTFILES.normal)"; \
|
|
||||||
fi; \
|
|
||||||
$(MAKE) $(DISTFILES.common) $(DISTFILES.generated) $$additional; \
|
|
||||||
for file in ChangeLog $(DISTFILES.common) $(DISTFILES.generated) $$additional; do \
|
|
||||||
if test -f $$file; then dir=.; else dir=$(srcdir); fi; \
|
|
||||||
cp -p $$dir/$$file $(distdir) || test $$file = Makefile.in || exit 1; \
|
|
||||||
done; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status
|
|
||||||
# This would be more efficient, but doesn't work any more with autoconf-2.57,
|
|
||||||
# when AC_CONFIG_FILES([intl/Makefile:somedir/Makefile.in]) is used.
|
|
||||||
# cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
|
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make not to export all variables.
|
|
||||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
||||||
.NOEXPORT:
|
|
|
@ -1 +0,0 @@
|
||||||
GNU gettext library from gettext-0.17
|
|
|
@ -1,340 +0,0 @@
|
||||||
/* Implementation of the bindtextdomain(3) function
|
|
||||||
Copyright (C) 1995-1998, 2000-2003, 2005-2006 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Handle multi-threaded applications. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <bits/libc-lock.h>
|
|
||||||
# define gl_rwlock_define __libc_rwlock_define
|
|
||||||
# define gl_rwlock_wrlock __libc_rwlock_wrlock
|
|
||||||
# define gl_rwlock_unlock __libc_rwlock_unlock
|
|
||||||
#else
|
|
||||||
# include "lock.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Some compilers, like SunOS4 cc, don't have offsetof in <stddef.h>. */
|
|
||||||
#ifndef offsetof
|
|
||||||
# define offsetof(type,ident) ((size_t)&(((type*)0)->ident))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* Lock variable to protect the global data in the gettext implementation. */
|
|
||||||
gl_rwlock_define (extern, _nl_state_lock attribute_hidden)
|
|
||||||
|
|
||||||
|
|
||||||
/* Names for the libintl functions are a problem. They must not clash
|
|
||||||
with existing names and they should follow ANSI C. But this source
|
|
||||||
code is also used in GNU C Library where the names have a __
|
|
||||||
prefix. So we have to make a difference here. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define BINDTEXTDOMAIN __bindtextdomain
|
|
||||||
# define BIND_TEXTDOMAIN_CODESET __bind_textdomain_codeset
|
|
||||||
# ifndef strdup
|
|
||||||
# define strdup(str) __strdup (str)
|
|
||||||
# endif
|
|
||||||
#else
|
|
||||||
# define BINDTEXTDOMAIN libintl_bindtextdomain
|
|
||||||
# define BIND_TEXTDOMAIN_CODESET libintl_bind_textdomain_codeset
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Specifies the directory name *DIRNAMEP and the output codeset *CODESETP
|
|
||||||
to be used for the DOMAINNAME message catalog.
|
|
||||||
If *DIRNAMEP or *CODESETP is NULL, the corresponding attribute is not
|
|
||||||
modified, only the current value is returned.
|
|
||||||
If DIRNAMEP or CODESETP is NULL, the corresponding attribute is neither
|
|
||||||
modified nor returned. */
|
|
||||||
static void
|
|
||||||
set_binding_values (const char *domainname,
|
|
||||||
const char **dirnamep, const char **codesetp)
|
|
||||||
{
|
|
||||||
struct binding *binding;
|
|
||||||
int modified;
|
|
||||||
|
|
||||||
/* Some sanity checks. */
|
|
||||||
if (domainname == NULL || domainname[0] == '\0')
|
|
||||||
{
|
|
||||||
if (dirnamep)
|
|
||||||
*dirnamep = NULL;
|
|
||||||
if (codesetp)
|
|
||||||
*codesetp = NULL;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
gl_rwlock_wrlock (_nl_state_lock);
|
|
||||||
|
|
||||||
modified = 0;
|
|
||||||
|
|
||||||
for (binding = _nl_domain_bindings; binding != NULL; binding = binding->next)
|
|
||||||
{
|
|
||||||
int compare = strcmp (domainname, binding->domainname);
|
|
||||||
if (compare == 0)
|
|
||||||
/* We found it! */
|
|
||||||
break;
|
|
||||||
if (compare < 0)
|
|
||||||
{
|
|
||||||
/* It is not in the list. */
|
|
||||||
binding = NULL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (binding != NULL)
|
|
||||||
{
|
|
||||||
if (dirnamep)
|
|
||||||
{
|
|
||||||
const char *dirname = *dirnamep;
|
|
||||||
|
|
||||||
if (dirname == NULL)
|
|
||||||
/* The current binding has be to returned. */
|
|
||||||
*dirnamep = binding->dirname;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* The domain is already bound. If the new value and the old
|
|
||||||
one are equal we simply do nothing. Otherwise replace the
|
|
||||||
old binding. */
|
|
||||||
char *result = binding->dirname;
|
|
||||||
if (strcmp (dirname, result) != 0)
|
|
||||||
{
|
|
||||||
if (strcmp (dirname, _nl_default_dirname) == 0)
|
|
||||||
result = (char *) _nl_default_dirname;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
#if defined _LIBC || defined HAVE_STRDUP
|
|
||||||
result = strdup (dirname);
|
|
||||||
#else
|
|
||||||
size_t len = strlen (dirname) + 1;
|
|
||||||
result = (char *) malloc (len);
|
|
||||||
if (__builtin_expect (result != NULL, 1))
|
|
||||||
memcpy (result, dirname, len);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
if (__builtin_expect (result != NULL, 1))
|
|
||||||
{
|
|
||||||
if (binding->dirname != _nl_default_dirname)
|
|
||||||
free (binding->dirname);
|
|
||||||
|
|
||||||
binding->dirname = result;
|
|
||||||
modified = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*dirnamep = result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (codesetp)
|
|
||||||
{
|
|
||||||
const char *codeset = *codesetp;
|
|
||||||
|
|
||||||
if (codeset == NULL)
|
|
||||||
/* The current binding has be to returned. */
|
|
||||||
*codesetp = binding->codeset;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* The domain is already bound. If the new value and the old
|
|
||||||
one are equal we simply do nothing. Otherwise replace the
|
|
||||||
old binding. */
|
|
||||||
char *result = binding->codeset;
|
|
||||||
if (result == NULL || strcmp (codeset, result) != 0)
|
|
||||||
{
|
|
||||||
#if defined _LIBC || defined HAVE_STRDUP
|
|
||||||
result = strdup (codeset);
|
|
||||||
#else
|
|
||||||
size_t len = strlen (codeset) + 1;
|
|
||||||
result = (char *) malloc (len);
|
|
||||||
if (__builtin_expect (result != NULL, 1))
|
|
||||||
memcpy (result, codeset, len);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (__builtin_expect (result != NULL, 1))
|
|
||||||
{
|
|
||||||
if (binding->codeset != NULL)
|
|
||||||
free (binding->codeset);
|
|
||||||
|
|
||||||
binding->codeset = result;
|
|
||||||
modified = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*codesetp = result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if ((dirnamep == NULL || *dirnamep == NULL)
|
|
||||||
&& (codesetp == NULL || *codesetp == NULL))
|
|
||||||
{
|
|
||||||
/* Simply return the default values. */
|
|
||||||
if (dirnamep)
|
|
||||||
*dirnamep = _nl_default_dirname;
|
|
||||||
if (codesetp)
|
|
||||||
*codesetp = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* We have to create a new binding. */
|
|
||||||
size_t len = strlen (domainname) + 1;
|
|
||||||
struct binding *new_binding =
|
|
||||||
(struct binding *) malloc (offsetof (struct binding, domainname) + len);
|
|
||||||
|
|
||||||
if (__builtin_expect (new_binding == NULL, 0))
|
|
||||||
goto failed;
|
|
||||||
|
|
||||||
memcpy (new_binding->domainname, domainname, len);
|
|
||||||
|
|
||||||
if (dirnamep)
|
|
||||||
{
|
|
||||||
const char *dirname = *dirnamep;
|
|
||||||
|
|
||||||
if (dirname == NULL)
|
|
||||||
/* The default value. */
|
|
||||||
dirname = _nl_default_dirname;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (strcmp (dirname, _nl_default_dirname) == 0)
|
|
||||||
dirname = _nl_default_dirname;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
char *result;
|
|
||||||
#if defined _LIBC || defined HAVE_STRDUP
|
|
||||||
result = strdup (dirname);
|
|
||||||
if (__builtin_expect (result == NULL, 0))
|
|
||||||
goto failed_dirname;
|
|
||||||
#else
|
|
||||||
size_t len = strlen (dirname) + 1;
|
|
||||||
result = (char *) malloc (len);
|
|
||||||
if (__builtin_expect (result == NULL, 0))
|
|
||||||
goto failed_dirname;
|
|
||||||
memcpy (result, dirname, len);
|
|
||||||
#endif
|
|
||||||
dirname = result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*dirnamep = dirname;
|
|
||||||
new_binding->dirname = (char *) dirname;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
/* The default value. */
|
|
||||||
new_binding->dirname = (char *) _nl_default_dirname;
|
|
||||||
|
|
||||||
if (codesetp)
|
|
||||||
{
|
|
||||||
const char *codeset = *codesetp;
|
|
||||||
|
|
||||||
if (codeset != NULL)
|
|
||||||
{
|
|
||||||
char *result;
|
|
||||||
|
|
||||||
#if defined _LIBC || defined HAVE_STRDUP
|
|
||||||
result = strdup (codeset);
|
|
||||||
if (__builtin_expect (result == NULL, 0))
|
|
||||||
goto failed_codeset;
|
|
||||||
#else
|
|
||||||
size_t len = strlen (codeset) + 1;
|
|
||||||
result = (char *) malloc (len);
|
|
||||||
if (__builtin_expect (result == NULL, 0))
|
|
||||||
goto failed_codeset;
|
|
||||||
memcpy (result, codeset, len);
|
|
||||||
#endif
|
|
||||||
codeset = result;
|
|
||||||
}
|
|
||||||
*codesetp = codeset;
|
|
||||||
new_binding->codeset = (char *) codeset;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
new_binding->codeset = NULL;
|
|
||||||
|
|
||||||
/* Now enqueue it. */
|
|
||||||
if (_nl_domain_bindings == NULL
|
|
||||||
|| strcmp (domainname, _nl_domain_bindings->domainname) < 0)
|
|
||||||
{
|
|
||||||
new_binding->next = _nl_domain_bindings;
|
|
||||||
_nl_domain_bindings = new_binding;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
binding = _nl_domain_bindings;
|
|
||||||
while (binding->next != NULL
|
|
||||||
&& strcmp (domainname, binding->next->domainname) > 0)
|
|
||||||
binding = binding->next;
|
|
||||||
|
|
||||||
new_binding->next = binding->next;
|
|
||||||
binding->next = new_binding;
|
|
||||||
}
|
|
||||||
|
|
||||||
modified = 1;
|
|
||||||
|
|
||||||
/* Here we deal with memory allocation failures. */
|
|
||||||
if (0)
|
|
||||||
{
|
|
||||||
failed_codeset:
|
|
||||||
if (new_binding->dirname != _nl_default_dirname)
|
|
||||||
free (new_binding->dirname);
|
|
||||||
failed_dirname:
|
|
||||||
free (new_binding);
|
|
||||||
failed:
|
|
||||||
if (dirnamep)
|
|
||||||
*dirnamep = NULL;
|
|
||||||
if (codesetp)
|
|
||||||
*codesetp = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If we modified any binding, we flush the caches. */
|
|
||||||
if (modified)
|
|
||||||
++_nl_msg_cat_cntr;
|
|
||||||
|
|
||||||
gl_rwlock_unlock (_nl_state_lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Specify that the DOMAINNAME message catalog will be found
|
|
||||||
in DIRNAME rather than in the system locale data base. */
|
|
||||||
char *
|
|
||||||
BINDTEXTDOMAIN (const char *domainname, const char *dirname)
|
|
||||||
{
|
|
||||||
set_binding_values (domainname, &dirname, NULL);
|
|
||||||
return (char *) dirname;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Specify the character encoding in which the messages from the
|
|
||||||
DOMAINNAME message catalog will be returned. */
|
|
||||||
char *
|
|
||||||
BIND_TEXTDOMAIN_CODESET (const char *domainname, const char *codeset)
|
|
||||||
{
|
|
||||||
set_binding_values (domainname, NULL, &codeset);
|
|
||||||
return (char *) codeset;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Aliases for function names in GNU C Library. */
|
|
||||||
weak_alias (__bindtextdomain, bindtextdomain);
|
|
||||||
weak_alias (__bind_textdomain_codeset, bind_textdomain_codeset);
|
|
||||||
#endif
|
|
|
@ -1,640 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
# Output a system dependent table of character encoding aliases.
|
|
||||||
#
|
|
||||||
# Copyright (C) 2000-2004, 2006 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify it
|
|
||||||
# under the terms of the GNU Library General Public License as published
|
|
||||||
# by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
# Library General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU Library General Public
|
|
||||||
# License along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
# USA.
|
|
||||||
#
|
|
||||||
# The table consists of lines of the form
|
|
||||||
# ALIAS CANONICAL
|
|
||||||
#
|
|
||||||
# ALIAS is the (system dependent) result of "nl_langinfo (CODESET)".
|
|
||||||
# ALIAS is compared in a case sensitive way.
|
|
||||||
#
|
|
||||||
# CANONICAL is the GNU canonical name for this character encoding.
|
|
||||||
# It must be an encoding supported by libiconv. Support by GNU libc is
|
|
||||||
# also desirable. CANONICAL is case insensitive. Usually an upper case
|
|
||||||
# MIME charset name is preferred.
|
|
||||||
# The current list of GNU canonical charset names is as follows.
|
|
||||||
#
|
|
||||||
# name MIME? used by which systems
|
|
||||||
# ASCII, ANSI_X3.4-1968 glibc solaris freebsd netbsd darwin
|
|
||||||
# ISO-8859-1 Y glibc aix hpux irix osf solaris freebsd netbsd darwin
|
|
||||||
# ISO-8859-2 Y glibc aix hpux irix osf solaris freebsd netbsd darwin
|
|
||||||
# ISO-8859-3 Y glibc solaris
|
|
||||||
# ISO-8859-4 Y osf solaris freebsd netbsd darwin
|
|
||||||
# ISO-8859-5 Y glibc aix hpux irix osf solaris freebsd netbsd darwin
|
|
||||||
# ISO-8859-6 Y glibc aix hpux solaris
|
|
||||||
# ISO-8859-7 Y glibc aix hpux irix osf solaris netbsd darwin
|
|
||||||
# ISO-8859-8 Y glibc aix hpux osf solaris
|
|
||||||
# ISO-8859-9 Y glibc aix hpux irix osf solaris darwin
|
|
||||||
# ISO-8859-13 glibc netbsd darwin
|
|
||||||
# ISO-8859-14 glibc
|
|
||||||
# ISO-8859-15 glibc aix osf solaris freebsd darwin
|
|
||||||
# KOI8-R Y glibc solaris freebsd netbsd darwin
|
|
||||||
# KOI8-U Y glibc freebsd netbsd darwin
|
|
||||||
# KOI8-T glibc
|
|
||||||
# CP437 dos
|
|
||||||
# CP775 dos
|
|
||||||
# CP850 aix osf dos
|
|
||||||
# CP852 dos
|
|
||||||
# CP855 dos
|
|
||||||
# CP856 aix
|
|
||||||
# CP857 dos
|
|
||||||
# CP861 dos
|
|
||||||
# CP862 dos
|
|
||||||
# CP864 dos
|
|
||||||
# CP865 dos
|
|
||||||
# CP866 freebsd netbsd darwin dos
|
|
||||||
# CP869 dos
|
|
||||||
# CP874 woe32 dos
|
|
||||||
# CP922 aix
|
|
||||||
# CP932 aix woe32 dos
|
|
||||||
# CP943 aix
|
|
||||||
# CP949 osf woe32 dos
|
|
||||||
# CP950 woe32 dos
|
|
||||||
# CP1046 aix
|
|
||||||
# CP1124 aix
|
|
||||||
# CP1125 dos
|
|
||||||
# CP1129 aix
|
|
||||||
# CP1250 woe32
|
|
||||||
# CP1251 glibc solaris netbsd darwin woe32
|
|
||||||
# CP1252 aix woe32
|
|
||||||
# CP1253 woe32
|
|
||||||
# CP1254 woe32
|
|
||||||
# CP1255 glibc woe32
|
|
||||||
# CP1256 woe32
|
|
||||||
# CP1257 woe32
|
|
||||||
# GB2312 Y glibc aix hpux irix solaris freebsd netbsd darwin
|
|
||||||
# EUC-JP Y glibc aix hpux irix osf solaris freebsd netbsd darwin
|
|
||||||
# EUC-KR Y glibc aix hpux irix osf solaris freebsd netbsd darwin
|
|
||||||
# EUC-TW glibc aix hpux irix osf solaris netbsd
|
|
||||||
# BIG5 Y glibc aix hpux osf solaris freebsd netbsd darwin
|
|
||||||
# BIG5-HKSCS glibc solaris
|
|
||||||
# GBK glibc aix osf solaris woe32 dos
|
|
||||||
# GB18030 glibc solaris netbsd
|
|
||||||
# SHIFT_JIS Y hpux osf solaris freebsd netbsd darwin
|
|
||||||
# JOHAB glibc solaris woe32
|
|
||||||
# TIS-620 glibc aix hpux osf solaris
|
|
||||||
# VISCII Y glibc
|
|
||||||
# TCVN5712-1 glibc
|
|
||||||
# GEORGIAN-PS glibc
|
|
||||||
# HP-ROMAN8 hpux
|
|
||||||
# HP-ARABIC8 hpux
|
|
||||||
# HP-GREEK8 hpux
|
|
||||||
# HP-HEBREW8 hpux
|
|
||||||
# HP-TURKISH8 hpux
|
|
||||||
# HP-KANA8 hpux
|
|
||||||
# DEC-KANJI osf
|
|
||||||
# DEC-HANYU osf
|
|
||||||
# UTF-8 Y glibc aix hpux osf solaris netbsd darwin
|
|
||||||
#
|
|
||||||
# Note: Names which are not marked as being a MIME name should not be used in
|
|
||||||
# Internet protocols for information interchange (mail, news, etc.).
|
|
||||||
#
|
|
||||||
# Note: ASCII and ANSI_X3.4-1968 are synonymous canonical names. Applications
|
|
||||||
# must understand both names and treat them as equivalent.
|
|
||||||
#
|
|
||||||
# The first argument passed to this file is the canonical host specification,
|
|
||||||
# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM
|
|
||||||
# or
|
|
||||||
# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
|
|
||||||
|
|
||||||
host="$1"
|
|
||||||
os=`echo "$host" | sed -e 's/^[^-]*-[^-]*-\(.*\)$/\1/'`
|
|
||||||
echo "# This file contains a table of character encoding aliases,"
|
|
||||||
echo "# suitable for operating system '${os}'."
|
|
||||||
echo "# It was automatically generated from config.charset."
|
|
||||||
# List of references, updated during installation:
|
|
||||||
echo "# Packages using this file: "
|
|
||||||
case "$os" in
|
|
||||||
linux-gnulibc1*)
|
|
||||||
# Linux libc5 doesn't have nl_langinfo(CODESET); therefore
|
|
||||||
# localcharset.c falls back to using the full locale name
|
|
||||||
# from the environment variables.
|
|
||||||
echo "C ASCII"
|
|
||||||
echo "POSIX ASCII"
|
|
||||||
for l in af af_ZA ca ca_ES da da_DK de de_AT de_BE de_CH de_DE de_LU \
|
|
||||||
en en_AU en_BW en_CA en_DK en_GB en_IE en_NZ en_US en_ZA \
|
|
||||||
en_ZW es es_AR es_BO es_CL es_CO es_DO es_EC es_ES es_GT \
|
|
||||||
es_HN es_MX es_PA es_PE es_PY es_SV es_US es_UY es_VE et \
|
|
||||||
et_EE eu eu_ES fi fi_FI fo fo_FO fr fr_BE fr_CA fr_CH fr_FR \
|
|
||||||
fr_LU ga ga_IE gl gl_ES id id_ID in in_ID is is_IS it it_CH \
|
|
||||||
it_IT kl kl_GL nl nl_BE nl_NL no no_NO pt pt_BR pt_PT sv \
|
|
||||||
sv_FI sv_SE; do
|
|
||||||
echo "$l ISO-8859-1"
|
|
||||||
echo "$l.iso-8859-1 ISO-8859-1"
|
|
||||||
echo "$l.iso-8859-15 ISO-8859-15"
|
|
||||||
echo "$l.iso-8859-15@euro ISO-8859-15"
|
|
||||||
echo "$l@euro ISO-8859-15"
|
|
||||||
echo "$l.cp-437 CP437"
|
|
||||||
echo "$l.cp-850 CP850"
|
|
||||||
echo "$l.cp-1252 CP1252"
|
|
||||||
echo "$l.cp-1252@euro CP1252"
|
|
||||||
#echo "$l.atari-st ATARI-ST" # not a commonly used encoding
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
echo "$l.utf-8@euro UTF-8"
|
|
||||||
done
|
|
||||||
for l in cs cs_CZ hr hr_HR hu hu_HU pl pl_PL ro ro_RO sk sk_SK sl \
|
|
||||||
sl_SI sr sr_CS sr_YU; do
|
|
||||||
echo "$l ISO-8859-2"
|
|
||||||
echo "$l.iso-8859-2 ISO-8859-2"
|
|
||||||
echo "$l.cp-852 CP852"
|
|
||||||
echo "$l.cp-1250 CP1250"
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
done
|
|
||||||
for l in mk mk_MK ru ru_RU; do
|
|
||||||
echo "$l ISO-8859-5"
|
|
||||||
echo "$l.iso-8859-5 ISO-8859-5"
|
|
||||||
echo "$l.koi8-r KOI8-R"
|
|
||||||
echo "$l.cp-866 CP866"
|
|
||||||
echo "$l.cp-1251 CP1251"
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
done
|
|
||||||
for l in ar ar_SA; do
|
|
||||||
echo "$l ISO-8859-6"
|
|
||||||
echo "$l.iso-8859-6 ISO-8859-6"
|
|
||||||
echo "$l.cp-864 CP864"
|
|
||||||
#echo "$l.cp-868 CP868" # not a commonly used encoding
|
|
||||||
echo "$l.cp-1256 CP1256"
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
done
|
|
||||||
for l in el el_GR gr gr_GR; do
|
|
||||||
echo "$l ISO-8859-7"
|
|
||||||
echo "$l.iso-8859-7 ISO-8859-7"
|
|
||||||
echo "$l.cp-869 CP869"
|
|
||||||
echo "$l.cp-1253 CP1253"
|
|
||||||
echo "$l.cp-1253@euro CP1253"
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
echo "$l.utf-8@euro UTF-8"
|
|
||||||
done
|
|
||||||
for l in he he_IL iw iw_IL; do
|
|
||||||
echo "$l ISO-8859-8"
|
|
||||||
echo "$l.iso-8859-8 ISO-8859-8"
|
|
||||||
echo "$l.cp-862 CP862"
|
|
||||||
echo "$l.cp-1255 CP1255"
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
done
|
|
||||||
for l in tr tr_TR; do
|
|
||||||
echo "$l ISO-8859-9"
|
|
||||||
echo "$l.iso-8859-9 ISO-8859-9"
|
|
||||||
echo "$l.cp-857 CP857"
|
|
||||||
echo "$l.cp-1254 CP1254"
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
done
|
|
||||||
for l in lt lt_LT lv lv_LV; do
|
|
||||||
#echo "$l BALTIC" # not a commonly used encoding, wrong encoding name
|
|
||||||
echo "$l ISO-8859-13"
|
|
||||||
done
|
|
||||||
for l in ru_UA uk uk_UA; do
|
|
||||||
echo "$l KOI8-U"
|
|
||||||
done
|
|
||||||
for l in zh zh_CN; do
|
|
||||||
#echo "$l GB_2312-80" # not a commonly used encoding, wrong encoding name
|
|
||||||
echo "$l GB2312"
|
|
||||||
done
|
|
||||||
for l in ja ja_JP ja_JP.EUC; do
|
|
||||||
echo "$l EUC-JP"
|
|
||||||
done
|
|
||||||
for l in ko ko_KR; do
|
|
||||||
echo "$l EUC-KR"
|
|
||||||
done
|
|
||||||
for l in th th_TH; do
|
|
||||||
echo "$l TIS-620"
|
|
||||||
done
|
|
||||||
for l in fa fa_IR; do
|
|
||||||
#echo "$l ISIRI-3342" # a broken encoding
|
|
||||||
echo "$l.utf-8 UTF-8"
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
linux* | *-gnu*)
|
|
||||||
# With glibc-2.1 or newer, we don't need any canonicalization,
|
|
||||||
# because glibc has iconv and both glibc and libiconv support all
|
|
||||||
# GNU canonical names directly. Therefore, the Makefile does not
|
|
||||||
# need to install the alias file at all.
|
|
||||||
# The following applies only to glibc-2.0.x and older libcs.
|
|
||||||
echo "ISO_646.IRV:1983 ASCII"
|
|
||||||
;;
|
|
||||||
aix*)
|
|
||||||
echo "ISO8859-1 ISO-8859-1"
|
|
||||||
echo "ISO8859-2 ISO-8859-2"
|
|
||||||
echo "ISO8859-5 ISO-8859-5"
|
|
||||||
echo "ISO8859-6 ISO-8859-6"
|
|
||||||
echo "ISO8859-7 ISO-8859-7"
|
|
||||||
echo "ISO8859-8 ISO-8859-8"
|
|
||||||
echo "ISO8859-9 ISO-8859-9"
|
|
||||||
echo "ISO8859-15 ISO-8859-15"
|
|
||||||
echo "IBM-850 CP850"
|
|
||||||
echo "IBM-856 CP856"
|
|
||||||
echo "IBM-921 ISO-8859-13"
|
|
||||||
echo "IBM-922 CP922"
|
|
||||||
echo "IBM-932 CP932"
|
|
||||||
echo "IBM-943 CP943"
|
|
||||||
echo "IBM-1046 CP1046"
|
|
||||||
echo "IBM-1124 CP1124"
|
|
||||||
echo "IBM-1129 CP1129"
|
|
||||||
echo "IBM-1252 CP1252"
|
|
||||||
echo "IBM-eucCN GB2312"
|
|
||||||
echo "IBM-eucJP EUC-JP"
|
|
||||||
echo "IBM-eucKR EUC-KR"
|
|
||||||
echo "IBM-eucTW EUC-TW"
|
|
||||||
echo "big5 BIG5"
|
|
||||||
echo "GBK GBK"
|
|
||||||
echo "TIS-620 TIS-620"
|
|
||||||
echo "UTF-8 UTF-8"
|
|
||||||
;;
|
|
||||||
hpux*)
|
|
||||||
echo "iso88591 ISO-8859-1"
|
|
||||||
echo "iso88592 ISO-8859-2"
|
|
||||||
echo "iso88595 ISO-8859-5"
|
|
||||||
echo "iso88596 ISO-8859-6"
|
|
||||||
echo "iso88597 ISO-8859-7"
|
|
||||||
echo "iso88598 ISO-8859-8"
|
|
||||||
echo "iso88599 ISO-8859-9"
|
|
||||||
echo "iso885915 ISO-8859-15"
|
|
||||||
echo "roman8 HP-ROMAN8"
|
|
||||||
echo "arabic8 HP-ARABIC8"
|
|
||||||
echo "greek8 HP-GREEK8"
|
|
||||||
echo "hebrew8 HP-HEBREW8"
|
|
||||||
echo "turkish8 HP-TURKISH8"
|
|
||||||
echo "kana8 HP-KANA8"
|
|
||||||
echo "tis620 TIS-620"
|
|
||||||
echo "big5 BIG5"
|
|
||||||
echo "eucJP EUC-JP"
|
|
||||||
echo "eucKR EUC-KR"
|
|
||||||
echo "eucTW EUC-TW"
|
|
||||||
echo "hp15CN GB2312"
|
|
||||||
#echo "ccdc ?" # what is this?
|
|
||||||
echo "SJIS SHIFT_JIS"
|
|
||||||
echo "utf8 UTF-8"
|
|
||||||
;;
|
|
||||||
irix*)
|
|
||||||
echo "ISO8859-1 ISO-8859-1"
|
|
||||||
echo "ISO8859-2 ISO-8859-2"
|
|
||||||
echo "ISO8859-5 ISO-8859-5"
|
|
||||||
echo "ISO8859-7 ISO-8859-7"
|
|
||||||
echo "ISO8859-9 ISO-8859-9"
|
|
||||||
echo "eucCN GB2312"
|
|
||||||
echo "eucJP EUC-JP"
|
|
||||||
echo "eucKR EUC-KR"
|
|
||||||
echo "eucTW EUC-TW"
|
|
||||||
;;
|
|
||||||
osf*)
|
|
||||||
echo "ISO8859-1 ISO-8859-1"
|
|
||||||
echo "ISO8859-2 ISO-8859-2"
|
|
||||||
echo "ISO8859-4 ISO-8859-4"
|
|
||||||
echo "ISO8859-5 ISO-8859-5"
|
|
||||||
echo "ISO8859-7 ISO-8859-7"
|
|
||||||
echo "ISO8859-8 ISO-8859-8"
|
|
||||||
echo "ISO8859-9 ISO-8859-9"
|
|
||||||
echo "ISO8859-15 ISO-8859-15"
|
|
||||||
echo "cp850 CP850"
|
|
||||||
echo "big5 BIG5"
|
|
||||||
echo "dechanyu DEC-HANYU"
|
|
||||||
echo "dechanzi GB2312"
|
|
||||||
echo "deckanji DEC-KANJI"
|
|
||||||
echo "deckorean EUC-KR"
|
|
||||||
echo "eucJP EUC-JP"
|
|
||||||
echo "eucKR EUC-KR"
|
|
||||||
echo "eucTW EUC-TW"
|
|
||||||
echo "GBK GBK"
|
|
||||||
echo "KSC5601 CP949"
|
|
||||||
echo "sdeckanji EUC-JP"
|
|
||||||
echo "SJIS SHIFT_JIS"
|
|
||||||
echo "TACTIS TIS-620"
|
|
||||||
echo "UTF-8 UTF-8"
|
|
||||||
;;
|
|
||||||
solaris*)
|
|
||||||
echo "646 ASCII"
|
|
||||||
echo "ISO8859-1 ISO-8859-1"
|
|
||||||
echo "ISO8859-2 ISO-8859-2"
|
|
||||||
echo "ISO8859-3 ISO-8859-3"
|
|
||||||
echo "ISO8859-4 ISO-8859-4"
|
|
||||||
echo "ISO8859-5 ISO-8859-5"
|
|
||||||
echo "ISO8859-6 ISO-8859-6"
|
|
||||||
echo "ISO8859-7 ISO-8859-7"
|
|
||||||
echo "ISO8859-8 ISO-8859-8"
|
|
||||||
echo "ISO8859-9 ISO-8859-9"
|
|
||||||
echo "ISO8859-15 ISO-8859-15"
|
|
||||||
echo "koi8-r KOI8-R"
|
|
||||||
echo "ansi-1251 CP1251"
|
|
||||||
echo "BIG5 BIG5"
|
|
||||||
echo "Big5-HKSCS BIG5-HKSCS"
|
|
||||||
echo "gb2312 GB2312"
|
|
||||||
echo "GBK GBK"
|
|
||||||
echo "GB18030 GB18030"
|
|
||||||
echo "cns11643 EUC-TW"
|
|
||||||
echo "5601 EUC-KR"
|
|
||||||
echo "ko_KR.johap92 JOHAB"
|
|
||||||
echo "eucJP EUC-JP"
|
|
||||||
echo "PCK SHIFT_JIS"
|
|
||||||
echo "TIS620.2533 TIS-620"
|
|
||||||
#echo "sun_eu_greek ?" # what is this?
|
|
||||||
echo "UTF-8 UTF-8"
|
|
||||||
;;
|
|
||||||
freebsd* | os2*)
|
|
||||||
# FreeBSD 4.2 doesn't have nl_langinfo(CODESET); therefore
|
|
||||||
# localcharset.c falls back to using the full locale name
|
|
||||||
# from the environment variables.
|
|
||||||
# Likewise for OS/2. OS/2 has XFree86 just like FreeBSD. Just
|
|
||||||
# reuse FreeBSD's locale data for OS/2.
|
|
||||||
echo "C ASCII"
|
|
||||||
echo "US-ASCII ASCII"
|
|
||||||
for l in la_LN lt_LN; do
|
|
||||||
echo "$l.ASCII ASCII"
|
|
||||||
done
|
|
||||||
for l in da_DK de_AT de_CH de_DE en_AU en_CA en_GB en_US es_ES \
|
|
||||||
fi_FI fr_BE fr_CA fr_CH fr_FR is_IS it_CH it_IT la_LN \
|
|
||||||
lt_LN nl_BE nl_NL no_NO pt_PT sv_SE; do
|
|
||||||
echo "$l.ISO_8859-1 ISO-8859-1"
|
|
||||||
echo "$l.DIS_8859-15 ISO-8859-15"
|
|
||||||
done
|
|
||||||
for l in cs_CZ hr_HR hu_HU la_LN lt_LN pl_PL sl_SI; do
|
|
||||||
echo "$l.ISO_8859-2 ISO-8859-2"
|
|
||||||
done
|
|
||||||
for l in la_LN lt_LT; do
|
|
||||||
echo "$l.ISO_8859-4 ISO-8859-4"
|
|
||||||
done
|
|
||||||
for l in ru_RU ru_SU; do
|
|
||||||
echo "$l.KOI8-R KOI8-R"
|
|
||||||
echo "$l.ISO_8859-5 ISO-8859-5"
|
|
||||||
echo "$l.CP866 CP866"
|
|
||||||
done
|
|
||||||
echo "uk_UA.KOI8-U KOI8-U"
|
|
||||||
echo "zh_TW.BIG5 BIG5"
|
|
||||||
echo "zh_TW.Big5 BIG5"
|
|
||||||
echo "zh_CN.EUC GB2312"
|
|
||||||
echo "ja_JP.EUC EUC-JP"
|
|
||||||
echo "ja_JP.SJIS SHIFT_JIS"
|
|
||||||
echo "ja_JP.Shift_JIS SHIFT_JIS"
|
|
||||||
echo "ko_KR.EUC EUC-KR"
|
|
||||||
;;
|
|
||||||
netbsd*)
|
|
||||||
echo "646 ASCII"
|
|
||||||
echo "ISO8859-1 ISO-8859-1"
|
|
||||||
echo "ISO8859-2 ISO-8859-2"
|
|
||||||
echo "ISO8859-4 ISO-8859-4"
|
|
||||||
echo "ISO8859-5 ISO-8859-5"
|
|
||||||
echo "ISO8859-7 ISO-8859-7"
|
|
||||||
echo "ISO8859-13 ISO-8859-13"
|
|
||||||
echo "ISO8859-15 ISO-8859-15"
|
|
||||||
echo "eucCN GB2312"
|
|
||||||
echo "eucJP EUC-JP"
|
|
||||||
echo "eucKR EUC-KR"
|
|
||||||
echo "eucTW EUC-TW"
|
|
||||||
echo "BIG5 BIG5"
|
|
||||||
echo "SJIS SHIFT_JIS"
|
|
||||||
;;
|
|
||||||
darwin[56]*)
|
|
||||||
# Darwin 6.8 doesn't have nl_langinfo(CODESET); therefore
|
|
||||||
# localcharset.c falls back to using the full locale name
|
|
||||||
# from the environment variables.
|
|
||||||
echo "C ASCII"
|
|
||||||
for l in en_AU en_CA en_GB en_US la_LN; do
|
|
||||||
echo "$l.US-ASCII ASCII"
|
|
||||||
done
|
|
||||||
for l in da_DK de_AT de_CH de_DE en_AU en_CA en_GB en_US es_ES \
|
|
||||||
fi_FI fr_BE fr_CA fr_CH fr_FR is_IS it_CH it_IT nl_BE \
|
|
||||||
nl_NL no_NO pt_PT sv_SE; do
|
|
||||||
echo "$l ISO-8859-1"
|
|
||||||
echo "$l.ISO8859-1 ISO-8859-1"
|
|
||||||
echo "$l.ISO8859-15 ISO-8859-15"
|
|
||||||
done
|
|
||||||
for l in la_LN; do
|
|
||||||
echo "$l.ISO8859-1 ISO-8859-1"
|
|
||||||
echo "$l.ISO8859-15 ISO-8859-15"
|
|
||||||
done
|
|
||||||
for l in cs_CZ hr_HR hu_HU la_LN pl_PL sl_SI; do
|
|
||||||
echo "$l.ISO8859-2 ISO-8859-2"
|
|
||||||
done
|
|
||||||
for l in la_LN lt_LT; do
|
|
||||||
echo "$l.ISO8859-4 ISO-8859-4"
|
|
||||||
done
|
|
||||||
for l in ru_RU; do
|
|
||||||
echo "$l.KOI8-R KOI8-R"
|
|
||||||
echo "$l.ISO8859-5 ISO-8859-5"
|
|
||||||
echo "$l.CP866 CP866"
|
|
||||||
done
|
|
||||||
for l in bg_BG; do
|
|
||||||
echo "$l.CP1251 CP1251"
|
|
||||||
done
|
|
||||||
echo "uk_UA.KOI8-U KOI8-U"
|
|
||||||
echo "zh_TW.BIG5 BIG5"
|
|
||||||
echo "zh_TW.Big5 BIG5"
|
|
||||||
echo "zh_CN.EUC GB2312"
|
|
||||||
echo "ja_JP.EUC EUC-JP"
|
|
||||||
echo "ja_JP.SJIS SHIFT_JIS"
|
|
||||||
echo "ko_KR.EUC EUC-KR"
|
|
||||||
;;
|
|
||||||
darwin*)
|
|
||||||
# Darwin 7.5 has nl_langinfo(CODESET), but it is useless:
|
|
||||||
# - It returns the empty string when LANG is set to a locale of the
|
|
||||||
# form ll_CC, although ll_CC/LC_CTYPE is a symlink to an UTF-8
|
|
||||||
# LC_CTYPE file.
|
|
||||||
# - The environment variables LANG, LC_CTYPE, LC_ALL are not set by
|
|
||||||
# the system; nl_langinfo(CODESET) returns "US-ASCII" in this case.
|
|
||||||
# - The documentation says:
|
|
||||||
# "... all code that calls BSD system routines should ensure
|
|
||||||
# that the const *char parameters of these routines are in UTF-8
|
|
||||||
# encoding. All BSD system functions expect their string
|
|
||||||
# parameters to be in UTF-8 encoding and nothing else."
|
|
||||||
# It also says
|
|
||||||
# "An additional caveat is that string parameters for files,
|
|
||||||
# paths, and other file-system entities must be in canonical
|
|
||||||
# UTF-8. In a canonical UTF-8 Unicode string, all decomposable
|
|
||||||
# characters are decomposed ..."
|
|
||||||
# but this is not true: You can pass non-decomposed UTF-8 strings
|
|
||||||
# to file system functions, and it is the OS which will convert
|
|
||||||
# them to decomposed UTF-8 before accessing the file system.
|
|
||||||
# - The Apple Terminal application displays UTF-8 by default.
|
|
||||||
# - However, other applications are free to use different encodings:
|
|
||||||
# - xterm uses ISO-8859-1 by default.
|
|
||||||
# - TextEdit uses MacRoman by default.
|
|
||||||
# We prefer UTF-8 over decomposed UTF-8-MAC because one should
|
|
||||||
# minimize the use of decomposed Unicode. Unfortunately, through the
|
|
||||||
# Darwin file system, decomposed UTF-8 strings are leaked into user
|
|
||||||
# space nevertheless.
|
|
||||||
echo "* UTF-8"
|
|
||||||
;;
|
|
||||||
beos*)
|
|
||||||
# BeOS has a single locale, and it has UTF-8 encoding.
|
|
||||||
echo "* UTF-8"
|
|
||||||
;;
|
|
||||||
msdosdjgpp*)
|
|
||||||
# DJGPP 2.03 doesn't have nl_langinfo(CODESET); therefore
|
|
||||||
# localcharset.c falls back to using the full locale name
|
|
||||||
# from the environment variables.
|
|
||||||
echo "#"
|
|
||||||
echo "# The encodings given here may not all be correct."
|
|
||||||
echo "# If you find that the encoding given for your language and"
|
|
||||||
echo "# country is not the one your DOS machine actually uses, just"
|
|
||||||
echo "# correct it in this file, and send a mail to"
|
|
||||||
echo "# Juan Manuel Guerrero <juan.guerrero@gmx.de>"
|
|
||||||
echo "# and Bruno Haible <bruno@clisp.org>."
|
|
||||||
echo "#"
|
|
||||||
echo "C ASCII"
|
|
||||||
# ISO-8859-1 languages
|
|
||||||
echo "ca CP850"
|
|
||||||
echo "ca_ES CP850"
|
|
||||||
echo "da CP865" # not CP850 ??
|
|
||||||
echo "da_DK CP865" # not CP850 ??
|
|
||||||
echo "de CP850"
|
|
||||||
echo "de_AT CP850"
|
|
||||||
echo "de_CH CP850"
|
|
||||||
echo "de_DE CP850"
|
|
||||||
echo "en CP850"
|
|
||||||
echo "en_AU CP850" # not CP437 ??
|
|
||||||
echo "en_CA CP850"
|
|
||||||
echo "en_GB CP850"
|
|
||||||
echo "en_NZ CP437"
|
|
||||||
echo "en_US CP437"
|
|
||||||
echo "en_ZA CP850" # not CP437 ??
|
|
||||||
echo "es CP850"
|
|
||||||
echo "es_AR CP850"
|
|
||||||
echo "es_BO CP850"
|
|
||||||
echo "es_CL CP850"
|
|
||||||
echo "es_CO CP850"
|
|
||||||
echo "es_CR CP850"
|
|
||||||
echo "es_CU CP850"
|
|
||||||
echo "es_DO CP850"
|
|
||||||
echo "es_EC CP850"
|
|
||||||
echo "es_ES CP850"
|
|
||||||
echo "es_GT CP850"
|
|
||||||
echo "es_HN CP850"
|
|
||||||
echo "es_MX CP850"
|
|
||||||
echo "es_NI CP850"
|
|
||||||
echo "es_PA CP850"
|
|
||||||
echo "es_PY CP850"
|
|
||||||
echo "es_PE CP850"
|
|
||||||
echo "es_SV CP850"
|
|
||||||
echo "es_UY CP850"
|
|
||||||
echo "es_VE CP850"
|
|
||||||
echo "et CP850"
|
|
||||||
echo "et_EE CP850"
|
|
||||||
echo "eu CP850"
|
|
||||||
echo "eu_ES CP850"
|
|
||||||
echo "fi CP850"
|
|
||||||
echo "fi_FI CP850"
|
|
||||||
echo "fr CP850"
|
|
||||||
echo "fr_BE CP850"
|
|
||||||
echo "fr_CA CP850"
|
|
||||||
echo "fr_CH CP850"
|
|
||||||
echo "fr_FR CP850"
|
|
||||||
echo "ga CP850"
|
|
||||||
echo "ga_IE CP850"
|
|
||||||
echo "gd CP850"
|
|
||||||
echo "gd_GB CP850"
|
|
||||||
echo "gl CP850"
|
|
||||||
echo "gl_ES CP850"
|
|
||||||
echo "id CP850" # not CP437 ??
|
|
||||||
echo "id_ID CP850" # not CP437 ??
|
|
||||||
echo "is CP861" # not CP850 ??
|
|
||||||
echo "is_IS CP861" # not CP850 ??
|
|
||||||
echo "it CP850"
|
|
||||||
echo "it_CH CP850"
|
|
||||||
echo "it_IT CP850"
|
|
||||||
echo "lt CP775"
|
|
||||||
echo "lt_LT CP775"
|
|
||||||
echo "lv CP775"
|
|
||||||
echo "lv_LV CP775"
|
|
||||||
echo "nb CP865" # not CP850 ??
|
|
||||||
echo "nb_NO CP865" # not CP850 ??
|
|
||||||
echo "nl CP850"
|
|
||||||
echo "nl_BE CP850"
|
|
||||||
echo "nl_NL CP850"
|
|
||||||
echo "nn CP865" # not CP850 ??
|
|
||||||
echo "nn_NO CP865" # not CP850 ??
|
|
||||||
echo "no CP865" # not CP850 ??
|
|
||||||
echo "no_NO CP865" # not CP850 ??
|
|
||||||
echo "pt CP850"
|
|
||||||
echo "pt_BR CP850"
|
|
||||||
echo "pt_PT CP850"
|
|
||||||
echo "sv CP850"
|
|
||||||
echo "sv_SE CP850"
|
|
||||||
# ISO-8859-2 languages
|
|
||||||
echo "cs CP852"
|
|
||||||
echo "cs_CZ CP852"
|
|
||||||
echo "hr CP852"
|
|
||||||
echo "hr_HR CP852"
|
|
||||||
echo "hu CP852"
|
|
||||||
echo "hu_HU CP852"
|
|
||||||
echo "pl CP852"
|
|
||||||
echo "pl_PL CP852"
|
|
||||||
echo "ro CP852"
|
|
||||||
echo "ro_RO CP852"
|
|
||||||
echo "sk CP852"
|
|
||||||
echo "sk_SK CP852"
|
|
||||||
echo "sl CP852"
|
|
||||||
echo "sl_SI CP852"
|
|
||||||
echo "sq CP852"
|
|
||||||
echo "sq_AL CP852"
|
|
||||||
echo "sr CP852" # CP852 or CP866 or CP855 ??
|
|
||||||
echo "sr_CS CP852" # CP852 or CP866 or CP855 ??
|
|
||||||
echo "sr_YU CP852" # CP852 or CP866 or CP855 ??
|
|
||||||
# ISO-8859-3 languages
|
|
||||||
echo "mt CP850"
|
|
||||||
echo "mt_MT CP850"
|
|
||||||
# ISO-8859-5 languages
|
|
||||||
echo "be CP866"
|
|
||||||
echo "be_BE CP866"
|
|
||||||
echo "bg CP866" # not CP855 ??
|
|
||||||
echo "bg_BG CP866" # not CP855 ??
|
|
||||||
echo "mk CP866" # not CP855 ??
|
|
||||||
echo "mk_MK CP866" # not CP855 ??
|
|
||||||
echo "ru CP866"
|
|
||||||
echo "ru_RU CP866"
|
|
||||||
echo "uk CP1125"
|
|
||||||
echo "uk_UA CP1125"
|
|
||||||
# ISO-8859-6 languages
|
|
||||||
echo "ar CP864"
|
|
||||||
echo "ar_AE CP864"
|
|
||||||
echo "ar_DZ CP864"
|
|
||||||
echo "ar_EG CP864"
|
|
||||||
echo "ar_IQ CP864"
|
|
||||||
echo "ar_IR CP864"
|
|
||||||
echo "ar_JO CP864"
|
|
||||||
echo "ar_KW CP864"
|
|
||||||
echo "ar_MA CP864"
|
|
||||||
echo "ar_OM CP864"
|
|
||||||
echo "ar_QA CP864"
|
|
||||||
echo "ar_SA CP864"
|
|
||||||
echo "ar_SY CP864"
|
|
||||||
# ISO-8859-7 languages
|
|
||||||
echo "el CP869"
|
|
||||||
echo "el_GR CP869"
|
|
||||||
# ISO-8859-8 languages
|
|
||||||
echo "he CP862"
|
|
||||||
echo "he_IL CP862"
|
|
||||||
# ISO-8859-9 languages
|
|
||||||
echo "tr CP857"
|
|
||||||
echo "tr_TR CP857"
|
|
||||||
# Japanese
|
|
||||||
echo "ja CP932"
|
|
||||||
echo "ja_JP CP932"
|
|
||||||
# Chinese
|
|
||||||
echo "zh_CN GBK"
|
|
||||||
echo "zh_TW CP950" # not CP938 ??
|
|
||||||
# Korean
|
|
||||||
echo "kr CP949" # not CP934 ??
|
|
||||||
echo "kr_KR CP949" # not CP934 ??
|
|
||||||
# Thai
|
|
||||||
echo "th CP874"
|
|
||||||
echo "th_TH CP874"
|
|
||||||
# Other
|
|
||||||
echo "eo CP850"
|
|
||||||
echo "eo_EO CP850"
|
|
||||||
;;
|
|
||||||
esac
|
|
|
@ -1,56 +0,0 @@
|
||||||
/* Implementation of the dcgettext(3) function.
|
|
||||||
Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* Names for the libintl functions are a problem. They must not clash
|
|
||||||
with existing names and they should follow ANSI C. But this source
|
|
||||||
code is also used in GNU C Library where the names have a __
|
|
||||||
prefix. So we have to make a difference here. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define DCGETTEXT __dcgettext
|
|
||||||
# define DCIGETTEXT __dcigettext
|
|
||||||
#else
|
|
||||||
# define DCGETTEXT libintl_dcgettext
|
|
||||||
# define DCIGETTEXT libintl_dcigettext
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
|
|
||||||
locale. */
|
|
||||||
char *
|
|
||||||
DCGETTEXT (const char *domainname, const char *msgid, int category)
|
|
||||||
{
|
|
||||||
return DCIGETTEXT (domainname, msgid, NULL, 0, 0, category);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Alias for function name in GNU C Library. */
|
|
||||||
INTDEF(__dcgettext)
|
|
||||||
weak_alias (__dcgettext, dcgettext);
|
|
||||||
#endif
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,57 +0,0 @@
|
||||||
/* Implementation of the dcngettext(3) function.
|
|
||||||
Copyright (C) 1995-1999, 2000-2003 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* Names for the libintl functions are a problem. They must not clash
|
|
||||||
with existing names and they should follow ANSI C. But this source
|
|
||||||
code is also used in GNU C Library where the names have a __
|
|
||||||
prefix. So we have to make a difference here. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define DCNGETTEXT __dcngettext
|
|
||||||
# define DCIGETTEXT __dcigettext
|
|
||||||
#else
|
|
||||||
# define DCNGETTEXT libintl_dcngettext
|
|
||||||
# define DCIGETTEXT libintl_dcigettext
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
|
|
||||||
locale. */
|
|
||||||
char *
|
|
||||||
DCNGETTEXT (const char *domainname,
|
|
||||||
const char *msgid1, const char *msgid2, unsigned long int n,
|
|
||||||
int category)
|
|
||||||
{
|
|
||||||
return DCIGETTEXT (domainname, msgid1, msgid2, 1, n, category);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Alias for function name in GNU C Library. */
|
|
||||||
weak_alias (__dcngettext, dcngettext);
|
|
||||||
#endif
|
|
|
@ -1,58 +0,0 @@
|
||||||
/* Implementation of the dgettext(3) function.
|
|
||||||
Copyright (C) 1995-1997, 2000-2003 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
|
|
||||||
#include <locale.h>
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* Names for the libintl functions are a problem. They must not clash
|
|
||||||
with existing names and they should follow ANSI C. But this source
|
|
||||||
code is also used in GNU C Library where the names have a __
|
|
||||||
prefix. So we have to make a difference here. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define DGETTEXT __dgettext
|
|
||||||
# define DCGETTEXT INTUSE(__dcgettext)
|
|
||||||
#else
|
|
||||||
# define DGETTEXT libintl_dgettext
|
|
||||||
# define DCGETTEXT libintl_dcgettext
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the DOMAINNAME message catalog of the current
|
|
||||||
LC_MESSAGES locale. */
|
|
||||||
char *
|
|
||||||
DGETTEXT (const char *domainname, const char *msgid)
|
|
||||||
{
|
|
||||||
return DCGETTEXT (domainname, msgid, LC_MESSAGES);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Alias for function name in GNU C Library. */
|
|
||||||
weak_alias (__dgettext, dgettext);
|
|
||||||
#endif
|
|
|
@ -1,59 +0,0 @@
|
||||||
/* Implementation of the dngettext(3) function.
|
|
||||||
Copyright (C) 1995-1997, 2000-2003 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
|
|
||||||
#include <locale.h>
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* Names for the libintl functions are a problem. They must not clash
|
|
||||||
with existing names and they should follow ANSI C. But this source
|
|
||||||
code is also used in GNU C Library where the names have a __
|
|
||||||
prefix. So we have to make a difference here. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define DNGETTEXT __dngettext
|
|
||||||
# define DCNGETTEXT __dcngettext
|
|
||||||
#else
|
|
||||||
# define DNGETTEXT libintl_dngettext
|
|
||||||
# define DCNGETTEXT libintl_dcngettext
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the DOMAINNAME message catalog of the current
|
|
||||||
LC_MESSAGES locale and skip message according to the plural form. */
|
|
||||||
char *
|
|
||||||
DNGETTEXT (const char *domainname,
|
|
||||||
const char *msgid1, const char *msgid2, unsigned long int n)
|
|
||||||
{
|
|
||||||
return DCNGETTEXT (domainname, msgid1, msgid2, n, LC_MESSAGES);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Alias for function name in GNU C Library. */
|
|
||||||
weak_alias (__dngettext, dngettext);
|
|
||||||
#endif
|
|
|
@ -1,108 +0,0 @@
|
||||||
/* Plural expression evaluation.
|
|
||||||
Copyright (C) 2000-2003, 2007 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifndef STATIC
|
|
||||||
#define STATIC static
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Evaluate the plural expression and return an index value. */
|
|
||||||
STATIC
|
|
||||||
unsigned long int
|
|
||||||
internal_function
|
|
||||||
plural_eval (const struct expression *pexp, unsigned long int n)
|
|
||||||
{
|
|
||||||
switch (pexp->nargs)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
switch (pexp->operation)
|
|
||||||
{
|
|
||||||
case var:
|
|
||||||
return n;
|
|
||||||
case num:
|
|
||||||
return pexp->val.num;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
/* NOTREACHED */
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
{
|
|
||||||
/* pexp->operation must be lnot. */
|
|
||||||
unsigned long int arg = plural_eval (pexp->val.args[0], n);
|
|
||||||
return ! arg;
|
|
||||||
}
|
|
||||||
case 2:
|
|
||||||
{
|
|
||||||
unsigned long int leftarg = plural_eval (pexp->val.args[0], n);
|
|
||||||
if (pexp->operation == lor)
|
|
||||||
return leftarg || plural_eval (pexp->val.args[1], n);
|
|
||||||
else if (pexp->operation == land)
|
|
||||||
return leftarg && plural_eval (pexp->val.args[1], n);
|
|
||||||
else
|
|
||||||
{
|
|
||||||
unsigned long int rightarg = plural_eval (pexp->val.args[1], n);
|
|
||||||
|
|
||||||
switch (pexp->operation)
|
|
||||||
{
|
|
||||||
case mult:
|
|
||||||
return leftarg * rightarg;
|
|
||||||
case divide:
|
|
||||||
#if !INTDIV0_RAISES_SIGFPE
|
|
||||||
if (rightarg == 0)
|
|
||||||
raise (SIGFPE);
|
|
||||||
#endif
|
|
||||||
return leftarg / rightarg;
|
|
||||||
case module:
|
|
||||||
#if !INTDIV0_RAISES_SIGFPE
|
|
||||||
if (rightarg == 0)
|
|
||||||
raise (SIGFPE);
|
|
||||||
#endif
|
|
||||||
return leftarg % rightarg;
|
|
||||||
case plus:
|
|
||||||
return leftarg + rightarg;
|
|
||||||
case minus:
|
|
||||||
return leftarg - rightarg;
|
|
||||||
case less_than:
|
|
||||||
return leftarg < rightarg;
|
|
||||||
case greater_than:
|
|
||||||
return leftarg > rightarg;
|
|
||||||
case less_or_equal:
|
|
||||||
return leftarg <= rightarg;
|
|
||||||
case greater_or_equal:
|
|
||||||
return leftarg >= rightarg;
|
|
||||||
case equal:
|
|
||||||
return leftarg == rightarg;
|
|
||||||
case not_equal:
|
|
||||||
return leftarg != rightarg;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* NOTREACHED */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 3:
|
|
||||||
{
|
|
||||||
/* pexp->operation must be qmop. */
|
|
||||||
unsigned long int boolarg = plural_eval (pexp->val.args[0], n);
|
|
||||||
return plural_eval (pexp->val.args[boolarg ? 1 : 2], n);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* NOTREACHED */
|
|
||||||
return 0;
|
|
||||||
}
|
|
|
@ -1,135 +0,0 @@
|
||||||
/* Copyright (C) 1995-1998, 2000-2001, 2003, 2005, 2007 Free Software Foundation, Inc.
|
|
||||||
Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
|
|
||||||
#include "loadinfo.h"
|
|
||||||
|
|
||||||
/* On some strange systems still no definition of NULL is found. Sigh! */
|
|
||||||
#ifndef NULL
|
|
||||||
# if defined __STDC__ && __STDC__
|
|
||||||
# define NULL ((void *) 0)
|
|
||||||
# else
|
|
||||||
# define NULL 0
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* Split a locale name NAME into a leading language part and all the
|
|
||||||
rest. Return a pointer to the first character after the language,
|
|
||||||
i.e. to the first byte of the rest. */
|
|
||||||
static char *_nl_find_language (const char *name);
|
|
||||||
|
|
||||||
static char *
|
|
||||||
_nl_find_language (const char *name)
|
|
||||||
{
|
|
||||||
while (name[0] != '\0' && name[0] != '_' && name[0] != '@' && name[0] != '.')
|
|
||||||
++name;
|
|
||||||
|
|
||||||
return (char *) name;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int
|
|
||||||
_nl_explode_name (char *name,
|
|
||||||
const char **language, const char **modifier,
|
|
||||||
const char **territory, const char **codeset,
|
|
||||||
const char **normalized_codeset)
|
|
||||||
{
|
|
||||||
char *cp;
|
|
||||||
int mask;
|
|
||||||
|
|
||||||
*modifier = NULL;
|
|
||||||
*territory = NULL;
|
|
||||||
*codeset = NULL;
|
|
||||||
*normalized_codeset = NULL;
|
|
||||||
|
|
||||||
/* Now we determine the single parts of the locale name. First
|
|
||||||
look for the language. Termination symbols are `_', '.', and `@'. */
|
|
||||||
mask = 0;
|
|
||||||
*language = cp = name;
|
|
||||||
cp = _nl_find_language (*language);
|
|
||||||
|
|
||||||
if (*language == cp)
|
|
||||||
/* This does not make sense: language has to be specified. Use
|
|
||||||
this entry as it is without exploding. Perhaps it is an alias. */
|
|
||||||
cp = strchr (*language, '\0');
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (cp[0] == '_')
|
|
||||||
{
|
|
||||||
/* Next is the territory. */
|
|
||||||
cp[0] = '\0';
|
|
||||||
*territory = ++cp;
|
|
||||||
|
|
||||||
while (cp[0] != '\0' && cp[0] != '.' && cp[0] != '@')
|
|
||||||
++cp;
|
|
||||||
|
|
||||||
mask |= XPG_TERRITORY;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cp[0] == '.')
|
|
||||||
{
|
|
||||||
/* Next is the codeset. */
|
|
||||||
cp[0] = '\0';
|
|
||||||
*codeset = ++cp;
|
|
||||||
|
|
||||||
while (cp[0] != '\0' && cp[0] != '@')
|
|
||||||
++cp;
|
|
||||||
|
|
||||||
mask |= XPG_CODESET;
|
|
||||||
|
|
||||||
if (*codeset != cp && (*codeset)[0] != '\0')
|
|
||||||
{
|
|
||||||
*normalized_codeset = _nl_normalize_codeset (*codeset,
|
|
||||||
cp - *codeset);
|
|
||||||
if (*normalized_codeset == NULL)
|
|
||||||
return -1;
|
|
||||||
else if (strcmp (*codeset, *normalized_codeset) == 0)
|
|
||||||
free ((char *) *normalized_codeset);
|
|
||||||
else
|
|
||||||
mask |= XPG_NORM_CODESET;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cp[0] == '@')
|
|
||||||
{
|
|
||||||
/* Next is the modifier. */
|
|
||||||
cp[0] = '\0';
|
|
||||||
*modifier = ++cp;
|
|
||||||
|
|
||||||
if (cp[0] != '\0')
|
|
||||||
mask |= XPG_MODIFIER;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (*territory != NULL && (*territory)[0] == '\0')
|
|
||||||
mask &= ~XPG_TERRITORY;
|
|
||||||
|
|
||||||
if (*codeset != NULL && (*codeset)[0] == '\0')
|
|
||||||
mask &= ~XPG_CODESET;
|
|
||||||
|
|
||||||
return mask;
|
|
||||||
}
|
|
|
@ -1,6 +0,0 @@
|
||||||
|
|
||||||
#if @HAVE_VISIBILITY@ && BUILDING_LIBINTL
|
|
||||||
#define LIBINTL_DLL_EXPORTED __attribute__((__visibility__("default")))
|
|
||||||
#else
|
|
||||||
#define LIBINTL_DLL_EXPORTED
|
|
||||||
#endif
|
|
|
@ -1,212 +0,0 @@
|
||||||
/* Handle list of needed message catalogs
|
|
||||||
Copyright (C) 1995-1999, 2000-2001, 2003-2007 Free Software Foundation, Inc.
|
|
||||||
Written by Ulrich Drepper <drepper@gnu.org>, 1995.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#if defined HAVE_UNISTD_H || defined _LIBC
|
|
||||||
# include <unistd.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Handle multi-threaded applications. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <bits/libc-lock.h>
|
|
||||||
# define gl_rwlock_define_initialized __libc_rwlock_define_initialized
|
|
||||||
# define gl_rwlock_rdlock __libc_rwlock_rdlock
|
|
||||||
# define gl_rwlock_wrlock __libc_rwlock_wrlock
|
|
||||||
# define gl_rwlock_unlock __libc_rwlock_unlock
|
|
||||||
#else
|
|
||||||
# include "lock.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
/* List of already loaded domains. */
|
|
||||||
static struct loaded_l10nfile *_nl_loaded_domains;
|
|
||||||
|
|
||||||
|
|
||||||
/* Return a data structure describing the message catalog described by
|
|
||||||
the DOMAINNAME and CATEGORY parameters with respect to the currently
|
|
||||||
established bindings. */
|
|
||||||
struct loaded_l10nfile *
|
|
||||||
internal_function
|
|
||||||
_nl_find_domain (const char *dirname, char *locale,
|
|
||||||
const char *domainname, struct binding *domainbinding)
|
|
||||||
{
|
|
||||||
struct loaded_l10nfile *retval;
|
|
||||||
const char *language;
|
|
||||||
const char *modifier;
|
|
||||||
const char *territory;
|
|
||||||
const char *codeset;
|
|
||||||
const char *normalized_codeset;
|
|
||||||
const char *alias_value;
|
|
||||||
int mask;
|
|
||||||
|
|
||||||
/* LOCALE can consist of up to four recognized parts for the XPG syntax:
|
|
||||||
|
|
||||||
language[_territory][.codeset][@modifier]
|
|
||||||
|
|
||||||
Beside the first part all of them are allowed to be missing. If
|
|
||||||
the full specified locale is not found, the less specific one are
|
|
||||||
looked for. The various parts will be stripped off according to
|
|
||||||
the following order:
|
|
||||||
(1) codeset
|
|
||||||
(2) normalized codeset
|
|
||||||
(3) territory
|
|
||||||
(4) modifier
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* We need to protect modifying the _NL_LOADED_DOMAINS data. */
|
|
||||||
gl_rwlock_define_initialized (static, lock);
|
|
||||||
gl_rwlock_rdlock (lock);
|
|
||||||
|
|
||||||
/* If we have already tested for this locale entry there has to
|
|
||||||
be one data set in the list of loaded domains. */
|
|
||||||
retval = _nl_make_l10nflist (&_nl_loaded_domains, dirname,
|
|
||||||
strlen (dirname) + 1, 0, locale, NULL, NULL,
|
|
||||||
NULL, NULL, domainname, 0);
|
|
||||||
|
|
||||||
gl_rwlock_unlock (lock);
|
|
||||||
|
|
||||||
if (retval != NULL)
|
|
||||||
{
|
|
||||||
/* We know something about this locale. */
|
|
||||||
int cnt;
|
|
||||||
|
|
||||||
if (retval->decided <= 0)
|
|
||||||
_nl_load_domain (retval, domainbinding);
|
|
||||||
|
|
||||||
if (retval->data != NULL)
|
|
||||||
return retval;
|
|
||||||
|
|
||||||
for (cnt = 0; retval->successor[cnt] != NULL; ++cnt)
|
|
||||||
{
|
|
||||||
if (retval->successor[cnt]->decided <= 0)
|
|
||||||
_nl_load_domain (retval->successor[cnt], domainbinding);
|
|
||||||
|
|
||||||
if (retval->successor[cnt]->data != NULL)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return retval;
|
|
||||||
/* NOTREACHED */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* See whether the locale value is an alias. If yes its value
|
|
||||||
*overwrites* the alias name. No test for the original value is
|
|
||||||
done. */
|
|
||||||
alias_value = _nl_expand_alias (locale);
|
|
||||||
if (alias_value != NULL)
|
|
||||||
{
|
|
||||||
#if defined _LIBC || defined HAVE_STRDUP
|
|
||||||
locale = strdup (alias_value);
|
|
||||||
if (locale == NULL)
|
|
||||||
return NULL;
|
|
||||||
#else
|
|
||||||
size_t len = strlen (alias_value) + 1;
|
|
||||||
locale = (char *) malloc (len);
|
|
||||||
if (locale == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
memcpy (locale, alias_value, len);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Now we determine the single parts of the locale name. First
|
|
||||||
look for the language. Termination symbols are `_', '.', and `@'. */
|
|
||||||
mask = _nl_explode_name (locale, &language, &modifier, &territory,
|
|
||||||
&codeset, &normalized_codeset);
|
|
||||||
if (mask == -1)
|
|
||||||
/* This means we are out of core. */
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
/* We need to protect modifying the _NL_LOADED_DOMAINS data. */
|
|
||||||
gl_rwlock_wrlock (lock);
|
|
||||||
|
|
||||||
/* Create all possible locale entries which might be interested in
|
|
||||||
generalization. */
|
|
||||||
retval = _nl_make_l10nflist (&_nl_loaded_domains, dirname,
|
|
||||||
strlen (dirname) + 1, mask, language, territory,
|
|
||||||
codeset, normalized_codeset, modifier,
|
|
||||||
domainname, 1);
|
|
||||||
|
|
||||||
gl_rwlock_unlock (lock);
|
|
||||||
|
|
||||||
if (retval == NULL)
|
|
||||||
/* This means we are out of core. */
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
if (retval->decided <= 0)
|
|
||||||
_nl_load_domain (retval, domainbinding);
|
|
||||||
if (retval->data == NULL)
|
|
||||||
{
|
|
||||||
int cnt;
|
|
||||||
for (cnt = 0; retval->successor[cnt] != NULL; ++cnt)
|
|
||||||
{
|
|
||||||
if (retval->successor[cnt]->decided <= 0)
|
|
||||||
_nl_load_domain (retval->successor[cnt], domainbinding);
|
|
||||||
if (retval->successor[cnt]->data != NULL)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The room for an alias was dynamically allocated. Free it now. */
|
|
||||||
if (alias_value != NULL)
|
|
||||||
free (locale);
|
|
||||||
|
|
||||||
out:
|
|
||||||
/* The space for normalized_codeset is dynamically allocated. Free it. */
|
|
||||||
if (mask & XPG_NORM_CODESET)
|
|
||||||
free ((void *) normalized_codeset);
|
|
||||||
|
|
||||||
return retval;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* This is called from iconv/gconv_db.c's free_mem, as locales must
|
|
||||||
be freed before freeing gconv steps arrays. */
|
|
||||||
void __libc_freeres_fn_section
|
|
||||||
_nl_finddomain_subfreeres ()
|
|
||||||
{
|
|
||||||
struct loaded_l10nfile *runp = _nl_loaded_domains;
|
|
||||||
|
|
||||||
while (runp != NULL)
|
|
||||||
{
|
|
||||||
struct loaded_l10nfile *here = runp;
|
|
||||||
if (runp->data != NULL)
|
|
||||||
_nl_unload_domain ((struct loaded_domain *) runp->data);
|
|
||||||
runp = runp->next;
|
|
||||||
free ((char *) here->filename);
|
|
||||||
free (here);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
|
@ -1,63 +0,0 @@
|
||||||
/* Implementation of gettext(3) function.
|
|
||||||
Copyright (C) 1995, 1997, 2000-2003 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define __need_NULL
|
|
||||||
# include <stddef.h>
|
|
||||||
#else
|
|
||||||
# include <stdlib.h> /* Just for NULL. */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <libintl.h>
|
|
||||||
#else
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* Names for the libintl functions are a problem. They must not clash
|
|
||||||
with existing names and they should follow ANSI C. But this source
|
|
||||||
code is also used in GNU C Library where the names have a __
|
|
||||||
prefix. So we have to make a difference here. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define GETTEXT __gettext
|
|
||||||
# define DCGETTEXT INTUSE(__dcgettext)
|
|
||||||
#else
|
|
||||||
# define GETTEXT libintl_gettext
|
|
||||||
# define DCGETTEXT libintl_dcgettext
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the current default message catalog for the current
|
|
||||||
LC_MESSAGES locale. If not found, returns MSGID itself (the default
|
|
||||||
text). */
|
|
||||||
char *
|
|
||||||
GETTEXT (const char *msgid)
|
|
||||||
{
|
|
||||||
return DCGETTEXT (NULL, msgid, LC_MESSAGES);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Alias for function name in GNU C Library. */
|
|
||||||
weak_alias (__gettext, gettext);
|
|
||||||
#endif
|
|
|
@ -1,297 +0,0 @@
|
||||||
/* Header describing internals of libintl library.
|
|
||||||
Copyright (C) 1995-1999, 2000-2007 Free Software Foundation, Inc.
|
|
||||||
Written by Ulrich Drepper <drepper@cygnus.com>, 1995.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifndef _GETTEXTP_H
|
|
||||||
#define _GETTEXTP_H
|
|
||||||
|
|
||||||
#include <stddef.h> /* Get size_t. */
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include "../iconv/gconv_int.h"
|
|
||||||
#else
|
|
||||||
# if HAVE_ICONV
|
|
||||||
# include <iconv.h>
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Handle multi-threaded applications. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <bits/libc-lock.h>
|
|
||||||
# define gl_rwlock_define __libc_rwlock_define
|
|
||||||
#else
|
|
||||||
# include "lock.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
extern char *__gettext (const char *__msgid);
|
|
||||||
extern char *__dgettext (const char *__domainname, const char *__msgid);
|
|
||||||
extern char *__dcgettext (const char *__domainname, const char *__msgid,
|
|
||||||
int __category);
|
|
||||||
extern char *__ngettext (const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n);
|
|
||||||
extern char *__dngettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int n);
|
|
||||||
extern char *__dcngettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n, int __category);
|
|
||||||
extern char *__dcigettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
int __plural, unsigned long int __n,
|
|
||||||
int __category);
|
|
||||||
extern char *__textdomain (const char *__domainname);
|
|
||||||
extern char *__bindtextdomain (const char *__domainname,
|
|
||||||
const char *__dirname);
|
|
||||||
extern char *__bind_textdomain_codeset (const char *__domainname,
|
|
||||||
const char *__codeset);
|
|
||||||
extern void _nl_finddomain_subfreeres (void) attribute_hidden;
|
|
||||||
extern void _nl_unload_domain (struct loaded_domain *__domain)
|
|
||||||
internal_function attribute_hidden;
|
|
||||||
#else
|
|
||||||
/* Declare the exported libintl_* functions, in a way that allows us to
|
|
||||||
call them under their real name. */
|
|
||||||
# undef _INTL_REDIRECT_INLINE
|
|
||||||
# undef _INTL_REDIRECT_MACROS
|
|
||||||
# define _INTL_REDIRECT_MACROS
|
|
||||||
# include "libgnuintl.h"
|
|
||||||
# ifdef IN_LIBGLOCALE
|
|
||||||
extern char *gl_dcigettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
int __plural, unsigned long int __n,
|
|
||||||
int __category,
|
|
||||||
const char *__localename, const char *__encoding);
|
|
||||||
# else
|
|
||||||
extern char *libintl_dcigettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
int __plural, unsigned long int __n,
|
|
||||||
int __category);
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "loadinfo.h"
|
|
||||||
|
|
||||||
#include "gmo.h" /* Get nls_uint32. */
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
#ifndef internal_function
|
|
||||||
# define internal_function
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef attribute_hidden
|
|
||||||
# define attribute_hidden
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Tell the compiler when a conditional or integer expression is
|
|
||||||
almost always true or almost always false. */
|
|
||||||
#ifndef HAVE_BUILTIN_EXPECT
|
|
||||||
# define __builtin_expect(expr, val) (expr)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef W
|
|
||||||
# define W(flag, data) ((flag) ? SWAP (data) : (data))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <byteswap.h>
|
|
||||||
# define SWAP(i) bswap_32 (i)
|
|
||||||
#else
|
|
||||||
static inline nls_uint32
|
|
||||||
# ifdef __cplusplus
|
|
||||||
SWAP (nls_uint32 i)
|
|
||||||
# else
|
|
||||||
SWAP (i)
|
|
||||||
nls_uint32 i;
|
|
||||||
# endif
|
|
||||||
{
|
|
||||||
return (i << 24) | ((i & 0xff00) << 8) | ((i >> 8) & 0xff00) | (i >> 24);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* In-memory representation of system dependent string. */
|
|
||||||
struct sysdep_string_desc
|
|
||||||
{
|
|
||||||
/* Length of addressed string, including the trailing NUL. */
|
|
||||||
size_t length;
|
|
||||||
/* Pointer to addressed string. */
|
|
||||||
const char *pointer;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Cache of translated strings after charset conversion.
|
|
||||||
Note: The strings are converted to the target encoding only on an as-needed
|
|
||||||
basis. */
|
|
||||||
struct converted_domain
|
|
||||||
{
|
|
||||||
/* The target encoding name. */
|
|
||||||
const char *encoding;
|
|
||||||
/* The descriptor for conversion from the message catalog's encoding to
|
|
||||||
this target encoding. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
__gconv_t conv;
|
|
||||||
#else
|
|
||||||
# if HAVE_ICONV
|
|
||||||
iconv_t conv;
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
/* The table of translated strings after charset conversion. */
|
|
||||||
char **conv_tab;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* The representation of an opened message catalog. */
|
|
||||||
struct loaded_domain
|
|
||||||
{
|
|
||||||
/* Pointer to memory containing the .mo file. */
|
|
||||||
const char *data;
|
|
||||||
/* 1 if the memory is mmap()ed, 0 if the memory is malloc()ed. */
|
|
||||||
int use_mmap;
|
|
||||||
/* Size of mmap()ed memory. */
|
|
||||||
size_t mmap_size;
|
|
||||||
/* 1 if the .mo file uses a different endianness than this machine. */
|
|
||||||
int must_swap;
|
|
||||||
/* Pointer to additional malloc()ed memory. */
|
|
||||||
void *malloced;
|
|
||||||
|
|
||||||
/* Number of static strings pairs. */
|
|
||||||
nls_uint32 nstrings;
|
|
||||||
/* Pointer to descriptors of original strings in the file. */
|
|
||||||
const struct string_desc *orig_tab;
|
|
||||||
/* Pointer to descriptors of translated strings in the file. */
|
|
||||||
const struct string_desc *trans_tab;
|
|
||||||
|
|
||||||
/* Number of system dependent strings pairs. */
|
|
||||||
nls_uint32 n_sysdep_strings;
|
|
||||||
/* Pointer to descriptors of original sysdep strings. */
|
|
||||||
const struct sysdep_string_desc *orig_sysdep_tab;
|
|
||||||
/* Pointer to descriptors of translated sysdep strings. */
|
|
||||||
const struct sysdep_string_desc *trans_sysdep_tab;
|
|
||||||
|
|
||||||
/* Size of hash table. */
|
|
||||||
nls_uint32 hash_size;
|
|
||||||
/* Pointer to hash table. */
|
|
||||||
const nls_uint32 *hash_tab;
|
|
||||||
/* 1 if the hash table uses a different endianness than this machine. */
|
|
||||||
int must_swap_hash_tab;
|
|
||||||
|
|
||||||
/* Cache of charset conversions of the translated strings. */
|
|
||||||
struct converted_domain *conversions;
|
|
||||||
size_t nconversions;
|
|
||||||
gl_rwlock_define (, conversions_lock)
|
|
||||||
|
|
||||||
const struct expression *plural;
|
|
||||||
unsigned long int nplurals;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* We want to allocate a string at the end of the struct. But ISO C
|
|
||||||
doesn't allow zero sized arrays. */
|
|
||||||
#ifdef __GNUC__
|
|
||||||
# define ZERO 0
|
|
||||||
#else
|
|
||||||
# define ZERO 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* A set of settings bound to a message domain. Used to store settings
|
|
||||||
from bindtextdomain() and bind_textdomain_codeset(). */
|
|
||||||
struct binding
|
|
||||||
{
|
|
||||||
struct binding *next;
|
|
||||||
char *dirname;
|
|
||||||
char *codeset;
|
|
||||||
char domainname[ZERO];
|
|
||||||
};
|
|
||||||
|
|
||||||
/* A counter which is incremented each time some previous translations
|
|
||||||
become invalid.
|
|
||||||
This variable is part of the external ABI of the GNU libintl. */
|
|
||||||
#ifdef IN_LIBGLOCALE
|
|
||||||
# include <glocale/config.h>
|
|
||||||
extern LIBGLOCALE_DLL_EXPORTED int _nl_msg_cat_cntr;
|
|
||||||
#else
|
|
||||||
extern LIBINTL_DLL_EXPORTED int _nl_msg_cat_cntr;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef _LIBC
|
|
||||||
extern const char *_nl_language_preferences_default (void);
|
|
||||||
# define gl_locale_name_canonicalize _nl_locale_name_canonicalize
|
|
||||||
extern void _nl_locale_name_canonicalize (char *name);
|
|
||||||
# define gl_locale_name_posix _nl_locale_name_posix
|
|
||||||
extern const char *_nl_locale_name_posix (int category,
|
|
||||||
const char *categoryname);
|
|
||||||
# define gl_locale_name_default _nl_locale_name_default
|
|
||||||
extern const char *_nl_locale_name_default (void);
|
|
||||||
# define gl_locale_name _nl_locale_name
|
|
||||||
extern const char *_nl_locale_name (int category, const char *categoryname);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct loaded_l10nfile *_nl_find_domain (const char *__dirname, char *__locale,
|
|
||||||
const char *__domainname,
|
|
||||||
struct binding *__domainbinding)
|
|
||||||
internal_function;
|
|
||||||
void _nl_load_domain (struct loaded_l10nfile *__domain,
|
|
||||||
struct binding *__domainbinding)
|
|
||||||
internal_function;
|
|
||||||
|
|
||||||
#ifdef IN_LIBGLOCALE
|
|
||||||
char *_nl_find_msg (struct loaded_l10nfile *domain_file,
|
|
||||||
struct binding *domainbinding, const char *encoding,
|
|
||||||
const char *msgid,
|
|
||||||
size_t *lengthp)
|
|
||||||
internal_function;
|
|
||||||
#else
|
|
||||||
char *_nl_find_msg (struct loaded_l10nfile *domain_file,
|
|
||||||
struct binding *domainbinding, const char *msgid,
|
|
||||||
int convert, size_t *lengthp)
|
|
||||||
internal_function;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* The internal variables in the standalone libintl.a must have different
|
|
||||||
names than the internal variables in GNU libc, otherwise programs
|
|
||||||
using libintl.a cannot be linked statically. */
|
|
||||||
#if !defined _LIBC
|
|
||||||
# define _nl_default_dirname libintl_nl_default_dirname
|
|
||||||
# define _nl_domain_bindings libintl_nl_domain_bindings
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Contains the default location of the message catalogs. */
|
|
||||||
extern const char _nl_default_dirname[];
|
|
||||||
#ifdef _LIBC
|
|
||||||
libc_hidden_proto (_nl_default_dirname)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* List with bindings of specific domains. */
|
|
||||||
extern struct binding *_nl_domain_bindings;
|
|
||||||
|
|
||||||
/* The internal variables in the standalone libintl.a must have different
|
|
||||||
names than the internal variables in GNU libc, otherwise programs
|
|
||||||
using libintl.a cannot be linked statically. */
|
|
||||||
#if !defined _LIBC
|
|
||||||
# define _nl_default_default_domain libintl_nl_default_default_domain
|
|
||||||
# define _nl_current_default_domain libintl_nl_current_default_domain
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Name of the default text domain. */
|
|
||||||
extern const char _nl_default_default_domain[] attribute_hidden;
|
|
||||||
|
|
||||||
/* Default text domain in which entries for gettext(3) are to be found. */
|
|
||||||
extern const char *_nl_current_default_domain attribute_hidden;
|
|
||||||
|
|
||||||
/* @@ begin of epilog @@ */
|
|
||||||
|
|
||||||
#endif /* gettextP.h */
|
|
|
@ -1,152 +0,0 @@
|
||||||
/* Description of GNU message catalog format: general file layout.
|
|
||||||
Copyright (C) 1995, 1997, 2000-2002, 2004, 2006 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifndef _GETTEXT_H
|
|
||||||
#define _GETTEXT_H 1
|
|
||||||
|
|
||||||
#include <limits.h>
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* The magic number of the GNU message catalog format. */
|
|
||||||
#define _MAGIC 0x950412de
|
|
||||||
#define _MAGIC_SWAPPED 0xde120495
|
|
||||||
|
|
||||||
/* Revision number of the currently used .mo (binary) file format. */
|
|
||||||
#define MO_REVISION_NUMBER 0
|
|
||||||
#define MO_REVISION_NUMBER_WITH_SYSDEP_I 1
|
|
||||||
|
|
||||||
/* The following contortions are an attempt to use the C preprocessor
|
|
||||||
to determine an unsigned integral type that is 32 bits wide. An
|
|
||||||
alternative approach is to use autoconf's AC_CHECK_SIZEOF macro, but
|
|
||||||
as of version autoconf-2.13, the AC_CHECK_SIZEOF macro doesn't work
|
|
||||||
when cross-compiling. */
|
|
||||||
|
|
||||||
#if __STDC__
|
|
||||||
# define UINT_MAX_32_BITS 4294967295U
|
|
||||||
#else
|
|
||||||
# define UINT_MAX_32_BITS 0xFFFFFFFF
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* If UINT_MAX isn't defined, assume it's a 32-bit type.
|
|
||||||
This should be valid for all systems GNU cares about because
|
|
||||||
that doesn't include 16-bit systems, and only modern systems
|
|
||||||
(that certainly have <limits.h>) have 64+-bit integral types. */
|
|
||||||
|
|
||||||
#ifndef UINT_MAX
|
|
||||||
# define UINT_MAX UINT_MAX_32_BITS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if UINT_MAX == UINT_MAX_32_BITS
|
|
||||||
typedef unsigned nls_uint32;
|
|
||||||
#else
|
|
||||||
# if USHRT_MAX == UINT_MAX_32_BITS
|
|
||||||
typedef unsigned short nls_uint32;
|
|
||||||
# else
|
|
||||||
# if ULONG_MAX == UINT_MAX_32_BITS
|
|
||||||
typedef unsigned long nls_uint32;
|
|
||||||
# else
|
|
||||||
/* The following line is intended to throw an error. Using #error is
|
|
||||||
not portable enough. */
|
|
||||||
"Cannot determine unsigned 32-bit data type."
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Header for binary .mo file format. */
|
|
||||||
struct mo_file_header
|
|
||||||
{
|
|
||||||
/* The magic number. */
|
|
||||||
nls_uint32 magic;
|
|
||||||
/* The revision number of the file format. */
|
|
||||||
nls_uint32 revision;
|
|
||||||
|
|
||||||
/* The following are only used in .mo files with major revision 0 or 1. */
|
|
||||||
|
|
||||||
/* The number of strings pairs. */
|
|
||||||
nls_uint32 nstrings;
|
|
||||||
/* Offset of table with start offsets of original strings. */
|
|
||||||
nls_uint32 orig_tab_offset;
|
|
||||||
/* Offset of table with start offsets of translated strings. */
|
|
||||||
nls_uint32 trans_tab_offset;
|
|
||||||
/* Size of hash table. */
|
|
||||||
nls_uint32 hash_tab_size;
|
|
||||||
/* Offset of first hash table entry. */
|
|
||||||
nls_uint32 hash_tab_offset;
|
|
||||||
|
|
||||||
/* The following are only used in .mo files with minor revision >= 1. */
|
|
||||||
|
|
||||||
/* The number of system dependent segments. */
|
|
||||||
nls_uint32 n_sysdep_segments;
|
|
||||||
/* Offset of table describing system dependent segments. */
|
|
||||||
nls_uint32 sysdep_segments_offset;
|
|
||||||
/* The number of system dependent strings pairs. */
|
|
||||||
nls_uint32 n_sysdep_strings;
|
|
||||||
/* Offset of table with start offsets of original sysdep strings. */
|
|
||||||
nls_uint32 orig_sysdep_tab_offset;
|
|
||||||
/* Offset of table with start offsets of translated sysdep strings. */
|
|
||||||
nls_uint32 trans_sysdep_tab_offset;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Descriptor for static string contained in the binary .mo file. */
|
|
||||||
struct string_desc
|
|
||||||
{
|
|
||||||
/* Length of addressed string, not including the trailing NUL. */
|
|
||||||
nls_uint32 length;
|
|
||||||
/* Offset of string in file. */
|
|
||||||
nls_uint32 offset;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* The following are only used in .mo files with minor revision >= 1. */
|
|
||||||
|
|
||||||
/* Descriptor for system dependent string segment. */
|
|
||||||
struct sysdep_segment
|
|
||||||
{
|
|
||||||
/* Length of addressed string, including the trailing NUL. */
|
|
||||||
nls_uint32 length;
|
|
||||||
/* Offset of string in file. */
|
|
||||||
nls_uint32 offset;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Pair of a static and a system dependent segment, in struct sysdep_string. */
|
|
||||||
struct segment_pair
|
|
||||||
{
|
|
||||||
/* Size of static segment. */
|
|
||||||
nls_uint32 segsize;
|
|
||||||
/* Reference to system dependent string segment, or ~0 at the end. */
|
|
||||||
nls_uint32 sysdepref;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Descriptor for system dependent string. */
|
|
||||||
struct sysdep_string
|
|
||||||
{
|
|
||||||
/* Offset of static string segments in file. */
|
|
||||||
nls_uint32 offset;
|
|
||||||
/* Alternating sequence of static and system dependent segments.
|
|
||||||
The last segment is a static segment, including the trailing NUL. */
|
|
||||||
struct segment_pair segments[1];
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Marker for the end of the segments[] array. This has the value 0xFFFFFFFF,
|
|
||||||
regardless whether 'int' is 16 bit, 32 bit, or 64 bit. */
|
|
||||||
#define SEGMENTS_END ((nls_uint32) ~0)
|
|
||||||
|
|
||||||
/* @@ begin of epilog @@ */
|
|
||||||
|
|
||||||
#endif /* gettext.h */
|
|
|
@ -1,51 +0,0 @@
|
||||||
/* Implements a string hashing function.
|
|
||||||
Copyright (C) 1995, 1997, 1998, 2000, 2003 Free Software Foundation, Inc.
|
|
||||||
This file is part of the GNU C Library.
|
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU Lesser General Public
|
|
||||||
License as published by the Free Software Foundation; either
|
|
||||||
version 2.1 of the License, or (at your option) any later version.
|
|
||||||
|
|
||||||
The GNU C Library is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Lesser General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public
|
|
||||||
License along with the GNU C Library; if not, write to the Free
|
|
||||||
Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
||||||
Boston, MA 02110-1301, USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Specification. */
|
|
||||||
#include "hash-string.h"
|
|
||||||
|
|
||||||
|
|
||||||
/* Defines the so called `hashpjw' function by P.J. Weinberger
|
|
||||||
[see Aho/Sethi/Ullman, COMPILERS: Principles, Techniques and Tools,
|
|
||||||
1986, 1987 Bell Telephone Laboratories, Inc.] */
|
|
||||||
unsigned long int
|
|
||||||
__hash_string (const char *str_param)
|
|
||||||
{
|
|
||||||
unsigned long int hval, g;
|
|
||||||
const char *str = str_param;
|
|
||||||
|
|
||||||
/* Compute the hash value for the given string. */
|
|
||||||
hval = 0;
|
|
||||||
while (*str != '\0')
|
|
||||||
{
|
|
||||||
hval <<= 4;
|
|
||||||
hval += (unsigned char) *str++;
|
|
||||||
g = hval & ((unsigned long int) 0xf << (HASHWORDBITS - 4));
|
|
||||||
if (g != 0)
|
|
||||||
{
|
|
||||||
hval ^= g >> (HASHWORDBITS - 8);
|
|
||||||
hval ^= g;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return hval;
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
/* Description of GNU message catalog format: string hashing function.
|
|
||||||
Copyright (C) 1995, 1997-1998, 2000-2003, 2005 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* We assume to have `unsigned long int' value with at least 32 bits. */
|
|
||||||
#define HASHWORDBITS 32
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef _LIBC
|
|
||||||
# ifdef IN_LIBINTL
|
|
||||||
# define __hash_string libintl_hash_string
|
|
||||||
# else
|
|
||||||
# define __hash_string hash_string
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Defines the so called `hashpjw' function by P.J. Weinberger
|
|
||||||
[see Aho/Sethi/Ullman, COMPILERS: Principles, Techniques and Tools,
|
|
||||||
1986, 1987 Bell Telephone Laboratories, Inc.] */
|
|
||||||
extern unsigned long int __hash_string (const char *str_param);
|
|
|
@ -1,133 +0,0 @@
|
||||||
/* intl-compat.c - Stub functions to call gettext functions from GNU gettext
|
|
||||||
Library.
|
|
||||||
Copyright (C) 1995, 2000-2003, 2005 Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
/* This file redirects the gettext functions (without prefix) to those
|
|
||||||
defined in the included GNU libintl library (with "libintl_" prefix).
|
|
||||||
It is compiled into libintl in order to make the AM_GNU_GETTEXT test
|
|
||||||
of gettext <= 0.11.2 work with the libintl library >= 0.11.3 which
|
|
||||||
has the redirections primarily in the <libintl.h> include file.
|
|
||||||
It is also compiled into libgnuintl so that libgnuintl.so can be used
|
|
||||||
as LD_PRELOADable library on glibc systems, to provide the extra
|
|
||||||
features that the functions in the libc don't have (namely, logging). */
|
|
||||||
|
|
||||||
|
|
||||||
#undef gettext
|
|
||||||
#undef dgettext
|
|
||||||
#undef dcgettext
|
|
||||||
#undef ngettext
|
|
||||||
#undef dngettext
|
|
||||||
#undef dcngettext
|
|
||||||
#undef textdomain
|
|
||||||
#undef bindtextdomain
|
|
||||||
#undef bind_textdomain_codeset
|
|
||||||
|
|
||||||
|
|
||||||
/* When building a DLL, we must export some functions. Note that because
|
|
||||||
the functions are only defined for binary backward compatibility, we
|
|
||||||
don't need to use __declspec(dllimport) in any case. */
|
|
||||||
#if HAVE_VISIBILITY && BUILDING_DLL
|
|
||||||
# define DLL_EXPORTED __attribute__((__visibility__("default")))
|
|
||||||
#elif defined _MSC_VER && BUILDING_DLL
|
|
||||||
# define DLL_EXPORTED __declspec(dllexport)
|
|
||||||
#else
|
|
||||||
# define DLL_EXPORTED
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
gettext (const char *msgid)
|
|
||||||
{
|
|
||||||
return libintl_gettext (msgid);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
dgettext (const char *domainname, const char *msgid)
|
|
||||||
{
|
|
||||||
return libintl_dgettext (domainname, msgid);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
dcgettext (const char *domainname, const char *msgid, int category)
|
|
||||||
{
|
|
||||||
return libintl_dcgettext (domainname, msgid, category);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
ngettext (const char *msgid1, const char *msgid2, unsigned long int n)
|
|
||||||
{
|
|
||||||
return libintl_ngettext (msgid1, msgid2, n);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
dngettext (const char *domainname,
|
|
||||||
const char *msgid1, const char *msgid2, unsigned long int n)
|
|
||||||
{
|
|
||||||
return libintl_dngettext (domainname, msgid1, msgid2, n);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
dcngettext (const char *domainname,
|
|
||||||
const char *msgid1, const char *msgid2, unsigned long int n,
|
|
||||||
int category)
|
|
||||||
{
|
|
||||||
return libintl_dcngettext (domainname, msgid1, msgid2, n, category);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
textdomain (const char *domainname)
|
|
||||||
{
|
|
||||||
return libintl_textdomain (domainname);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
bindtextdomain (const char *domainname, const char *dirname)
|
|
||||||
{
|
|
||||||
return libintl_bindtextdomain (domainname, dirname);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
DLL_EXPORTED
|
|
||||||
char *
|
|
||||||
bind_textdomain_codeset (const char *domainname, const char *codeset)
|
|
||||||
{
|
|
||||||
return libintl_bind_textdomain_codeset (domainname, codeset);
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
/* List of exported symbols of libintl on Cygwin.
|
|
||||||
Copyright (C) 2006 Free Software Foundation, Inc.
|
|
||||||
Written by Bruno Haible <bruno@clisp.org>, 2006.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* IMP(x) is a symbol that contains the address of x. */
|
|
||||||
#define IMP(x) _imp__##x
|
|
||||||
|
|
||||||
/* Ensure that the variable x is exported from the library, and that a
|
|
||||||
pseudo-variable IMP(x) is available. */
|
|
||||||
#define VARIABLE(x) \
|
|
||||||
/* Export x without redefining x. This code was found by compiling a \
|
|
||||||
snippet: \
|
|
||||||
extern __declspec(dllexport) int x; int x = 42; */ \
|
|
||||||
asm (".section .drectve\n"); \
|
|
||||||
asm (".ascii \" -export:" #x ",data\"\n"); \
|
|
||||||
asm (".data\n"); \
|
|
||||||
/* Allocate a pseudo-variable IMP(x). */ \
|
|
||||||
extern int x; \
|
|
||||||
void * IMP(x) = &x;
|
|
||||||
|
|
||||||
VARIABLE(libintl_version)
|
|
|
@ -1,400 +0,0 @@
|
||||||
/* Copyright (C) 1995-1999, 2000-2006 Free Software Foundation, Inc.
|
|
||||||
Contributed by Ulrich Drepper <drepper@gnu.ai.mit.edu>, 1995.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* Tell glibc's <string.h> to provide a prototype for stpcpy().
|
|
||||||
This must come before <config.h> because <config.h> may include
|
|
||||||
<features.h>, and once <features.h> has been included, it's too late. */
|
|
||||||
#ifndef _GNU_SOURCE
|
|
||||||
# define _GNU_SOURCE 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#if defined _LIBC || defined HAVE_ARGZ_H
|
|
||||||
# include <argz.h>
|
|
||||||
#endif
|
|
||||||
#include <ctype.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
#include "loadinfo.h"
|
|
||||||
|
|
||||||
/* On some strange systems still no definition of NULL is found. Sigh! */
|
|
||||||
#ifndef NULL
|
|
||||||
# if defined __STDC__ && __STDC__
|
|
||||||
# define NULL ((void *) 0)
|
|
||||||
# else
|
|
||||||
# define NULL 0
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Rename the non ANSI C functions. This is required by the standard
|
|
||||||
because some ANSI C functions will require linking with this object
|
|
||||||
file and the name space must not be polluted. */
|
|
||||||
# ifndef stpcpy
|
|
||||||
# define stpcpy(dest, src) __stpcpy(dest, src)
|
|
||||||
# endif
|
|
||||||
#else
|
|
||||||
# ifndef HAVE_STPCPY
|
|
||||||
static char *stpcpy (char *dest, const char *src);
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Pathname support.
|
|
||||||
ISSLASH(C) tests whether C is a directory separator character.
|
|
||||||
IS_ABSOLUTE_PATH(P) tests whether P is an absolute path. If it is not,
|
|
||||||
it may be concatenated to a directory pathname.
|
|
||||||
*/
|
|
||||||
#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__
|
|
||||||
/* Win32, Cygwin, OS/2, DOS */
|
|
||||||
# define ISSLASH(C) ((C) == '/' || (C) == '\\')
|
|
||||||
# define HAS_DEVICE(P) \
|
|
||||||
((((P)[0] >= 'A' && (P)[0] <= 'Z') || ((P)[0] >= 'a' && (P)[0] <= 'z')) \
|
|
||||||
&& (P)[1] == ':')
|
|
||||||
# define IS_ABSOLUTE_PATH(P) (ISSLASH ((P)[0]) || HAS_DEVICE (P))
|
|
||||||
#else
|
|
||||||
/* Unix */
|
|
||||||
# define ISSLASH(C) ((C) == '/')
|
|
||||||
# define IS_ABSOLUTE_PATH(P) ISSLASH ((P)[0])
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Define function which are usually not available. */
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define __argz_count(argz, len) INTUSE(__argz_count) (argz, len)
|
|
||||||
#elif defined HAVE_ARGZ_COUNT
|
|
||||||
# undef __argz_count
|
|
||||||
# define __argz_count argz_count
|
|
||||||
#else
|
|
||||||
/* Returns the number of strings in ARGZ. */
|
|
||||||
static size_t
|
|
||||||
argz_count__ (const char *argz, size_t len)
|
|
||||||
{
|
|
||||||
size_t count = 0;
|
|
||||||
while (len > 0)
|
|
||||||
{
|
|
||||||
size_t part_len = strlen (argz);
|
|
||||||
argz += part_len + 1;
|
|
||||||
len -= part_len + 1;
|
|
||||||
count++;
|
|
||||||
}
|
|
||||||
return count;
|
|
||||||
}
|
|
||||||
# undef __argz_count
|
|
||||||
# define __argz_count(argz, len) argz_count__ (argz, len)
|
|
||||||
#endif /* !_LIBC && !HAVE_ARGZ_COUNT */
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define __argz_stringify(argz, len, sep) \
|
|
||||||
INTUSE(__argz_stringify) (argz, len, sep)
|
|
||||||
#elif defined HAVE_ARGZ_STRINGIFY
|
|
||||||
# undef __argz_stringify
|
|
||||||
# define __argz_stringify argz_stringify
|
|
||||||
#else
|
|
||||||
/* Make '\0' separated arg vector ARGZ printable by converting all the '\0's
|
|
||||||
except the last into the character SEP. */
|
|
||||||
static void
|
|
||||||
argz_stringify__ (char *argz, size_t len, int sep)
|
|
||||||
{
|
|
||||||
while (len > 0)
|
|
||||||
{
|
|
||||||
size_t part_len = strlen (argz);
|
|
||||||
argz += part_len;
|
|
||||||
len -= part_len + 1;
|
|
||||||
if (len > 0)
|
|
||||||
*argz++ = sep;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
# undef __argz_stringify
|
|
||||||
# define __argz_stringify(argz, len, sep) argz_stringify__ (argz, len, sep)
|
|
||||||
#endif /* !_LIBC && !HAVE_ARGZ_STRINGIFY */
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
#elif defined HAVE_ARGZ_NEXT
|
|
||||||
# undef __argz_next
|
|
||||||
# define __argz_next argz_next
|
|
||||||
#else
|
|
||||||
static char *
|
|
||||||
argz_next__ (char *argz, size_t argz_len, const char *entry)
|
|
||||||
{
|
|
||||||
if (entry)
|
|
||||||
{
|
|
||||||
if (entry < argz + argz_len)
|
|
||||||
entry = strchr (entry, '\0') + 1;
|
|
||||||
|
|
||||||
return entry >= argz + argz_len ? NULL : (char *) entry;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (argz_len > 0)
|
|
||||||
return argz;
|
|
||||||
else
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
# undef __argz_next
|
|
||||||
# define __argz_next(argz, len, entry) argz_next__ (argz, len, entry)
|
|
||||||
#endif /* !_LIBC && !HAVE_ARGZ_NEXT */
|
|
||||||
|
|
||||||
|
|
||||||
/* Return number of bits set in X. */
|
|
||||||
static inline int
|
|
||||||
pop (int x)
|
|
||||||
{
|
|
||||||
/* We assume that no more than 16 bits are used. */
|
|
||||||
x = ((x & ~0x5555) >> 1) + (x & 0x5555);
|
|
||||||
x = ((x & ~0x3333) >> 2) + (x & 0x3333);
|
|
||||||
x = ((x >> 4) + x) & 0x0f0f;
|
|
||||||
x = ((x >> 8) + x) & 0xff;
|
|
||||||
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
struct loaded_l10nfile *
|
|
||||||
_nl_make_l10nflist (struct loaded_l10nfile **l10nfile_list,
|
|
||||||
const char *dirlist, size_t dirlist_len,
|
|
||||||
int mask, const char *language, const char *territory,
|
|
||||||
const char *codeset, const char *normalized_codeset,
|
|
||||||
const char *modifier,
|
|
||||||
const char *filename, int do_allocate)
|
|
||||||
{
|
|
||||||
char *abs_filename;
|
|
||||||
struct loaded_l10nfile **lastp;
|
|
||||||
struct loaded_l10nfile *retval;
|
|
||||||
char *cp;
|
|
||||||
size_t dirlist_count;
|
|
||||||
size_t entries;
|
|
||||||
int cnt;
|
|
||||||
|
|
||||||
/* If LANGUAGE contains an absolute directory specification, we ignore
|
|
||||||
DIRLIST. */
|
|
||||||
if (IS_ABSOLUTE_PATH (language))
|
|
||||||
dirlist_len = 0;
|
|
||||||
|
|
||||||
/* Allocate room for the full file name. */
|
|
||||||
abs_filename = (char *) malloc (dirlist_len
|
|
||||||
+ strlen (language)
|
|
||||||
+ ((mask & XPG_TERRITORY) != 0
|
|
||||||
? strlen (territory) + 1 : 0)
|
|
||||||
+ ((mask & XPG_CODESET) != 0
|
|
||||||
? strlen (codeset) + 1 : 0)
|
|
||||||
+ ((mask & XPG_NORM_CODESET) != 0
|
|
||||||
? strlen (normalized_codeset) + 1 : 0)
|
|
||||||
+ ((mask & XPG_MODIFIER) != 0
|
|
||||||
? strlen (modifier) + 1 : 0)
|
|
||||||
+ 1 + strlen (filename) + 1);
|
|
||||||
|
|
||||||
if (abs_filename == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
/* Construct file name. */
|
|
||||||
cp = abs_filename;
|
|
||||||
if (dirlist_len > 0)
|
|
||||||
{
|
|
||||||
memcpy (cp, dirlist, dirlist_len);
|
|
||||||
__argz_stringify (cp, dirlist_len, PATH_SEPARATOR);
|
|
||||||
cp += dirlist_len;
|
|
||||||
cp[-1] = '/';
|
|
||||||
}
|
|
||||||
|
|
||||||
cp = stpcpy (cp, language);
|
|
||||||
|
|
||||||
if ((mask & XPG_TERRITORY) != 0)
|
|
||||||
{
|
|
||||||
*cp++ = '_';
|
|
||||||
cp = stpcpy (cp, territory);
|
|
||||||
}
|
|
||||||
if ((mask & XPG_CODESET) != 0)
|
|
||||||
{
|
|
||||||
*cp++ = '.';
|
|
||||||
cp = stpcpy (cp, codeset);
|
|
||||||
}
|
|
||||||
if ((mask & XPG_NORM_CODESET) != 0)
|
|
||||||
{
|
|
||||||
*cp++ = '.';
|
|
||||||
cp = stpcpy (cp, normalized_codeset);
|
|
||||||
}
|
|
||||||
if ((mask & XPG_MODIFIER) != 0)
|
|
||||||
{
|
|
||||||
*cp++ = '@';
|
|
||||||
cp = stpcpy (cp, modifier);
|
|
||||||
}
|
|
||||||
|
|
||||||
*cp++ = '/';
|
|
||||||
stpcpy (cp, filename);
|
|
||||||
|
|
||||||
/* Look in list of already loaded domains whether it is already
|
|
||||||
available. */
|
|
||||||
lastp = l10nfile_list;
|
|
||||||
for (retval = *l10nfile_list; retval != NULL; retval = retval->next)
|
|
||||||
if (retval->filename != NULL)
|
|
||||||
{
|
|
||||||
int compare = strcmp (retval->filename, abs_filename);
|
|
||||||
if (compare == 0)
|
|
||||||
/* We found it! */
|
|
||||||
break;
|
|
||||||
if (compare < 0)
|
|
||||||
{
|
|
||||||
/* It's not in the list. */
|
|
||||||
retval = NULL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
lastp = &retval->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (retval != NULL || do_allocate == 0)
|
|
||||||
{
|
|
||||||
free (abs_filename);
|
|
||||||
return retval;
|
|
||||||
}
|
|
||||||
|
|
||||||
dirlist_count = (dirlist_len > 0 ? __argz_count (dirlist, dirlist_len) : 1);
|
|
||||||
|
|
||||||
/* Allocate a new loaded_l10nfile. */
|
|
||||||
retval =
|
|
||||||
(struct loaded_l10nfile *)
|
|
||||||
malloc (sizeof (*retval)
|
|
||||||
+ (((dirlist_count << pop (mask)) + (dirlist_count > 1 ? 1 : 0))
|
|
||||||
* sizeof (struct loaded_l10nfile *)));
|
|
||||||
if (retval == NULL)
|
|
||||||
{
|
|
||||||
free (abs_filename);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
retval->filename = abs_filename;
|
|
||||||
|
|
||||||
/* We set retval->data to NULL here; it is filled in later.
|
|
||||||
Setting retval->decided to 1 here means that retval does not
|
|
||||||
correspond to a real file (dirlist_count > 1) or is not worth
|
|
||||||
looking up (if an unnormalized codeset was specified). */
|
|
||||||
retval->decided = (dirlist_count > 1
|
|
||||||
|| ((mask & XPG_CODESET) != 0
|
|
||||||
&& (mask & XPG_NORM_CODESET) != 0));
|
|
||||||
retval->data = NULL;
|
|
||||||
|
|
||||||
retval->next = *lastp;
|
|
||||||
*lastp = retval;
|
|
||||||
|
|
||||||
entries = 0;
|
|
||||||
/* Recurse to fill the inheritance list of RETVAL.
|
|
||||||
If the DIRLIST is a real list (i.e. DIRLIST_COUNT > 1), the RETVAL
|
|
||||||
entry does not correspond to a real file; retval->filename contains
|
|
||||||
colons. In this case we loop across all elements of DIRLIST and
|
|
||||||
across all bit patterns dominated by MASK.
|
|
||||||
If the DIRLIST is a single directory or entirely redundant (i.e.
|
|
||||||
DIRLIST_COUNT == 1), we loop across all bit patterns dominated by
|
|
||||||
MASK, excluding MASK itself.
|
|
||||||
In either case, we loop down from MASK to 0. This has the effect
|
|
||||||
that the extra bits in the locale name are dropped in this order:
|
|
||||||
first the modifier, then the territory, then the codeset, then the
|
|
||||||
normalized_codeset. */
|
|
||||||
for (cnt = dirlist_count > 1 ? mask : mask - 1; cnt >= 0; --cnt)
|
|
||||||
if ((cnt & ~mask) == 0
|
|
||||||
&& !((cnt & XPG_CODESET) != 0 && (cnt & XPG_NORM_CODESET) != 0))
|
|
||||||
{
|
|
||||||
if (dirlist_count > 1)
|
|
||||||
{
|
|
||||||
/* Iterate over all elements of the DIRLIST. */
|
|
||||||
char *dir = NULL;
|
|
||||||
|
|
||||||
while ((dir = __argz_next ((char *) dirlist, dirlist_len, dir))
|
|
||||||
!= NULL)
|
|
||||||
retval->successor[entries++]
|
|
||||||
= _nl_make_l10nflist (l10nfile_list, dir, strlen (dir) + 1,
|
|
||||||
cnt, language, territory, codeset,
|
|
||||||
normalized_codeset, modifier, filename,
|
|
||||||
1);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
retval->successor[entries++]
|
|
||||||
= _nl_make_l10nflist (l10nfile_list, dirlist, dirlist_len,
|
|
||||||
cnt, language, territory, codeset,
|
|
||||||
normalized_codeset, modifier, filename, 1);
|
|
||||||
}
|
|
||||||
retval->successor[entries] = NULL;
|
|
||||||
|
|
||||||
return retval;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Normalize codeset name. There is no standard for the codeset
|
|
||||||
names. Normalization allows the user to use any of the common
|
|
||||||
names. The return value is dynamically allocated and has to be
|
|
||||||
freed by the caller. */
|
|
||||||
const char *
|
|
||||||
_nl_normalize_codeset (const char *codeset, size_t name_len)
|
|
||||||
{
|
|
||||||
int len = 0;
|
|
||||||
int only_digit = 1;
|
|
||||||
char *retval;
|
|
||||||
char *wp;
|
|
||||||
size_t cnt;
|
|
||||||
|
|
||||||
for (cnt = 0; cnt < name_len; ++cnt)
|
|
||||||
if (isalnum ((unsigned char) codeset[cnt]))
|
|
||||||
{
|
|
||||||
++len;
|
|
||||||
|
|
||||||
if (isalpha ((unsigned char) codeset[cnt]))
|
|
||||||
only_digit = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
retval = (char *) malloc ((only_digit ? 3 : 0) + len + 1);
|
|
||||||
|
|
||||||
if (retval != NULL)
|
|
||||||
{
|
|
||||||
if (only_digit)
|
|
||||||
wp = stpcpy (retval, "iso");
|
|
||||||
else
|
|
||||||
wp = retval;
|
|
||||||
|
|
||||||
for (cnt = 0; cnt < name_len; ++cnt)
|
|
||||||
if (isalpha ((unsigned char) codeset[cnt]))
|
|
||||||
*wp++ = tolower ((unsigned char) codeset[cnt]);
|
|
||||||
else if (isdigit ((unsigned char) codeset[cnt]))
|
|
||||||
*wp++ = codeset[cnt];
|
|
||||||
|
|
||||||
*wp = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
return (const char *) retval;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @@ begin of epilog @@ */
|
|
||||||
|
|
||||||
/* We don't want libintl.a to depend on any other library. So we
|
|
||||||
avoid the non-standard function stpcpy. In GNU C Library this
|
|
||||||
function is available, though. Also allow the symbol HAVE_STPCPY
|
|
||||||
to be defined. */
|
|
||||||
#if !_LIBC && !HAVE_STPCPY
|
|
||||||
static char *
|
|
||||||
stpcpy (char *dest, const char *src)
|
|
||||||
{
|
|
||||||
while ((*dest++ = *src++) != '\0')
|
|
||||||
/* Do nothing. */ ;
|
|
||||||
return dest - 1;
|
|
||||||
}
|
|
||||||
#endif
|
|
|
@ -1,130 +0,0 @@
|
||||||
/* Determine the user's language preferences.
|
|
||||||
Copyright (C) 2004-2006 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* Written by Bruno Haible <bruno@clisp.org>. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
#if HAVE_CFPREFERENCESCOPYAPPVALUE
|
|
||||||
# include <string.h>
|
|
||||||
# include <CoreFoundation/CFPreferences.h>
|
|
||||||
# include <CoreFoundation/CFPropertyList.h>
|
|
||||||
# include <CoreFoundation/CFArray.h>
|
|
||||||
# include <CoreFoundation/CFString.h>
|
|
||||||
extern void _nl_locale_name_canonicalize (char *name);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Determine the user's language preferences, as a colon separated list of
|
|
||||||
locale names in XPG syntax
|
|
||||||
language[_territory][.codeset][@modifier]
|
|
||||||
The result must not be freed; it is statically allocated.
|
|
||||||
The LANGUAGE environment variable does not need to be considered; it is
|
|
||||||
already taken into account by the caller. */
|
|
||||||
|
|
||||||
const char *
|
|
||||||
_nl_language_preferences_default (void)
|
|
||||||
{
|
|
||||||
#if HAVE_CFPREFERENCESCOPYAPPVALUE /* MacOS X 10.2 or newer */
|
|
||||||
{
|
|
||||||
/* Cache the preferences list, since CoreFoundation calls are expensive. */
|
|
||||||
static const char *cached_languages;
|
|
||||||
static int cache_initialized;
|
|
||||||
|
|
||||||
if (!cache_initialized)
|
|
||||||
{
|
|
||||||
CFTypeRef preferences =
|
|
||||||
CFPreferencesCopyAppValue (CFSTR ("AppleLanguages"),
|
|
||||||
kCFPreferencesCurrentApplication);
|
|
||||||
if (preferences != NULL
|
|
||||||
&& CFGetTypeID (preferences) == CFArrayGetTypeID ())
|
|
||||||
{
|
|
||||||
CFArrayRef prefArray = (CFArrayRef)preferences;
|
|
||||||
int n = CFArrayGetCount (prefArray);
|
|
||||||
char buf[256];
|
|
||||||
size_t size = 0;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < n; i++)
|
|
||||||
{
|
|
||||||
CFTypeRef element = CFArrayGetValueAtIndex (prefArray, i);
|
|
||||||
if (element != NULL
|
|
||||||
&& CFGetTypeID (element) == CFStringGetTypeID ()
|
|
||||||
&& CFStringGetCString ((CFStringRef)element,
|
|
||||||
buf, sizeof (buf),
|
|
||||||
kCFStringEncodingASCII))
|
|
||||||
{
|
|
||||||
_nl_locale_name_canonicalize (buf);
|
|
||||||
size += strlen (buf) + 1;
|
|
||||||
/* Most GNU programs use msgids in English and don't ship
|
|
||||||
an en.mo message catalog. Therefore when we see "en"
|
|
||||||
in the preferences list, arrange for gettext() to
|
|
||||||
return the msgid, and ignore all further elements of
|
|
||||||
the preferences list. */
|
|
||||||
if (strcmp (buf, "en") == 0)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (size > 0)
|
|
||||||
{
|
|
||||||
char *languages = (char *) malloc (size);
|
|
||||||
|
|
||||||
if (languages != NULL)
|
|
||||||
{
|
|
||||||
char *p = languages;
|
|
||||||
|
|
||||||
for (i = 0; i < n; i++)
|
|
||||||
{
|
|
||||||
CFTypeRef element =
|
|
||||||
CFArrayGetValueAtIndex (prefArray, i);
|
|
||||||
if (element != NULL
|
|
||||||
&& CFGetTypeID (element) == CFStringGetTypeID ()
|
|
||||||
&& CFStringGetCString ((CFStringRef)element,
|
|
||||||
buf, sizeof (buf),
|
|
||||||
kCFStringEncodingASCII))
|
|
||||||
{
|
|
||||||
_nl_locale_name_canonicalize (buf);
|
|
||||||
strcpy (p, buf);
|
|
||||||
p += strlen (buf);
|
|
||||||
*p++ = ':';
|
|
||||||
if (strcmp (buf, "en") == 0)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
*--p = '\0';
|
|
||||||
|
|
||||||
cached_languages = languages;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cache_initialized = 1;
|
|
||||||
}
|
|
||||||
if (cached_languages != NULL)
|
|
||||||
return cached_languages;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
|
@ -1,419 +0,0 @@
|
||||||
/* Message catalogs for internationalization.
|
|
||||||
Copyright (C) 1995-1997, 2000-2007 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifndef _LIBINTL_H
|
|
||||||
#define _LIBINTL_H 1
|
|
||||||
|
|
||||||
#include <locale.h>
|
|
||||||
|
|
||||||
/* The LC_MESSAGES locale category is the category used by the functions
|
|
||||||
gettext() and dgettext(). It is specified in POSIX, but not in ANSI C.
|
|
||||||
On systems that don't define it, use an arbitrary value instead.
|
|
||||||
On Solaris, <locale.h> defines __LOCALE_H (or _LOCALE_H in Solaris 2.5)
|
|
||||||
then includes <libintl.h> (i.e. this file!) and then only defines
|
|
||||||
LC_MESSAGES. To avoid a redefinition warning, don't define LC_MESSAGES
|
|
||||||
in this case. */
|
|
||||||
#if !defined LC_MESSAGES && !(defined __LOCALE_H || (defined _LOCALE_H && defined __sun))
|
|
||||||
# define LC_MESSAGES 1729
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* We define an additional symbol to signal that we use the GNU
|
|
||||||
implementation of gettext. */
|
|
||||||
#define __USE_GNU_GETTEXT 1
|
|
||||||
|
|
||||||
/* Provide information about the supported file formats. Returns the
|
|
||||||
maximum minor revision number supported for a given major revision. */
|
|
||||||
#define __GNU_GETTEXT_SUPPORTED_REVISION(major) \
|
|
||||||
((major) == 0 || (major) == 1 ? 1 : -1)
|
|
||||||
|
|
||||||
/* Resolve a platform specific conflict on DJGPP. GNU gettext takes
|
|
||||||
precedence over _conio_gettext. */
|
|
||||||
#ifdef __DJGPP__
|
|
||||||
# undef gettext
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Version number: (major<<16) + (minor<<8) + subminor */
|
|
||||||
#define LIBINTL_VERSION 0x001100
|
|
||||||
extern int libintl_version;
|
|
||||||
|
|
||||||
|
|
||||||
/* We redirect the functions to those prefixed with "libintl_". This is
|
|
||||||
necessary, because some systems define gettext/textdomain/... in the C
|
|
||||||
library (namely, Solaris 2.4 and newer, and GNU libc 2.0 and newer).
|
|
||||||
If we used the unprefixed names, there would be cases where the
|
|
||||||
definition in the C library would override the one in the libintl.so
|
|
||||||
shared library. Recall that on ELF systems, the symbols are looked
|
|
||||||
up in the following order:
|
|
||||||
1. in the executable,
|
|
||||||
2. in the shared libraries specified on the link command line, in order,
|
|
||||||
3. in the dependencies of the shared libraries specified on the link
|
|
||||||
command line,
|
|
||||||
4. in the dlopen()ed shared libraries, in the order in which they were
|
|
||||||
dlopen()ed.
|
|
||||||
The definition in the C library would override the one in libintl.so if
|
|
||||||
either
|
|
||||||
* -lc is given on the link command line and -lintl isn't, or
|
|
||||||
* -lc is given on the link command line before -lintl, or
|
|
||||||
* libintl.so is a dependency of a dlopen()ed shared library but not
|
|
||||||
linked to the executable at link time.
|
|
||||||
Since Solaris gettext() behaves differently than GNU gettext(), this
|
|
||||||
would be unacceptable.
|
|
||||||
|
|
||||||
The redirection happens by default through macros in C, so that &gettext
|
|
||||||
is independent of the compilation unit, but through inline functions in
|
|
||||||
C++, in order not to interfere with the name mangling of class fields or
|
|
||||||
class methods called 'gettext'. */
|
|
||||||
|
|
||||||
/* The user can define _INTL_REDIRECT_INLINE or _INTL_REDIRECT_MACROS.
|
|
||||||
If he doesn't, we choose the method. A third possible method is
|
|
||||||
_INTL_REDIRECT_ASM, supported only by GCC. */
|
|
||||||
#if !(defined _INTL_REDIRECT_INLINE || defined _INTL_REDIRECT_MACROS)
|
|
||||||
# if __GNUC__ >= 2 && !(__APPLE_CC__ > 1) && !defined __MINGW32__ && !(__GNUC__ == 2 && defined _AIX) && (defined __STDC__ || defined __cplusplus)
|
|
||||||
# define _INTL_REDIRECT_ASM
|
|
||||||
# else
|
|
||||||
# ifdef __cplusplus
|
|
||||||
# define _INTL_REDIRECT_INLINE
|
|
||||||
# else
|
|
||||||
# define _INTL_REDIRECT_MACROS
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
/* Auxiliary macros. */
|
|
||||||
#ifdef _INTL_REDIRECT_ASM
|
|
||||||
# define _INTL_ASM(cname) __asm__ (_INTL_ASMNAME (__USER_LABEL_PREFIX__, #cname))
|
|
||||||
# define _INTL_ASMNAME(prefix,cnamestring) _INTL_STRINGIFY (prefix) cnamestring
|
|
||||||
# define _INTL_STRINGIFY(prefix) #prefix
|
|
||||||
#else
|
|
||||||
# define _INTL_ASM(cname)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* _INTL_MAY_RETURN_STRING_ARG(n) declares that the given function may return
|
|
||||||
its n-th argument literally. This enables GCC to warn for example about
|
|
||||||
printf (gettext ("foo %y")). */
|
|
||||||
#if __GNUC__ >= 3 && !(__APPLE_CC__ > 1 && defined __cplusplus)
|
|
||||||
# define _INTL_MAY_RETURN_STRING_ARG(n) __attribute__ ((__format_arg__ (n)))
|
|
||||||
#else
|
|
||||||
# define _INTL_MAY_RETURN_STRING_ARG(n)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the current default message catalog for the current
|
|
||||||
LC_MESSAGES locale. If not found, returns MSGID itself (the default
|
|
||||||
text). */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_gettext (const char *__msgid)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (1);
|
|
||||||
static inline char *gettext (const char *__msgid)
|
|
||||||
{
|
|
||||||
return libintl_gettext (__msgid);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define gettext libintl_gettext
|
|
||||||
#endif
|
|
||||||
extern char *gettext (const char *__msgid)
|
|
||||||
_INTL_ASM (libintl_gettext)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (1);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the DOMAINNAME message catalog for the current
|
|
||||||
LC_MESSAGES locale. */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_dgettext (const char *__domainname, const char *__msgid)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2);
|
|
||||||
static inline char *dgettext (const char *__domainname, const char *__msgid)
|
|
||||||
{
|
|
||||||
return libintl_dgettext (__domainname, __msgid);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define dgettext libintl_dgettext
|
|
||||||
#endif
|
|
||||||
extern char *dgettext (const char *__domainname, const char *__msgid)
|
|
||||||
_INTL_ASM (libintl_dgettext)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Look up MSGID in the DOMAINNAME message catalog for the current CATEGORY
|
|
||||||
locale. */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_dcgettext (const char *__domainname, const char *__msgid,
|
|
||||||
int __category)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2);
|
|
||||||
static inline char *dcgettext (const char *__domainname, const char *__msgid,
|
|
||||||
int __category)
|
|
||||||
{
|
|
||||||
return libintl_dcgettext (__domainname, __msgid, __category);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define dcgettext libintl_dcgettext
|
|
||||||
#endif
|
|
||||||
extern char *dcgettext (const char *__domainname, const char *__msgid,
|
|
||||||
int __category)
|
|
||||||
_INTL_ASM (libintl_dcgettext)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Similar to `gettext' but select the plural form corresponding to the
|
|
||||||
number N. */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_ngettext (const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (1) _INTL_MAY_RETURN_STRING_ARG (2);
|
|
||||||
static inline char *ngettext (const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n)
|
|
||||||
{
|
|
||||||
return libintl_ngettext (__msgid1, __msgid2, __n);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define ngettext libintl_ngettext
|
|
||||||
#endif
|
|
||||||
extern char *ngettext (const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n)
|
|
||||||
_INTL_ASM (libintl_ngettext)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (1) _INTL_MAY_RETURN_STRING_ARG (2);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Similar to `dgettext' but select the plural form corresponding to the
|
|
||||||
number N. */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_dngettext (const char *__domainname, const char *__msgid1,
|
|
||||||
const char *__msgid2, unsigned long int __n)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
|
|
||||||
static inline char *dngettext (const char *__domainname, const char *__msgid1,
|
|
||||||
const char *__msgid2, unsigned long int __n)
|
|
||||||
{
|
|
||||||
return libintl_dngettext (__domainname, __msgid1, __msgid2, __n);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define dngettext libintl_dngettext
|
|
||||||
#endif
|
|
||||||
extern char *dngettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n)
|
|
||||||
_INTL_ASM (libintl_dngettext)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Similar to `dcgettext' but select the plural form corresponding to the
|
|
||||||
number N. */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_dcngettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n, int __category)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
|
|
||||||
static inline char *dcngettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n, int __category)
|
|
||||||
{
|
|
||||||
return libintl_dcngettext (__domainname, __msgid1, __msgid2, __n, __category);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define dcngettext libintl_dcngettext
|
|
||||||
#endif
|
|
||||||
extern char *dcngettext (const char *__domainname,
|
|
||||||
const char *__msgid1, const char *__msgid2,
|
|
||||||
unsigned long int __n, int __category)
|
|
||||||
_INTL_ASM (libintl_dcngettext)
|
|
||||||
_INTL_MAY_RETURN_STRING_ARG (2) _INTL_MAY_RETURN_STRING_ARG (3);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef IN_LIBGLOCALE
|
|
||||||
|
|
||||||
/* Set the current default message catalog to DOMAINNAME.
|
|
||||||
If DOMAINNAME is null, return the current default.
|
|
||||||
If DOMAINNAME is "", reset to the default of "messages". */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_textdomain (const char *__domainname);
|
|
||||||
static inline char *textdomain (const char *__domainname)
|
|
||||||
{
|
|
||||||
return libintl_textdomain (__domainname);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define textdomain libintl_textdomain
|
|
||||||
#endif
|
|
||||||
extern char *textdomain (const char *__domainname)
|
|
||||||
_INTL_ASM (libintl_textdomain);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Specify that the DOMAINNAME message catalog will be found
|
|
||||||
in DIRNAME rather than in the system locale data base. */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_bindtextdomain (const char *__domainname,
|
|
||||||
const char *__dirname);
|
|
||||||
static inline char *bindtextdomain (const char *__domainname,
|
|
||||||
const char *__dirname)
|
|
||||||
{
|
|
||||||
return libintl_bindtextdomain (__domainname, __dirname);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define bindtextdomain libintl_bindtextdomain
|
|
||||||
#endif
|
|
||||||
extern char *bindtextdomain (const char *__domainname, const char *__dirname)
|
|
||||||
_INTL_ASM (libintl_bindtextdomain);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Specify the character encoding in which the messages from the
|
|
||||||
DOMAINNAME message catalog will be returned. */
|
|
||||||
#ifdef _INTL_REDIRECT_INLINE
|
|
||||||
extern char *libintl_bind_textdomain_codeset (const char *__domainname,
|
|
||||||
const char *__codeset);
|
|
||||||
static inline char *bind_textdomain_codeset (const char *__domainname,
|
|
||||||
const char *__codeset)
|
|
||||||
{
|
|
||||||
return libintl_bind_textdomain_codeset (__domainname, __codeset);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#ifdef _INTL_REDIRECT_MACROS
|
|
||||||
# define bind_textdomain_codeset libintl_bind_textdomain_codeset
|
|
||||||
#endif
|
|
||||||
extern char *bind_textdomain_codeset (const char *__domainname,
|
|
||||||
const char *__codeset)
|
|
||||||
_INTL_ASM (libintl_bind_textdomain_codeset);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* IN_LIBGLOCALE */
|
|
||||||
|
|
||||||
|
|
||||||
/* Support for format strings with positions in *printf(), following the
|
|
||||||
POSIX/XSI specification.
|
|
||||||
Note: These replacements for the *printf() functions are visible only
|
|
||||||
in source files that #include <libintl.h> or #include "gettext.h".
|
|
||||||
Packages that use *printf() in source files that don't refer to _()
|
|
||||||
or gettext() but for which the format string could be the return value
|
|
||||||
of _() or gettext() need to add this #include. Oh well. */
|
|
||||||
|
|
||||||
#if !@HAVE_POSIX_PRINTF@
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stddef.h>
|
|
||||||
|
|
||||||
/* Get va_list. */
|
|
||||||
#if __STDC__ || defined __cplusplus || defined _MSC_VER
|
|
||||||
# include <stdarg.h>
|
|
||||||
#else
|
|
||||||
# include <varargs.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#undef fprintf
|
|
||||||
#define fprintf libintl_fprintf
|
|
||||||
extern int fprintf (FILE *, const char *, ...);
|
|
||||||
#undef vfprintf
|
|
||||||
#define vfprintf libintl_vfprintf
|
|
||||||
extern int vfprintf (FILE *, const char *, va_list);
|
|
||||||
|
|
||||||
#undef printf
|
|
||||||
#if defined __NetBSD__ || defined __BEOS__ || defined __CYGWIN__ || defined __MINGW32__
|
|
||||||
/* Don't break __attribute__((format(printf,M,N))).
|
|
||||||
This redefinition is only possible because the libc in NetBSD, Cygwin,
|
|
||||||
mingw does not have a function __printf__. */
|
|
||||||
# define libintl_printf __printf__
|
|
||||||
#endif
|
|
||||||
#define printf libintl_printf
|
|
||||||
extern int printf (const char *, ...);
|
|
||||||
#undef vprintf
|
|
||||||
#define vprintf libintl_vprintf
|
|
||||||
extern int vprintf (const char *, va_list);
|
|
||||||
|
|
||||||
#undef sprintf
|
|
||||||
#define sprintf libintl_sprintf
|
|
||||||
extern int sprintf (char *, const char *, ...);
|
|
||||||
#undef vsprintf
|
|
||||||
#define vsprintf libintl_vsprintf
|
|
||||||
extern int vsprintf (char *, const char *, va_list);
|
|
||||||
|
|
||||||
#if @HAVE_SNPRINTF@
|
|
||||||
|
|
||||||
#undef snprintf
|
|
||||||
#define snprintf libintl_snprintf
|
|
||||||
extern int snprintf (char *, size_t, const char *, ...);
|
|
||||||
#undef vsnprintf
|
|
||||||
#define vsnprintf libintl_vsnprintf
|
|
||||||
extern int vsnprintf (char *, size_t, const char *, va_list);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if @HAVE_ASPRINTF@
|
|
||||||
|
|
||||||
#undef asprintf
|
|
||||||
#define asprintf libintl_asprintf
|
|
||||||
extern int asprintf (char **, const char *, ...);
|
|
||||||
#undef vasprintf
|
|
||||||
#define vasprintf libintl_vasprintf
|
|
||||||
extern int vasprintf (char **, const char *, va_list);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if @HAVE_WPRINTF@
|
|
||||||
|
|
||||||
#undef fwprintf
|
|
||||||
#define fwprintf libintl_fwprintf
|
|
||||||
extern int fwprintf (FILE *, const wchar_t *, ...);
|
|
||||||
#undef vfwprintf
|
|
||||||
#define vfwprintf libintl_vfwprintf
|
|
||||||
extern int vfwprintf (FILE *, const wchar_t *, va_list);
|
|
||||||
|
|
||||||
#undef wprintf
|
|
||||||
#define wprintf libintl_wprintf
|
|
||||||
extern int wprintf (const wchar_t *, ...);
|
|
||||||
#undef vwprintf
|
|
||||||
#define vwprintf libintl_vwprintf
|
|
||||||
extern int vwprintf (const wchar_t *, va_list);
|
|
||||||
|
|
||||||
#undef swprintf
|
|
||||||
#define swprintf libintl_swprintf
|
|
||||||
extern int swprintf (wchar_t *, size_t, const wchar_t *, ...);
|
|
||||||
#undef vswprintf
|
|
||||||
#define vswprintf libintl_vswprintf
|
|
||||||
extern int vswprintf (wchar_t *, size_t, const wchar_t *, va_list);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Support for relocatable packages. */
|
|
||||||
|
|
||||||
/* Sets the original and the current installation prefix of the package.
|
|
||||||
Relocation simply replaces a pathname starting with the original prefix
|
|
||||||
by the corresponding pathname with the current prefix instead. Both
|
|
||||||
prefixes should be directory names without trailing slash (i.e. use ""
|
|
||||||
instead of "/"). */
|
|
||||||
#define libintl_set_relocation_prefix libintl_set_relocation_prefix
|
|
||||||
extern void
|
|
||||||
libintl_set_relocation_prefix (const char *orig_prefix,
|
|
||||||
const char *curr_prefix);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* libintl.h */
|
|
|
@ -1,38 +0,0 @@
|
||||||
/* Resources for intl.dll */
|
|
||||||
|
|
||||||
#include <winver.h>
|
|
||||||
|
|
||||||
VS_VERSION_INFO VERSIONINFO
|
|
||||||
FILEVERSION PACKAGE_VERSION_MAJOR,PACKAGE_VERSION_MINOR,PACKAGE_VERSION_SUBMINOR,0
|
|
||||||
PRODUCTVERSION PACKAGE_VERSION_MAJOR,PACKAGE_VERSION_MINOR,PACKAGE_VERSION_SUBMINOR,0
|
|
||||||
FILEFLAGSMASK 0x3fL /* VS_FFI_FILEFLAGSMASK */
|
|
||||||
#ifdef _DEBUG
|
|
||||||
FILEFLAGS 0x1L /* VS_FF_DEBUG */
|
|
||||||
#else
|
|
||||||
FILEFLAGS 0x0L
|
|
||||||
#endif
|
|
||||||
FILEOS 0x10004L /* VOS_DOS_WINDOWS32 */
|
|
||||||
FILETYPE 0x2L /* VFT_DLL */
|
|
||||||
FILESUBTYPE 0x0L /* VFT2_UNKNOWN */
|
|
||||||
BEGIN
|
|
||||||
BLOCK "StringFileInfo"
|
|
||||||
BEGIN
|
|
||||||
BLOCK "04090000" /* Lang = US English, Charset = ASCII */
|
|
||||||
BEGIN
|
|
||||||
VALUE "Comments", "This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License. You should have received a copy of the GNU Library General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA\0"
|
|
||||||
VALUE "CompanyName", "Free Software Foundation\0"
|
|
||||||
VALUE "FileDescription", "LGPLed libintl for Windows NT/2000/XP/Vista and Windows 95/98/ME\0"
|
|
||||||
VALUE "FileVersion", PACKAGE_VERSION_STRING "\0"
|
|
||||||
VALUE "InternalName", "intl.dll\0"
|
|
||||||
VALUE "LegalCopyright", "Copyright (C) 1995-2007\0"
|
|
||||||
VALUE "LegalTrademarks", "\0"
|
|
||||||
VALUE "OriginalFilename", "intl.dll\0"
|
|
||||||
VALUE "ProductName", "libintl: accessing NLS message catalogs\0"
|
|
||||||
VALUE "ProductVersion", PACKAGE_VERSION_STRING "\0"
|
|
||||||
END
|
|
||||||
END
|
|
||||||
BLOCK "VarFileInfo"
|
|
||||||
BEGIN
|
|
||||||
VALUE "Translation", 0x0409, 0 /* US English, ASCII */
|
|
||||||
END
|
|
||||||
END
|
|
|
@ -1,132 +0,0 @@
|
||||||
/* Copyright (C) 1996-1999, 2000-2003, 2005-2006 Free Software Foundation, Inc.
|
|
||||||
This file is part of the GNU C Library.
|
|
||||||
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifndef _LOADINFO_H
|
|
||||||
#define _LOADINFO_H 1
|
|
||||||
|
|
||||||
/* Declarations of locale dependent catalog lookup functions.
|
|
||||||
Implemented in
|
|
||||||
|
|
||||||
localealias.c Possibly replace a locale name by another.
|
|
||||||
explodename.c Split a locale name into its various fields.
|
|
||||||
l10nflist.c Generate a list of filenames of possible message catalogs.
|
|
||||||
finddomain.c Find and open the relevant message catalogs.
|
|
||||||
|
|
||||||
The main function _nl_find_domain() in finddomain.c is declared
|
|
||||||
in gettextP.h.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef internal_function
|
|
||||||
# define internal_function
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef LIBINTL_DLL_EXPORTED
|
|
||||||
# define LIBINTL_DLL_EXPORTED
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Tell the compiler when a conditional or integer expression is
|
|
||||||
almost always true or almost always false. */
|
|
||||||
#ifndef HAVE_BUILTIN_EXPECT
|
|
||||||
# define __builtin_expect(expr, val) (expr)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Separator in PATH like lists of pathnames. */
|
|
||||||
#if ((defined _WIN32 || defined __WIN32__) && !defined __CYGWIN__) || defined __EMX__ || defined __DJGPP__
|
|
||||||
/* Win32, OS/2, DOS */
|
|
||||||
# define PATH_SEPARATOR ';'
|
|
||||||
#else
|
|
||||||
/* Unix */
|
|
||||||
# define PATH_SEPARATOR ':'
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Encoding of locale name parts. */
|
|
||||||
#define XPG_NORM_CODESET 1
|
|
||||||
#define XPG_CODESET 2
|
|
||||||
#define XPG_TERRITORY 4
|
|
||||||
#define XPG_MODIFIER 8
|
|
||||||
|
|
||||||
|
|
||||||
struct loaded_l10nfile
|
|
||||||
{
|
|
||||||
const char *filename;
|
|
||||||
int decided;
|
|
||||||
|
|
||||||
const void *data;
|
|
||||||
|
|
||||||
struct loaded_l10nfile *next;
|
|
||||||
struct loaded_l10nfile *successor[1];
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/* Normalize codeset name. There is no standard for the codeset
|
|
||||||
names. Normalization allows the user to use any of the common
|
|
||||||
names. The return value is dynamically allocated and has to be
|
|
||||||
freed by the caller. */
|
|
||||||
extern const char *_nl_normalize_codeset (const char *codeset,
|
|
||||||
size_t name_len);
|
|
||||||
|
|
||||||
/* Lookup a locale dependent file.
|
|
||||||
*L10NFILE_LIST denotes a pool of lookup results of locale dependent
|
|
||||||
files of the same kind, sorted in decreasing order of ->filename.
|
|
||||||
DIRLIST and DIRLIST_LEN are an argz list of directories in which to
|
|
||||||
look, containing at least one directory (i.e. DIRLIST_LEN > 0).
|
|
||||||
MASK, LANGUAGE, TERRITORY, CODESET, NORMALIZED_CODESET, MODIFIER
|
|
||||||
are the pieces of the locale name, as produced by _nl_explode_name().
|
|
||||||
FILENAME is the filename suffix.
|
|
||||||
The return value is the lookup result, either found in *L10NFILE_LIST,
|
|
||||||
or - if DO_ALLOCATE is nonzero - freshly allocated, or possibly NULL.
|
|
||||||
If the return value is non-NULL, it is added to *L10NFILE_LIST, and
|
|
||||||
its ->next field denotes the chaining inside *L10NFILE_LIST, and
|
|
||||||
furthermore its ->successor[] field contains a list of other lookup
|
|
||||||
results from which this lookup result inherits. */
|
|
||||||
extern struct loaded_l10nfile *
|
|
||||||
_nl_make_l10nflist (struct loaded_l10nfile **l10nfile_list,
|
|
||||||
const char *dirlist, size_t dirlist_len, int mask,
|
|
||||||
const char *language, const char *territory,
|
|
||||||
const char *codeset, const char *normalized_codeset,
|
|
||||||
const char *modifier,
|
|
||||||
const char *filename, int do_allocate);
|
|
||||||
|
|
||||||
/* Lookup the real locale name for a locale alias NAME, or NULL if
|
|
||||||
NAME is not a locale alias (but possibly a real locale name).
|
|
||||||
The return value is statically allocated and must not be freed. */
|
|
||||||
/* Part of the libintl ABI only for the sake of the gettext.m4 macro. */
|
|
||||||
extern LIBINTL_DLL_EXPORTED const char *_nl_expand_alias (const char *name);
|
|
||||||
|
|
||||||
/* Split a locale name NAME into its pieces: language, modifier,
|
|
||||||
territory, codeset.
|
|
||||||
NAME gets destructively modified: NUL bytes are inserted here and
|
|
||||||
there. *LANGUAGE gets assigned NAME. Each of *MODIFIER, *TERRITORY,
|
|
||||||
*CODESET gets assigned either a pointer into the old NAME string, or
|
|
||||||
NULL. *NORMALIZED_CODESET gets assigned the expanded *CODESET, if it
|
|
||||||
is different from *CODESET; this one is dynamically allocated and has
|
|
||||||
to be freed by the caller.
|
|
||||||
The return value is a bitmask, where each bit corresponds to one
|
|
||||||
filled-in value:
|
|
||||||
XPG_MODIFIER for *MODIFIER,
|
|
||||||
XPG_TERRITORY for *TERRITORY,
|
|
||||||
XPG_CODESET for *CODESET,
|
|
||||||
XPG_NORM_CODESET for *NORMALIZED_CODESET.
|
|
||||||
*/
|
|
||||||
extern int _nl_explode_name (char *name, const char **language,
|
|
||||||
const char **modifier, const char **territory,
|
|
||||||
const char **codeset,
|
|
||||||
const char **normalized_codeset);
|
|
||||||
|
|
||||||
#endif /* loadinfo.h */
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,461 +0,0 @@
|
||||||
/* Determine a canonical name for the current locale's character encoding.
|
|
||||||
|
|
||||||
Copyright (C) 2000-2006 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* Written by Bruno Haible <bruno@clisp.org>. */
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
|
|
||||||
/* Specification. */
|
|
||||||
#include "localcharset.h"
|
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
#if defined _WIN32 || defined __WIN32__
|
|
||||||
# define WIN32_NATIVE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined __EMX__
|
|
||||||
/* Assume EMX program runs on OS/2, even if compiled under DOS. */
|
|
||||||
# define OS2
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined WIN32_NATIVE
|
|
||||||
# if HAVE_LANGINFO_CODESET
|
|
||||||
# include <langinfo.h>
|
|
||||||
# else
|
|
||||||
# if 0 /* see comment below */
|
|
||||||
# include <locale.h>
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# ifdef __CYGWIN__
|
|
||||||
# define WIN32_LEAN_AND_MEAN
|
|
||||||
# include <windows.h>
|
|
||||||
# endif
|
|
||||||
#elif defined WIN32_NATIVE
|
|
||||||
# define WIN32_LEAN_AND_MEAN
|
|
||||||
# include <windows.h>
|
|
||||||
#endif
|
|
||||||
#if defined OS2
|
|
||||||
# define INCL_DOS
|
|
||||||
# include <os2.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if ENABLE_RELOCATABLE
|
|
||||||
# include "relocatable.h"
|
|
||||||
#else
|
|
||||||
# define relocate(pathname) (pathname)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Get LIBDIR. */
|
|
||||||
#ifndef LIBDIR
|
|
||||||
# include "configmake.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined _WIN32 || defined __WIN32__ || defined __CYGWIN__ || defined __EMX__ || defined __DJGPP__
|
|
||||||
/* Win32, Cygwin, OS/2, DOS */
|
|
||||||
# define ISSLASH(C) ((C) == '/' || (C) == '\\')
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef DIRECTORY_SEPARATOR
|
|
||||||
# define DIRECTORY_SEPARATOR '/'
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef ISSLASH
|
|
||||||
# define ISSLASH(C) ((C) == DIRECTORY_SEPARATOR)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if HAVE_DECL_GETC_UNLOCKED
|
|
||||||
# undef getc
|
|
||||||
# define getc getc_unlocked
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* The following static variable is declared 'volatile' to avoid a
|
|
||||||
possible multithread problem in the function get_charset_aliases. If we
|
|
||||||
are running in a threaded environment, and if two threads initialize
|
|
||||||
'charset_aliases' simultaneously, both will produce the same value,
|
|
||||||
and everything will be ok if the two assignments to 'charset_aliases'
|
|
||||||
are atomic. But I don't know what will happen if the two assignments mix. */
|
|
||||||
#if __STDC__ != 1
|
|
||||||
# define volatile /* empty */
|
|
||||||
#endif
|
|
||||||
/* Pointer to the contents of the charset.alias file, if it has already been
|
|
||||||
read, else NULL. Its format is:
|
|
||||||
ALIAS_1 '\0' CANONICAL_1 '\0' ... ALIAS_n '\0' CANONICAL_n '\0' '\0' */
|
|
||||||
static const char * volatile charset_aliases;
|
|
||||||
|
|
||||||
/* Return a pointer to the contents of the charset.alias file. */
|
|
||||||
static const char *
|
|
||||||
get_charset_aliases (void)
|
|
||||||
{
|
|
||||||
const char *cp;
|
|
||||||
|
|
||||||
cp = charset_aliases;
|
|
||||||
if (cp == NULL)
|
|
||||||
{
|
|
||||||
#if !(defined VMS || defined WIN32_NATIVE || defined __CYGWIN__)
|
|
||||||
FILE *fp;
|
|
||||||
const char *dir;
|
|
||||||
const char *base = "charset.alias";
|
|
||||||
char *file_name;
|
|
||||||
|
|
||||||
/* Make it possible to override the charset.alias location. This is
|
|
||||||
necessary for running the testsuite before "make install". */
|
|
||||||
dir = getenv ("CHARSETALIASDIR");
|
|
||||||
if (dir == NULL || dir[0] == '\0')
|
|
||||||
dir = relocate (LIBDIR);
|
|
||||||
|
|
||||||
/* Concatenate dir and base into freshly allocated file_name. */
|
|
||||||
{
|
|
||||||
size_t dir_len = strlen (dir);
|
|
||||||
size_t base_len = strlen (base);
|
|
||||||
int add_slash = (dir_len > 0 && !ISSLASH (dir[dir_len - 1]));
|
|
||||||
file_name = (char *) malloc (dir_len + add_slash + base_len + 1);
|
|
||||||
if (file_name != NULL)
|
|
||||||
{
|
|
||||||
memcpy (file_name, dir, dir_len);
|
|
||||||
if (add_slash)
|
|
||||||
file_name[dir_len] = DIRECTORY_SEPARATOR;
|
|
||||||
memcpy (file_name + dir_len + add_slash, base, base_len + 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (file_name == NULL || (fp = fopen (file_name, "r")) == NULL)
|
|
||||||
/* Out of memory or file not found, treat it as empty. */
|
|
||||||
cp = "";
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Parse the file's contents. */
|
|
||||||
char *res_ptr = NULL;
|
|
||||||
size_t res_size = 0;
|
|
||||||
|
|
||||||
for (;;)
|
|
||||||
{
|
|
||||||
int c;
|
|
||||||
char buf1[50+1];
|
|
||||||
char buf2[50+1];
|
|
||||||
size_t l1, l2;
|
|
||||||
char *old_res_ptr;
|
|
||||||
|
|
||||||
c = getc (fp);
|
|
||||||
if (c == EOF)
|
|
||||||
break;
|
|
||||||
if (c == '\n' || c == ' ' || c == '\t')
|
|
||||||
continue;
|
|
||||||
if (c == '#')
|
|
||||||
{
|
|
||||||
/* Skip comment, to end of line. */
|
|
||||||
do
|
|
||||||
c = getc (fp);
|
|
||||||
while (!(c == EOF || c == '\n'));
|
|
||||||
if (c == EOF)
|
|
||||||
break;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
ungetc (c, fp);
|
|
||||||
if (fscanf (fp, "%50s %50s", buf1, buf2) < 2)
|
|
||||||
break;
|
|
||||||
l1 = strlen (buf1);
|
|
||||||
l2 = strlen (buf2);
|
|
||||||
old_res_ptr = res_ptr;
|
|
||||||
if (res_size == 0)
|
|
||||||
{
|
|
||||||
res_size = l1 + 1 + l2 + 1;
|
|
||||||
res_ptr = (char *) malloc (res_size + 1);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
res_size += l1 + 1 + l2 + 1;
|
|
||||||
res_ptr = (char *) realloc (res_ptr, res_size + 1);
|
|
||||||
}
|
|
||||||
if (res_ptr == NULL)
|
|
||||||
{
|
|
||||||
/* Out of memory. */
|
|
||||||
res_size = 0;
|
|
||||||
if (old_res_ptr != NULL)
|
|
||||||
free (old_res_ptr);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
strcpy (res_ptr + res_size - (l2 + 1) - (l1 + 1), buf1);
|
|
||||||
strcpy (res_ptr + res_size - (l2 + 1), buf2);
|
|
||||||
}
|
|
||||||
fclose (fp);
|
|
||||||
if (res_size == 0)
|
|
||||||
cp = "";
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*(res_ptr + res_size) = '\0';
|
|
||||||
cp = res_ptr;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (file_name != NULL)
|
|
||||||
free (file_name);
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
# if defined VMS
|
|
||||||
/* To avoid the troubles of an extra file charset.alias_vms in the
|
|
||||||
sources of many GNU packages, simply inline the aliases here. */
|
|
||||||
/* The list of encodings is taken from the OpenVMS 7.3-1 documentation
|
|
||||||
"Compaq C Run-Time Library Reference Manual for OpenVMS systems"
|
|
||||||
section 10.7 "Handling Different Character Sets". */
|
|
||||||
cp = "ISO8859-1" "\0" "ISO-8859-1" "\0"
|
|
||||||
"ISO8859-2" "\0" "ISO-8859-2" "\0"
|
|
||||||
"ISO8859-5" "\0" "ISO-8859-5" "\0"
|
|
||||||
"ISO8859-7" "\0" "ISO-8859-7" "\0"
|
|
||||||
"ISO8859-8" "\0" "ISO-8859-8" "\0"
|
|
||||||
"ISO8859-9" "\0" "ISO-8859-9" "\0"
|
|
||||||
/* Japanese */
|
|
||||||
"eucJP" "\0" "EUC-JP" "\0"
|
|
||||||
"SJIS" "\0" "SHIFT_JIS" "\0"
|
|
||||||
"DECKANJI" "\0" "DEC-KANJI" "\0"
|
|
||||||
"SDECKANJI" "\0" "EUC-JP" "\0"
|
|
||||||
/* Chinese */
|
|
||||||
"eucTW" "\0" "EUC-TW" "\0"
|
|
||||||
"DECHANYU" "\0" "DEC-HANYU" "\0"
|
|
||||||
"DECHANZI" "\0" "GB2312" "\0"
|
|
||||||
/* Korean */
|
|
||||||
"DECKOREAN" "\0" "EUC-KR" "\0";
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# if defined WIN32_NATIVE || defined __CYGWIN__
|
|
||||||
/* To avoid the troubles of installing a separate file in the same
|
|
||||||
directory as the DLL and of retrieving the DLL's directory at
|
|
||||||
runtime, simply inline the aliases here. */
|
|
||||||
|
|
||||||
cp = "CP936" "\0" "GBK" "\0"
|
|
||||||
"CP1361" "\0" "JOHAB" "\0"
|
|
||||||
"CP20127" "\0" "ASCII" "\0"
|
|
||||||
"CP20866" "\0" "KOI8-R" "\0"
|
|
||||||
"CP20936" "\0" "GB2312" "\0"
|
|
||||||
"CP21866" "\0" "KOI8-RU" "\0"
|
|
||||||
"CP28591" "\0" "ISO-8859-1" "\0"
|
|
||||||
"CP28592" "\0" "ISO-8859-2" "\0"
|
|
||||||
"CP28593" "\0" "ISO-8859-3" "\0"
|
|
||||||
"CP28594" "\0" "ISO-8859-4" "\0"
|
|
||||||
"CP28595" "\0" "ISO-8859-5" "\0"
|
|
||||||
"CP28596" "\0" "ISO-8859-6" "\0"
|
|
||||||
"CP28597" "\0" "ISO-8859-7" "\0"
|
|
||||||
"CP28598" "\0" "ISO-8859-8" "\0"
|
|
||||||
"CP28599" "\0" "ISO-8859-9" "\0"
|
|
||||||
"CP28605" "\0" "ISO-8859-15" "\0"
|
|
||||||
"CP38598" "\0" "ISO-8859-8" "\0"
|
|
||||||
"CP51932" "\0" "EUC-JP" "\0"
|
|
||||||
"CP51936" "\0" "GB2312" "\0"
|
|
||||||
"CP51949" "\0" "EUC-KR" "\0"
|
|
||||||
"CP51950" "\0" "EUC-TW" "\0"
|
|
||||||
"CP54936" "\0" "GB18030" "\0"
|
|
||||||
"CP65001" "\0" "UTF-8" "\0";
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
charset_aliases = cp;
|
|
||||||
}
|
|
||||||
|
|
||||||
return cp;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Determine the current locale's character encoding, and canonicalize it
|
|
||||||
into one of the canonical names listed in config.charset.
|
|
||||||
The result must not be freed; it is statically allocated.
|
|
||||||
If the canonical name cannot be determined, the result is a non-canonical
|
|
||||||
name. */
|
|
||||||
|
|
||||||
#ifdef STATIC
|
|
||||||
STATIC
|
|
||||||
#endif
|
|
||||||
const char *
|
|
||||||
locale_charset (void)
|
|
||||||
{
|
|
||||||
const char *codeset;
|
|
||||||
const char *aliases;
|
|
||||||
|
|
||||||
#if !(defined WIN32_NATIVE || defined OS2)
|
|
||||||
|
|
||||||
# if HAVE_LANGINFO_CODESET
|
|
||||||
|
|
||||||
/* Most systems support nl_langinfo (CODESET) nowadays. */
|
|
||||||
codeset = nl_langinfo (CODESET);
|
|
||||||
|
|
||||||
# ifdef __CYGWIN__
|
|
||||||
/* Cygwin 2006 does not have locales. nl_langinfo (CODESET) always
|
|
||||||
returns "US-ASCII". As long as this is not fixed, return the suffix
|
|
||||||
of the locale name from the environment variables (if present) or
|
|
||||||
the codepage as a number. */
|
|
||||||
if (codeset != NULL && strcmp (codeset, "US-ASCII") == 0)
|
|
||||||
{
|
|
||||||
const char *locale;
|
|
||||||
static char buf[2 + 10 + 1];
|
|
||||||
|
|
||||||
locale = getenv ("LC_ALL");
|
|
||||||
if (locale == NULL || locale[0] == '\0')
|
|
||||||
{
|
|
||||||
locale = getenv ("LC_CTYPE");
|
|
||||||
if (locale == NULL || locale[0] == '\0')
|
|
||||||
locale = getenv ("LANG");
|
|
||||||
}
|
|
||||||
if (locale != NULL && locale[0] != '\0')
|
|
||||||
{
|
|
||||||
/* If the locale name contains an encoding after the dot, return
|
|
||||||
it. */
|
|
||||||
const char *dot = strchr (locale, '.');
|
|
||||||
|
|
||||||
if (dot != NULL)
|
|
||||||
{
|
|
||||||
const char *modifier;
|
|
||||||
|
|
||||||
dot++;
|
|
||||||
/* Look for the possible @... trailer and remove it, if any. */
|
|
||||||
modifier = strchr (dot, '@');
|
|
||||||
if (modifier == NULL)
|
|
||||||
return dot;
|
|
||||||
if (modifier - dot < sizeof (buf))
|
|
||||||
{
|
|
||||||
memcpy (buf, dot, modifier - dot);
|
|
||||||
buf [modifier - dot] = '\0';
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Woe32 has a function returning the locale's codepage as a number. */
|
|
||||||
sprintf (buf, "CP%u", GetACP ());
|
|
||||||
codeset = buf;
|
|
||||||
}
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# else
|
|
||||||
|
|
||||||
/* On old systems which lack it, use setlocale or getenv. */
|
|
||||||
const char *locale = NULL;
|
|
||||||
|
|
||||||
/* But most old systems don't have a complete set of locales. Some
|
|
||||||
(like SunOS 4 or DJGPP) have only the C locale. Therefore we don't
|
|
||||||
use setlocale here; it would return "C" when it doesn't support the
|
|
||||||
locale name the user has set. */
|
|
||||||
# if 0
|
|
||||||
locale = setlocale (LC_CTYPE, NULL);
|
|
||||||
# endif
|
|
||||||
if (locale == NULL || locale[0] == '\0')
|
|
||||||
{
|
|
||||||
locale = getenv ("LC_ALL");
|
|
||||||
if (locale == NULL || locale[0] == '\0')
|
|
||||||
{
|
|
||||||
locale = getenv ("LC_CTYPE");
|
|
||||||
if (locale == NULL || locale[0] == '\0')
|
|
||||||
locale = getenv ("LANG");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* On some old systems, one used to set locale = "iso8859_1". On others,
|
|
||||||
you set it to "language_COUNTRY.charset". In any case, we resolve it
|
|
||||||
through the charset.alias file. */
|
|
||||||
codeset = locale;
|
|
||||||
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#elif defined WIN32_NATIVE
|
|
||||||
|
|
||||||
static char buf[2 + 10 + 1];
|
|
||||||
|
|
||||||
/* Woe32 has a function returning the locale's codepage as a number. */
|
|
||||||
sprintf (buf, "CP%u", GetACP ());
|
|
||||||
codeset = buf;
|
|
||||||
|
|
||||||
#elif defined OS2
|
|
||||||
|
|
||||||
const char *locale;
|
|
||||||
static char buf[2 + 10 + 1];
|
|
||||||
ULONG cp[3];
|
|
||||||
ULONG cplen;
|
|
||||||
|
|
||||||
/* Allow user to override the codeset, as set in the operating system,
|
|
||||||
with standard language environment variables. */
|
|
||||||
locale = getenv ("LC_ALL");
|
|
||||||
if (locale == NULL || locale[0] == '\0')
|
|
||||||
{
|
|
||||||
locale = getenv ("LC_CTYPE");
|
|
||||||
if (locale == NULL || locale[0] == '\0')
|
|
||||||
locale = getenv ("LANG");
|
|
||||||
}
|
|
||||||
if (locale != NULL && locale[0] != '\0')
|
|
||||||
{
|
|
||||||
/* If the locale name contains an encoding after the dot, return it. */
|
|
||||||
const char *dot = strchr (locale, '.');
|
|
||||||
|
|
||||||
if (dot != NULL)
|
|
||||||
{
|
|
||||||
const char *modifier;
|
|
||||||
|
|
||||||
dot++;
|
|
||||||
/* Look for the possible @... trailer and remove it, if any. */
|
|
||||||
modifier = strchr (dot, '@');
|
|
||||||
if (modifier == NULL)
|
|
||||||
return dot;
|
|
||||||
if (modifier - dot < sizeof (buf))
|
|
||||||
{
|
|
||||||
memcpy (buf, dot, modifier - dot);
|
|
||||||
buf [modifier - dot] = '\0';
|
|
||||||
return buf;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Resolve through the charset.alias file. */
|
|
||||||
codeset = locale;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* OS/2 has a function returning the locale's codepage as a number. */
|
|
||||||
if (DosQueryCp (sizeof (cp), cp, &cplen))
|
|
||||||
codeset = "";
|
|
||||||
else
|
|
||||||
{
|
|
||||||
sprintf (buf, "CP%u", cp[0]);
|
|
||||||
codeset = buf;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (codeset == NULL)
|
|
||||||
/* The canonical name cannot be determined. */
|
|
||||||
codeset = "";
|
|
||||||
|
|
||||||
/* Resolve alias. */
|
|
||||||
for (aliases = get_charset_aliases ();
|
|
||||||
*aliases != '\0';
|
|
||||||
aliases += strlen (aliases) + 1, aliases += strlen (aliases) + 1)
|
|
||||||
if (strcmp (codeset, aliases) == 0
|
|
||||||
|| (aliases[0] == '*' && aliases[1] == '\0'))
|
|
||||||
{
|
|
||||||
codeset = aliases + strlen (aliases) + 1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Don't return an empty string. GNU libc and GNU libiconv interpret
|
|
||||||
the empty string as denoting "the locale's character encoding",
|
|
||||||
thus GNU libiconv would call this function a second time. */
|
|
||||||
if (codeset[0] == '\0')
|
|
||||||
codeset = "ASCII";
|
|
||||||
|
|
||||||
return codeset;
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
/* Determine a canonical name for the current locale's character encoding.
|
|
||||||
Copyright (C) 2000-2003 Free Software Foundation, Inc.
|
|
||||||
This file is part of the GNU CHARSET Library.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
#ifndef _LOCALCHARSET_H
|
|
||||||
#define _LOCALCHARSET_H
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Determine the current locale's character encoding, and canonicalize it
|
|
||||||
into one of the canonical names listed in config.charset.
|
|
||||||
The result must not be freed; it is statically allocated.
|
|
||||||
If the canonical name cannot be determined, the result is a non-canonical
|
|
||||||
name. */
|
|
||||||
extern const char * locale_charset (void);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* _LOCALCHARSET_H */
|
|
|
@ -1,77 +0,0 @@
|
||||||
# Locale name alias data base.
|
|
||||||
# Copyright (C) 1996-2001,2003,2007 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify it
|
|
||||||
# under the terms of the GNU Library General Public License as published
|
|
||||||
# by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
# Library General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU Library General Public
|
|
||||||
# License along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
# USA.
|
|
||||||
|
|
||||||
# The format of this file is the same as for the corresponding file of
|
|
||||||
# the X Window System, which normally can be found in
|
|
||||||
# /usr/lib/X11/locale/locale.alias
|
|
||||||
# A single line contains two fields: an alias and a substitution value.
|
|
||||||
# All entries are case independent.
|
|
||||||
|
|
||||||
# Note: This file is obsolete and is kept around for the time being for
|
|
||||||
# backward compatibility. Nobody should rely on the names defined here.
|
|
||||||
# Locales should always be specified by their full name.
|
|
||||||
|
|
||||||
# Packages using this file:
|
|
||||||
|
|
||||||
bokmal nb_NO.ISO-8859-1
|
|
||||||
bokmål nb_NO.ISO-8859-1
|
|
||||||
catalan ca_ES.ISO-8859-1
|
|
||||||
croatian hr_HR.ISO-8859-2
|
|
||||||
czech cs_CZ.ISO-8859-2
|
|
||||||
danish da_DK.ISO-8859-1
|
|
||||||
dansk da_DK.ISO-8859-1
|
|
||||||
deutsch de_DE.ISO-8859-1
|
|
||||||
dutch nl_NL.ISO-8859-1
|
|
||||||
eesti et_EE.ISO-8859-1
|
|
||||||
estonian et_EE.ISO-8859-1
|
|
||||||
finnish fi_FI.ISO-8859-1
|
|
||||||
français fr_FR.ISO-8859-1
|
|
||||||
french fr_FR.ISO-8859-1
|
|
||||||
galego gl_ES.ISO-8859-1
|
|
||||||
galician gl_ES.ISO-8859-1
|
|
||||||
german de_DE.ISO-8859-1
|
|
||||||
greek el_GR.ISO-8859-7
|
|
||||||
hebrew he_IL.ISO-8859-8
|
|
||||||
hrvatski hr_HR.ISO-8859-2
|
|
||||||
hungarian hu_HU.ISO-8859-2
|
|
||||||
icelandic is_IS.ISO-8859-1
|
|
||||||
italian it_IT.ISO-8859-1
|
|
||||||
japanese ja_JP.eucJP
|
|
||||||
japanese.euc ja_JP.eucJP
|
|
||||||
ja_JP ja_JP.eucJP
|
|
||||||
ja_JP.ujis ja_JP.eucJP
|
|
||||||
japanese.sjis ja_JP.SJIS
|
|
||||||
korean ko_KR.eucKR
|
|
||||||
korean.euc ko_KR.eucKR
|
|
||||||
ko_KR ko_KR.eucKR
|
|
||||||
lithuanian lt_LT.ISO-8859-13
|
|
||||||
no_NO nb_NO.ISO-8859-1
|
|
||||||
no_NO.ISO-8859-1 nb_NO.ISO-8859-1
|
|
||||||
norwegian nb_NO.ISO-8859-1
|
|
||||||
nynorsk nn_NO.ISO-8859-1
|
|
||||||
polish pl_PL.ISO-8859-2
|
|
||||||
portuguese pt_PT.ISO-8859-1
|
|
||||||
romanian ro_RO.ISO-8859-2
|
|
||||||
russian ru_RU.ISO-8859-5
|
|
||||||
slovak sk_SK.ISO-8859-2
|
|
||||||
slovene sl_SI.ISO-8859-2
|
|
||||||
slovenian sl_SI.ISO-8859-2
|
|
||||||
spanish es_ES.ISO-8859-1
|
|
||||||
swedish sv_SE.ISO-8859-1
|
|
||||||
thai th_TH.TIS-620
|
|
||||||
turkish tr_TR.ISO-8859-9
|
|
|
@ -1,439 +0,0 @@
|
||||||
/* Handle aliases for locale names.
|
|
||||||
Copyright (C) 1995-1999, 2000-2001, 2003, 2005-2006 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* Tell glibc's <string.h> to provide a prototype for mempcpy().
|
|
||||||
This must come before <config.h> because <config.h> may include
|
|
||||||
<features.h>, and once <features.h> has been included, it's too late. */
|
|
||||||
#ifndef _GNU_SOURCE
|
|
||||||
# define _GNU_SOURCE 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <ctype.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#if defined _LIBC || defined HAVE___FSETLOCKING
|
|
||||||
# include <stdio_ext.h>
|
|
||||||
#endif
|
|
||||||
#include <sys/types.h>
|
|
||||||
|
|
||||||
#ifdef __GNUC__
|
|
||||||
# undef alloca
|
|
||||||
# define alloca __builtin_alloca
|
|
||||||
# define HAVE_ALLOCA 1
|
|
||||||
#else
|
|
||||||
# ifdef _MSC_VER
|
|
||||||
# include <malloc.h>
|
|
||||||
# define alloca _alloca
|
|
||||||
# else
|
|
||||||
# if defined HAVE_ALLOCA_H || defined _LIBC
|
|
||||||
# include <alloca.h>
|
|
||||||
# else
|
|
||||||
# ifdef _AIX
|
|
||||||
#pragma alloca
|
|
||||||
# else
|
|
||||||
# ifndef alloca
|
|
||||||
char *alloca ();
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include "gettextP.h"
|
|
||||||
|
|
||||||
#if ENABLE_RELOCATABLE
|
|
||||||
# include "relocatable.h"
|
|
||||||
#else
|
|
||||||
# define relocate(pathname) (pathname)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* @@ end of prolog @@ */
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Rename the non ANSI C functions. This is required by the standard
|
|
||||||
because some ANSI C functions will require linking with this object
|
|
||||||
file and the name space must not be polluted. */
|
|
||||||
# define strcasecmp __strcasecmp
|
|
||||||
|
|
||||||
# ifndef mempcpy
|
|
||||||
# define mempcpy __mempcpy
|
|
||||||
# endif
|
|
||||||
# define HAVE_MEMPCPY 1
|
|
||||||
# define HAVE___FSETLOCKING 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Handle multi-threaded applications. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <bits/libc-lock.h>
|
|
||||||
#else
|
|
||||||
# include "lock.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef internal_function
|
|
||||||
# define internal_function
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Some optimizations for glibc. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# define FEOF(fp) feof_unlocked (fp)
|
|
||||||
# define FGETS(buf, n, fp) fgets_unlocked (buf, n, fp)
|
|
||||||
#else
|
|
||||||
# define FEOF(fp) feof (fp)
|
|
||||||
# define FGETS(buf, n, fp) fgets (buf, n, fp)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* For those losing systems which don't have `alloca' we have to add
|
|
||||||
some additional code emulating it. */
|
|
||||||
#ifdef HAVE_ALLOCA
|
|
||||||
# define freea(p) /* nothing */
|
|
||||||
#else
|
|
||||||
# define alloca(n) malloc (n)
|
|
||||||
# define freea(p) free (p)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined _LIBC_REENTRANT || HAVE_DECL_FGETS_UNLOCKED
|
|
||||||
# undef fgets
|
|
||||||
# define fgets(buf, len, s) fgets_unlocked (buf, len, s)
|
|
||||||
#endif
|
|
||||||
#if defined _LIBC_REENTRANT || HAVE_DECL_FEOF_UNLOCKED
|
|
||||||
# undef feof
|
|
||||||
# define feof(s) feof_unlocked (s)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
__libc_lock_define_initialized (static, lock)
|
|
||||||
|
|
||||||
|
|
||||||
struct alias_map
|
|
||||||
{
|
|
||||||
const char *alias;
|
|
||||||
const char *value;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef _LIBC
|
|
||||||
# define libc_freeres_ptr(decl) decl
|
|
||||||
#endif
|
|
||||||
|
|
||||||
libc_freeres_ptr (static char *string_space);
|
|
||||||
static size_t string_space_act;
|
|
||||||
static size_t string_space_max;
|
|
||||||
libc_freeres_ptr (static struct alias_map *map);
|
|
||||||
static size_t nmap;
|
|
||||||
static size_t maxmap;
|
|
||||||
|
|
||||||
|
|
||||||
/* Prototypes for local functions. */
|
|
||||||
static size_t read_alias_file (const char *fname, int fname_len)
|
|
||||||
internal_function;
|
|
||||||
static int extend_alias_table (void);
|
|
||||||
static int alias_compare (const struct alias_map *map1,
|
|
||||||
const struct alias_map *map2);
|
|
||||||
|
|
||||||
|
|
||||||
const char *
|
|
||||||
_nl_expand_alias (const char *name)
|
|
||||||
{
|
|
||||||
static const char *locale_alias_path;
|
|
||||||
struct alias_map *retval;
|
|
||||||
const char *result = NULL;
|
|
||||||
size_t added;
|
|
||||||
|
|
||||||
__libc_lock_lock (lock);
|
|
||||||
|
|
||||||
if (locale_alias_path == NULL)
|
|
||||||
locale_alias_path = LOCALE_ALIAS_PATH;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
struct alias_map item;
|
|
||||||
|
|
||||||
item.alias = name;
|
|
||||||
|
|
||||||
if (nmap > 0)
|
|
||||||
retval = (struct alias_map *) bsearch (&item, map, nmap,
|
|
||||||
sizeof (struct alias_map),
|
|
||||||
(int (*) (const void *,
|
|
||||||
const void *)
|
|
||||||
) alias_compare);
|
|
||||||
else
|
|
||||||
retval = NULL;
|
|
||||||
|
|
||||||
/* We really found an alias. Return the value. */
|
|
||||||
if (retval != NULL)
|
|
||||||
{
|
|
||||||
result = retval->value;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Perhaps we can find another alias file. */
|
|
||||||
added = 0;
|
|
||||||
while (added == 0 && locale_alias_path[0] != '\0')
|
|
||||||
{
|
|
||||||
const char *start;
|
|
||||||
|
|
||||||
while (locale_alias_path[0] == PATH_SEPARATOR)
|
|
||||||
++locale_alias_path;
|
|
||||||
start = locale_alias_path;
|
|
||||||
|
|
||||||
while (locale_alias_path[0] != '\0'
|
|
||||||
&& locale_alias_path[0] != PATH_SEPARATOR)
|
|
||||||
++locale_alias_path;
|
|
||||||
|
|
||||||
if (start < locale_alias_path)
|
|
||||||
added = read_alias_file (start, locale_alias_path - start);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
while (added != 0);
|
|
||||||
|
|
||||||
__libc_lock_unlock (lock);
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static size_t
|
|
||||||
internal_function
|
|
||||||
read_alias_file (const char *fname, int fname_len)
|
|
||||||
{
|
|
||||||
FILE *fp;
|
|
||||||
char *full_fname;
|
|
||||||
size_t added;
|
|
||||||
static const char aliasfile[] = "/locale.alias";
|
|
||||||
|
|
||||||
full_fname = (char *) alloca (fname_len + sizeof aliasfile);
|
|
||||||
#ifdef HAVE_MEMPCPY
|
|
||||||
mempcpy (mempcpy (full_fname, fname, fname_len),
|
|
||||||
aliasfile, sizeof aliasfile);
|
|
||||||
#else
|
|
||||||
memcpy (full_fname, fname, fname_len);
|
|
||||||
memcpy (&full_fname[fname_len], aliasfile, sizeof aliasfile);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef _LIBC
|
|
||||||
/* Note the file is opened with cancellation in the I/O functions
|
|
||||||
disabled. */
|
|
||||||
fp = fopen (relocate (full_fname), "rc");
|
|
||||||
#else
|
|
||||||
fp = fopen (relocate (full_fname), "r");
|
|
||||||
#endif
|
|
||||||
freea (full_fname);
|
|
||||||
if (fp == NULL)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
#ifdef HAVE___FSETLOCKING
|
|
||||||
/* No threads present. */
|
|
||||||
__fsetlocking (fp, FSETLOCKING_BYCALLER);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
added = 0;
|
|
||||||
while (!FEOF (fp))
|
|
||||||
{
|
|
||||||
/* It is a reasonable approach to use a fix buffer here because
|
|
||||||
a) we are only interested in the first two fields
|
|
||||||
b) these fields must be usable as file names and so must not
|
|
||||||
be that long
|
|
||||||
We avoid a multi-kilobyte buffer here since this would use up
|
|
||||||
stack space which we might not have if the program ran out of
|
|
||||||
memory. */
|
|
||||||
char buf[400];
|
|
||||||
char *alias;
|
|
||||||
char *value;
|
|
||||||
char *cp;
|
|
||||||
int complete_line;
|
|
||||||
|
|
||||||
if (FGETS (buf, sizeof buf, fp) == NULL)
|
|
||||||
/* EOF reached. */
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* Determine whether the line is complete. */
|
|
||||||
complete_line = strchr (buf, '\n') != NULL;
|
|
||||||
|
|
||||||
cp = buf;
|
|
||||||
/* Ignore leading white space. */
|
|
||||||
while (isspace ((unsigned char) cp[0]))
|
|
||||||
++cp;
|
|
||||||
|
|
||||||
/* A leading '#' signals a comment line. */
|
|
||||||
if (cp[0] != '\0' && cp[0] != '#')
|
|
||||||
{
|
|
||||||
alias = cp++;
|
|
||||||
while (cp[0] != '\0' && !isspace ((unsigned char) cp[0]))
|
|
||||||
++cp;
|
|
||||||
/* Terminate alias name. */
|
|
||||||
if (cp[0] != '\0')
|
|
||||||
*cp++ = '\0';
|
|
||||||
|
|
||||||
/* Now look for the beginning of the value. */
|
|
||||||
while (isspace ((unsigned char) cp[0]))
|
|
||||||
++cp;
|
|
||||||
|
|
||||||
if (cp[0] != '\0')
|
|
||||||
{
|
|
||||||
value = cp++;
|
|
||||||
while (cp[0] != '\0' && !isspace ((unsigned char) cp[0]))
|
|
||||||
++cp;
|
|
||||||
/* Terminate value. */
|
|
||||||
if (cp[0] == '\n')
|
|
||||||
{
|
|
||||||
/* This has to be done to make the following test
|
|
||||||
for the end of line possible. We are looking for
|
|
||||||
the terminating '\n' which do not overwrite here. */
|
|
||||||
*cp++ = '\0';
|
|
||||||
*cp = '\n';
|
|
||||||
}
|
|
||||||
else if (cp[0] != '\0')
|
|
||||||
*cp++ = '\0';
|
|
||||||
|
|
||||||
#ifdef IN_LIBGLOCALE
|
|
||||||
/* glibc's locale.alias contains entries for ja_JP and ko_KR
|
|
||||||
that make it impossible to use a Japanese or Korean UTF-8
|
|
||||||
locale under the name "ja_JP" or "ko_KR". Ignore these
|
|
||||||
entries. */
|
|
||||||
if (strchr (alias, '_') == NULL)
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
size_t alias_len;
|
|
||||||
size_t value_len;
|
|
||||||
|
|
||||||
if (nmap >= maxmap)
|
|
||||||
if (__builtin_expect (extend_alias_table (), 0))
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
alias_len = strlen (alias) + 1;
|
|
||||||
value_len = strlen (value) + 1;
|
|
||||||
|
|
||||||
if (string_space_act + alias_len + value_len > string_space_max)
|
|
||||||
{
|
|
||||||
/* Increase size of memory pool. */
|
|
||||||
size_t new_size = (string_space_max
|
|
||||||
+ (alias_len + value_len > 1024
|
|
||||||
? alias_len + value_len : 1024));
|
|
||||||
char *new_pool = (char *) realloc (string_space, new_size);
|
|
||||||
if (new_pool == NULL)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
if (__builtin_expect (string_space != new_pool, 0))
|
|
||||||
{
|
|
||||||
size_t i;
|
|
||||||
|
|
||||||
for (i = 0; i < nmap; i++)
|
|
||||||
{
|
|
||||||
map[i].alias += new_pool - string_space;
|
|
||||||
map[i].value += new_pool - string_space;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
string_space = new_pool;
|
|
||||||
string_space_max = new_size;
|
|
||||||
}
|
|
||||||
|
|
||||||
map[nmap].alias =
|
|
||||||
(const char *) memcpy (&string_space[string_space_act],
|
|
||||||
alias, alias_len);
|
|
||||||
string_space_act += alias_len;
|
|
||||||
|
|
||||||
map[nmap].value =
|
|
||||||
(const char *) memcpy (&string_space[string_space_act],
|
|
||||||
value, value_len);
|
|
||||||
string_space_act += value_len;
|
|
||||||
|
|
||||||
++nmap;
|
|
||||||
++added;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Possibly not the whole line fits into the buffer. Ignore
|
|
||||||
the rest of the line. */
|
|
||||||
if (! complete_line)
|
|
||||||
do
|
|
||||||
if (FGETS (buf, sizeof buf, fp) == NULL)
|
|
||||||
/* Make sure the inner loop will be left. The outer loop
|
|
||||||
will exit at the `feof' test. */
|
|
||||||
break;
|
|
||||||
while (strchr (buf, '\n') == NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
out:
|
|
||||||
/* Should we test for ferror()? I think we have to silently ignore
|
|
||||||
errors. --drepper */
|
|
||||||
fclose (fp);
|
|
||||||
|
|
||||||
if (added > 0)
|
|
||||||
qsort (map, nmap, sizeof (struct alias_map),
|
|
||||||
(int (*) (const void *, const void *)) alias_compare);
|
|
||||||
|
|
||||||
return added;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static int
|
|
||||||
extend_alias_table ()
|
|
||||||
{
|
|
||||||
size_t new_size;
|
|
||||||
struct alias_map *new_map;
|
|
||||||
|
|
||||||
new_size = maxmap == 0 ? 100 : 2 * maxmap;
|
|
||||||
new_map = (struct alias_map *) realloc (map, (new_size
|
|
||||||
* sizeof (struct alias_map)));
|
|
||||||
if (new_map == NULL)
|
|
||||||
/* Simply don't extend: we don't have any more core. */
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
map = new_map;
|
|
||||||
maxmap = new_size;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static int
|
|
||||||
alias_compare (const struct alias_map *map1, const struct alias_map *map2)
|
|
||||||
{
|
|
||||||
#if defined _LIBC || defined HAVE_STRCASECMP
|
|
||||||
return strcasecmp (map1->alias, map2->alias);
|
|
||||||
#else
|
|
||||||
const unsigned char *p1 = (const unsigned char *) map1->alias;
|
|
||||||
const unsigned char *p2 = (const unsigned char *) map2->alias;
|
|
||||||
unsigned char c1, c2;
|
|
||||||
|
|
||||||
if (p1 == p2)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
/* I know this seems to be odd but the tolower() function in
|
|
||||||
some systems libc cannot handle nonalpha characters. */
|
|
||||||
c1 = isupper (*p1) ? tolower (*p1) : *p1;
|
|
||||||
c2 = isupper (*p2) ? tolower (*p2) : *p2;
|
|
||||||
if (c1 == '\0')
|
|
||||||
break;
|
|
||||||
++p1;
|
|
||||||
++p2;
|
|
||||||
}
|
|
||||||
while (c1 == c2);
|
|
||||||
|
|
||||||
return c1 - c2;
|
|
||||||
#endif
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,922 +0,0 @@
|
||||||
/* Locking in multithreaded situations.
|
|
||||||
Copyright (C) 2005-2006 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* Written by Bruno Haible <bruno@clisp.org>, 2005.
|
|
||||||
Based on GCC's gthr-posix.h, gthr-posix95.h, gthr-solaris.h,
|
|
||||||
gthr-win32.h. */
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
|
|
||||||
#include "lock.h"
|
|
||||||
|
|
||||||
/* ========================================================================= */
|
|
||||||
|
|
||||||
#if USE_POSIX_THREADS
|
|
||||||
|
|
||||||
/* Use the POSIX threads library. */
|
|
||||||
|
|
||||||
# if PTHREAD_IN_USE_DETECTION_HARD
|
|
||||||
|
|
||||||
/* The function to be executed by a dummy thread. */
|
|
||||||
static void *
|
|
||||||
dummy_thread_func (void *arg)
|
|
||||||
{
|
|
||||||
return arg;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
glthread_in_use (void)
|
|
||||||
{
|
|
||||||
static int tested;
|
|
||||||
static int result; /* 1: linked with -lpthread, 0: only with libc */
|
|
||||||
|
|
||||||
if (!tested)
|
|
||||||
{
|
|
||||||
pthread_t thread;
|
|
||||||
|
|
||||||
if (pthread_create (&thread, NULL, dummy_thread_func, NULL) != 0)
|
|
||||||
/* Thread creation failed. */
|
|
||||||
result = 0;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Thread creation works. */
|
|
||||||
void *retval;
|
|
||||||
if (pthread_join (thread, &retval) != 0)
|
|
||||||
abort ();
|
|
||||||
result = 1;
|
|
||||||
}
|
|
||||||
tested = 1;
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/* -------------------------- gl_lock_t datatype -------------------------- */
|
|
||||||
|
|
||||||
/* ------------------------- gl_rwlock_t datatype ------------------------- */
|
|
||||||
|
|
||||||
# if HAVE_PTHREAD_RWLOCK
|
|
||||||
|
|
||||||
# if !defined PTHREAD_RWLOCK_INITIALIZER
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_init (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (pthread_rwlock_init (&lock->rwlock, NULL) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->initialized = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_rdlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->initialized)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_lock (&lock->guard) != 0)
|
|
||||||
abort ();
|
|
||||||
if (!lock->initialized)
|
|
||||||
glthread_rwlock_init (lock);
|
|
||||||
if (pthread_mutex_unlock (&lock->guard) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
if (pthread_rwlock_rdlock (&lock->rwlock) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_wrlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->initialized)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_lock (&lock->guard) != 0)
|
|
||||||
abort ();
|
|
||||||
if (!lock->initialized)
|
|
||||||
glthread_rwlock_init (lock);
|
|
||||||
if (pthread_mutex_unlock (&lock->guard) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
if (pthread_rwlock_wrlock (&lock->rwlock) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_unlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->initialized)
|
|
||||||
abort ();
|
|
||||||
if (pthread_rwlock_unlock (&lock->rwlock) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_destroy (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->initialized)
|
|
||||||
abort ();
|
|
||||||
if (pthread_rwlock_destroy (&lock->rwlock) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->initialized = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# else
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_init (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_init (&lock->lock, NULL) != 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_cond_init (&lock->waiting_readers, NULL) != 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_cond_init (&lock->waiting_writers, NULL) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->waiting_writers_count = 0;
|
|
||||||
lock->runcount = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_rdlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_lock (&lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
/* Test whether only readers are currently running, and whether the runcount
|
|
||||||
field will not overflow. */
|
|
||||||
/* POSIX says: "It is implementation-defined whether the calling thread
|
|
||||||
acquires the lock when a writer does not hold the lock and there are
|
|
||||||
writers blocked on the lock." Let's say, no: give the writers a higher
|
|
||||||
priority. */
|
|
||||||
while (!(lock->runcount + 1 > 0 && lock->waiting_writers_count == 0))
|
|
||||||
{
|
|
||||||
/* This thread has to wait for a while. Enqueue it among the
|
|
||||||
waiting_readers. */
|
|
||||||
if (pthread_cond_wait (&lock->waiting_readers, &lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
lock->runcount++;
|
|
||||||
if (pthread_mutex_unlock (&lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_wrlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_lock (&lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
/* Test whether no readers or writers are currently running. */
|
|
||||||
while (!(lock->runcount == 0))
|
|
||||||
{
|
|
||||||
/* This thread has to wait for a while. Enqueue it among the
|
|
||||||
waiting_writers. */
|
|
||||||
lock->waiting_writers_count++;
|
|
||||||
if (pthread_cond_wait (&lock->waiting_writers, &lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->waiting_writers_count--;
|
|
||||||
}
|
|
||||||
lock->runcount--; /* runcount becomes -1 */
|
|
||||||
if (pthread_mutex_unlock (&lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_unlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_lock (&lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
if (lock->runcount < 0)
|
|
||||||
{
|
|
||||||
/* Drop a writer lock. */
|
|
||||||
if (!(lock->runcount == -1))
|
|
||||||
abort ();
|
|
||||||
lock->runcount = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Drop a reader lock. */
|
|
||||||
if (!(lock->runcount > 0))
|
|
||||||
abort ();
|
|
||||||
lock->runcount--;
|
|
||||||
}
|
|
||||||
if (lock->runcount == 0)
|
|
||||||
{
|
|
||||||
/* POSIX recommends that "write locks shall take precedence over read
|
|
||||||
locks", to avoid "writer starvation". */
|
|
||||||
if (lock->waiting_writers_count > 0)
|
|
||||||
{
|
|
||||||
/* Wake up one of the waiting writers. */
|
|
||||||
if (pthread_cond_signal (&lock->waiting_writers) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Wake up all waiting readers. */
|
|
||||||
if (pthread_cond_broadcast (&lock->waiting_readers) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (pthread_mutex_unlock (&lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_destroy (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_destroy (&lock->lock) != 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_cond_destroy (&lock->waiting_readers) != 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_cond_destroy (&lock->waiting_writers) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/* --------------------- gl_recursive_lock_t datatype --------------------- */
|
|
||||||
|
|
||||||
# if HAVE_PTHREAD_MUTEX_RECURSIVE
|
|
||||||
|
|
||||||
# if !(defined PTHREAD_RECURSIVE_MUTEX_INITIALIZER || defined PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP)
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_init (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
pthread_mutexattr_t attributes;
|
|
||||||
|
|
||||||
if (pthread_mutexattr_init (&attributes) != 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_mutexattr_settype (&attributes, PTHREAD_MUTEX_RECURSIVE) != 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_mutex_init (&lock->recmutex, &attributes) != 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_mutexattr_destroy (&attributes) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->initialized = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->initialized)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_lock (&lock->guard) != 0)
|
|
||||||
abort ();
|
|
||||||
if (!lock->initialized)
|
|
||||||
glthread_recursive_lock_init (lock);
|
|
||||||
if (pthread_mutex_unlock (&lock->guard) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
if (pthread_mutex_lock (&lock->recmutex) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->initialized)
|
|
||||||
abort ();
|
|
||||||
if (pthread_mutex_unlock (&lock->recmutex) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->initialized)
|
|
||||||
abort ();
|
|
||||||
if (pthread_mutex_destroy (&lock->recmutex) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->initialized = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# else
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_init (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_init (&lock->mutex, NULL) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->owner = (pthread_t) 0;
|
|
||||||
lock->depth = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
pthread_t self = pthread_self ();
|
|
||||||
if (lock->owner != self)
|
|
||||||
{
|
|
||||||
if (pthread_mutex_lock (&lock->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->owner = self;
|
|
||||||
}
|
|
||||||
if (++(lock->depth) == 0) /* wraparound? */
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (lock->owner != pthread_self ())
|
|
||||||
abort ();
|
|
||||||
if (lock->depth == 0)
|
|
||||||
abort ();
|
|
||||||
if (--(lock->depth) == 0)
|
|
||||||
{
|
|
||||||
lock->owner = (pthread_t) 0;
|
|
||||||
if (pthread_mutex_unlock (&lock->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (lock->owner != (pthread_t) 0)
|
|
||||||
abort ();
|
|
||||||
if (pthread_mutex_destroy (&lock->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/* -------------------------- gl_once_t datatype -------------------------- */
|
|
||||||
|
|
||||||
static const pthread_once_t fresh_once = PTHREAD_ONCE_INIT;
|
|
||||||
|
|
||||||
int
|
|
||||||
glthread_once_singlethreaded (pthread_once_t *once_control)
|
|
||||||
{
|
|
||||||
/* We don't know whether pthread_once_t is an integer type, a floating-point
|
|
||||||
type, a pointer type, or a structure type. */
|
|
||||||
char *firstbyte = (char *)once_control;
|
|
||||||
if (*firstbyte == *(const char *)&fresh_once)
|
|
||||||
{
|
|
||||||
/* First time use of once_control. Invert the first byte. */
|
|
||||||
*firstbyte = ~ *(const char *)&fresh_once;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ========================================================================= */
|
|
||||||
|
|
||||||
#if USE_PTH_THREADS
|
|
||||||
|
|
||||||
/* Use the GNU Pth threads library. */
|
|
||||||
|
|
||||||
/* -------------------------- gl_lock_t datatype -------------------------- */
|
|
||||||
|
|
||||||
/* ------------------------- gl_rwlock_t datatype ------------------------- */
|
|
||||||
|
|
||||||
/* --------------------- gl_recursive_lock_t datatype --------------------- */
|
|
||||||
|
|
||||||
/* -------------------------- gl_once_t datatype -------------------------- */
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_once_call (void *arg)
|
|
||||||
{
|
|
||||||
void (**gl_once_temp_addr) (void) = (void (**) (void)) arg;
|
|
||||||
void (*initfunction) (void) = *gl_once_temp_addr;
|
|
||||||
initfunction ();
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
glthread_once_singlethreaded (pth_once_t *once_control)
|
|
||||||
{
|
|
||||||
/* We know that pth_once_t is an integer type. */
|
|
||||||
if (*once_control == PTH_ONCE_INIT)
|
|
||||||
{
|
|
||||||
/* First time use of once_control. Invert the marker. */
|
|
||||||
*once_control = ~ PTH_ONCE_INIT;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ========================================================================= */
|
|
||||||
|
|
||||||
#if USE_SOLARIS_THREADS
|
|
||||||
|
|
||||||
/* Use the old Solaris threads library. */
|
|
||||||
|
|
||||||
/* -------------------------- gl_lock_t datatype -------------------------- */
|
|
||||||
|
|
||||||
/* ------------------------- gl_rwlock_t datatype ------------------------- */
|
|
||||||
|
|
||||||
/* --------------------- gl_recursive_lock_t datatype --------------------- */
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_init (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (mutex_init (&lock->mutex, USYNC_THREAD, NULL) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->owner = (thread_t) 0;
|
|
||||||
lock->depth = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
thread_t self = thr_self ();
|
|
||||||
if (lock->owner != self)
|
|
||||||
{
|
|
||||||
if (mutex_lock (&lock->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
lock->owner = self;
|
|
||||||
}
|
|
||||||
if (++(lock->depth) == 0) /* wraparound? */
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (lock->owner != thr_self ())
|
|
||||||
abort ();
|
|
||||||
if (lock->depth == 0)
|
|
||||||
abort ();
|
|
||||||
if (--(lock->depth) == 0)
|
|
||||||
{
|
|
||||||
lock->owner = (thread_t) 0;
|
|
||||||
if (mutex_unlock (&lock->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (lock->owner != (thread_t) 0)
|
|
||||||
abort ();
|
|
||||||
if (mutex_destroy (&lock->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -------------------------- gl_once_t datatype -------------------------- */
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_once (gl_once_t *once_control, void (*initfunction) (void))
|
|
||||||
{
|
|
||||||
if (!once_control->inited)
|
|
||||||
{
|
|
||||||
/* Use the mutex to guarantee that if another thread is already calling
|
|
||||||
the initfunction, this thread waits until it's finished. */
|
|
||||||
if (mutex_lock (&once_control->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
if (!once_control->inited)
|
|
||||||
{
|
|
||||||
once_control->inited = 1;
|
|
||||||
initfunction ();
|
|
||||||
}
|
|
||||||
if (mutex_unlock (&once_control->mutex) != 0)
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
glthread_once_singlethreaded (gl_once_t *once_control)
|
|
||||||
{
|
|
||||||
/* We know that gl_once_t contains an integer type. */
|
|
||||||
if (!once_control->inited)
|
|
||||||
{
|
|
||||||
/* First time use of once_control. Invert the marker. */
|
|
||||||
once_control->inited = ~ 0;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ========================================================================= */
|
|
||||||
|
|
||||||
#if USE_WIN32_THREADS
|
|
||||||
|
|
||||||
/* -------------------------- gl_lock_t datatype -------------------------- */
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_lock_init (gl_lock_t *lock)
|
|
||||||
{
|
|
||||||
InitializeCriticalSection (&lock->lock);
|
|
||||||
lock->guard.done = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_lock_lock (gl_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
{
|
|
||||||
if (InterlockedIncrement (&lock->guard.started) == 0)
|
|
||||||
/* This thread is the first one to need this lock. Initialize it. */
|
|
||||||
glthread_lock_init (lock);
|
|
||||||
else
|
|
||||||
/* Yield the CPU while waiting for another thread to finish
|
|
||||||
initializing this lock. */
|
|
||||||
while (!lock->guard.done)
|
|
||||||
Sleep (0);
|
|
||||||
}
|
|
||||||
EnterCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_lock_unlock (gl_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
abort ();
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_lock_destroy (gl_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
abort ();
|
|
||||||
DeleteCriticalSection (&lock->lock);
|
|
||||||
lock->guard.done = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------- gl_rwlock_t datatype ------------------------- */
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
gl_waitqueue_init (gl_waitqueue_t *wq)
|
|
||||||
{
|
|
||||||
wq->array = NULL;
|
|
||||||
wq->count = 0;
|
|
||||||
wq->alloc = 0;
|
|
||||||
wq->offset = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Enqueues the current thread, represented by an event, in a wait queue.
|
|
||||||
Returns INVALID_HANDLE_VALUE if an allocation failure occurs. */
|
|
||||||
static HANDLE
|
|
||||||
gl_waitqueue_add (gl_waitqueue_t *wq)
|
|
||||||
{
|
|
||||||
HANDLE event;
|
|
||||||
unsigned int index;
|
|
||||||
|
|
||||||
if (wq->count == wq->alloc)
|
|
||||||
{
|
|
||||||
unsigned int new_alloc = 2 * wq->alloc + 1;
|
|
||||||
HANDLE *new_array =
|
|
||||||
(HANDLE *) realloc (wq->array, new_alloc * sizeof (HANDLE));
|
|
||||||
if (new_array == NULL)
|
|
||||||
/* No more memory. */
|
|
||||||
return INVALID_HANDLE_VALUE;
|
|
||||||
/* Now is a good opportunity to rotate the array so that its contents
|
|
||||||
starts at offset 0. */
|
|
||||||
if (wq->offset > 0)
|
|
||||||
{
|
|
||||||
unsigned int old_count = wq->count;
|
|
||||||
unsigned int old_alloc = wq->alloc;
|
|
||||||
unsigned int old_offset = wq->offset;
|
|
||||||
unsigned int i;
|
|
||||||
if (old_offset + old_count > old_alloc)
|
|
||||||
{
|
|
||||||
unsigned int limit = old_offset + old_count - old_alloc;
|
|
||||||
for (i = 0; i < limit; i++)
|
|
||||||
new_array[old_alloc + i] = new_array[i];
|
|
||||||
}
|
|
||||||
for (i = 0; i < old_count; i++)
|
|
||||||
new_array[i] = new_array[old_offset + i];
|
|
||||||
wq->offset = 0;
|
|
||||||
}
|
|
||||||
wq->array = new_array;
|
|
||||||
wq->alloc = new_alloc;
|
|
||||||
}
|
|
||||||
event = CreateEvent (NULL, TRUE, FALSE, NULL);
|
|
||||||
if (event == INVALID_HANDLE_VALUE)
|
|
||||||
/* No way to allocate an event. */
|
|
||||||
return INVALID_HANDLE_VALUE;
|
|
||||||
index = wq->offset + wq->count;
|
|
||||||
if (index >= wq->alloc)
|
|
||||||
index -= wq->alloc;
|
|
||||||
wq->array[index] = event;
|
|
||||||
wq->count++;
|
|
||||||
return event;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Notifies the first thread from a wait queue and dequeues it. */
|
|
||||||
static inline void
|
|
||||||
gl_waitqueue_notify_first (gl_waitqueue_t *wq)
|
|
||||||
{
|
|
||||||
SetEvent (wq->array[wq->offset + 0]);
|
|
||||||
wq->offset++;
|
|
||||||
wq->count--;
|
|
||||||
if (wq->count == 0 || wq->offset == wq->alloc)
|
|
||||||
wq->offset = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Notifies all threads from a wait queue and dequeues them all. */
|
|
||||||
static inline void
|
|
||||||
gl_waitqueue_notify_all (gl_waitqueue_t *wq)
|
|
||||||
{
|
|
||||||
unsigned int i;
|
|
||||||
|
|
||||||
for (i = 0; i < wq->count; i++)
|
|
||||||
{
|
|
||||||
unsigned int index = wq->offset + i;
|
|
||||||
if (index >= wq->alloc)
|
|
||||||
index -= wq->alloc;
|
|
||||||
SetEvent (wq->array[index]);
|
|
||||||
}
|
|
||||||
wq->count = 0;
|
|
||||||
wq->offset = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_init (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
InitializeCriticalSection (&lock->lock);
|
|
||||||
gl_waitqueue_init (&lock->waiting_readers);
|
|
||||||
gl_waitqueue_init (&lock->waiting_writers);
|
|
||||||
lock->runcount = 0;
|
|
||||||
lock->guard.done = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_rdlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
{
|
|
||||||
if (InterlockedIncrement (&lock->guard.started) == 0)
|
|
||||||
/* This thread is the first one to need this lock. Initialize it. */
|
|
||||||
glthread_rwlock_init (lock);
|
|
||||||
else
|
|
||||||
/* Yield the CPU while waiting for another thread to finish
|
|
||||||
initializing this lock. */
|
|
||||||
while (!lock->guard.done)
|
|
||||||
Sleep (0);
|
|
||||||
}
|
|
||||||
EnterCriticalSection (&lock->lock);
|
|
||||||
/* Test whether only readers are currently running, and whether the runcount
|
|
||||||
field will not overflow. */
|
|
||||||
if (!(lock->runcount + 1 > 0))
|
|
||||||
{
|
|
||||||
/* This thread has to wait for a while. Enqueue it among the
|
|
||||||
waiting_readers. */
|
|
||||||
HANDLE event = gl_waitqueue_add (&lock->waiting_readers);
|
|
||||||
if (event != INVALID_HANDLE_VALUE)
|
|
||||||
{
|
|
||||||
DWORD result;
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
/* Wait until another thread signals this event. */
|
|
||||||
result = WaitForSingleObject (event, INFINITE);
|
|
||||||
if (result == WAIT_FAILED || result == WAIT_TIMEOUT)
|
|
||||||
abort ();
|
|
||||||
CloseHandle (event);
|
|
||||||
/* The thread which signalled the event already did the bookkeeping:
|
|
||||||
removed us from the waiting_readers, incremented lock->runcount. */
|
|
||||||
if (!(lock->runcount > 0))
|
|
||||||
abort ();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Allocation failure. Weird. */
|
|
||||||
do
|
|
||||||
{
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
Sleep (1);
|
|
||||||
EnterCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
while (!(lock->runcount + 1 > 0));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
lock->runcount++;
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_wrlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
{
|
|
||||||
if (InterlockedIncrement (&lock->guard.started) == 0)
|
|
||||||
/* This thread is the first one to need this lock. Initialize it. */
|
|
||||||
glthread_rwlock_init (lock);
|
|
||||||
else
|
|
||||||
/* Yield the CPU while waiting for another thread to finish
|
|
||||||
initializing this lock. */
|
|
||||||
while (!lock->guard.done)
|
|
||||||
Sleep (0);
|
|
||||||
}
|
|
||||||
EnterCriticalSection (&lock->lock);
|
|
||||||
/* Test whether no readers or writers are currently running. */
|
|
||||||
if (!(lock->runcount == 0))
|
|
||||||
{
|
|
||||||
/* This thread has to wait for a while. Enqueue it among the
|
|
||||||
waiting_writers. */
|
|
||||||
HANDLE event = gl_waitqueue_add (&lock->waiting_writers);
|
|
||||||
if (event != INVALID_HANDLE_VALUE)
|
|
||||||
{
|
|
||||||
DWORD result;
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
/* Wait until another thread signals this event. */
|
|
||||||
result = WaitForSingleObject (event, INFINITE);
|
|
||||||
if (result == WAIT_FAILED || result == WAIT_TIMEOUT)
|
|
||||||
abort ();
|
|
||||||
CloseHandle (event);
|
|
||||||
/* The thread which signalled the event already did the bookkeeping:
|
|
||||||
removed us from the waiting_writers, set lock->runcount = -1. */
|
|
||||||
if (!(lock->runcount == -1))
|
|
||||||
abort ();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Allocation failure. Weird. */
|
|
||||||
do
|
|
||||||
{
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
Sleep (1);
|
|
||||||
EnterCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
while (!(lock->runcount == 0));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
lock->runcount--; /* runcount becomes -1 */
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_unlock (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
abort ();
|
|
||||||
EnterCriticalSection (&lock->lock);
|
|
||||||
if (lock->runcount < 0)
|
|
||||||
{
|
|
||||||
/* Drop a writer lock. */
|
|
||||||
if (!(lock->runcount == -1))
|
|
||||||
abort ();
|
|
||||||
lock->runcount = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Drop a reader lock. */
|
|
||||||
if (!(lock->runcount > 0))
|
|
||||||
abort ();
|
|
||||||
lock->runcount--;
|
|
||||||
}
|
|
||||||
if (lock->runcount == 0)
|
|
||||||
{
|
|
||||||
/* POSIX recommends that "write locks shall take precedence over read
|
|
||||||
locks", to avoid "writer starvation". */
|
|
||||||
if (lock->waiting_writers.count > 0)
|
|
||||||
{
|
|
||||||
/* Wake up one of the waiting writers. */
|
|
||||||
lock->runcount--;
|
|
||||||
gl_waitqueue_notify_first (&lock->waiting_writers);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Wake up all waiting readers. */
|
|
||||||
lock->runcount += lock->waiting_readers.count;
|
|
||||||
gl_waitqueue_notify_all (&lock->waiting_readers);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_rwlock_destroy (gl_rwlock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
abort ();
|
|
||||||
if (lock->runcount != 0)
|
|
||||||
abort ();
|
|
||||||
DeleteCriticalSection (&lock->lock);
|
|
||||||
if (lock->waiting_readers.array != NULL)
|
|
||||||
free (lock->waiting_readers.array);
|
|
||||||
if (lock->waiting_writers.array != NULL)
|
|
||||||
free (lock->waiting_writers.array);
|
|
||||||
lock->guard.done = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* --------------------- gl_recursive_lock_t datatype --------------------- */
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_init (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
lock->owner = 0;
|
|
||||||
lock->depth = 0;
|
|
||||||
InitializeCriticalSection (&lock->lock);
|
|
||||||
lock->guard.done = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_lock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (!lock->guard.done)
|
|
||||||
{
|
|
||||||
if (InterlockedIncrement (&lock->guard.started) == 0)
|
|
||||||
/* This thread is the first one to need this lock. Initialize it. */
|
|
||||||
glthread_recursive_lock_init (lock);
|
|
||||||
else
|
|
||||||
/* Yield the CPU while waiting for another thread to finish
|
|
||||||
initializing this lock. */
|
|
||||||
while (!lock->guard.done)
|
|
||||||
Sleep (0);
|
|
||||||
}
|
|
||||||
{
|
|
||||||
DWORD self = GetCurrentThreadId ();
|
|
||||||
if (lock->owner != self)
|
|
||||||
{
|
|
||||||
EnterCriticalSection (&lock->lock);
|
|
||||||
lock->owner = self;
|
|
||||||
}
|
|
||||||
if (++(lock->depth) == 0) /* wraparound? */
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_unlock (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (lock->owner != GetCurrentThreadId ())
|
|
||||||
abort ();
|
|
||||||
if (lock->depth == 0)
|
|
||||||
abort ();
|
|
||||||
if (--(lock->depth) == 0)
|
|
||||||
{
|
|
||||||
lock->owner = 0;
|
|
||||||
LeaveCriticalSection (&lock->lock);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_recursive_lock_destroy (gl_recursive_lock_t *lock)
|
|
||||||
{
|
|
||||||
if (lock->owner != 0)
|
|
||||||
abort ();
|
|
||||||
DeleteCriticalSection (&lock->lock);
|
|
||||||
lock->guard.done = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -------------------------- gl_once_t datatype -------------------------- */
|
|
||||||
|
|
||||||
void
|
|
||||||
glthread_once (gl_once_t *once_control, void (*initfunction) (void))
|
|
||||||
{
|
|
||||||
if (once_control->inited <= 0)
|
|
||||||
{
|
|
||||||
if (InterlockedIncrement (&once_control->started) == 0)
|
|
||||||
{
|
|
||||||
/* This thread is the first one to come to this once_control. */
|
|
||||||
InitializeCriticalSection (&once_control->lock);
|
|
||||||
EnterCriticalSection (&once_control->lock);
|
|
||||||
once_control->inited = 0;
|
|
||||||
initfunction ();
|
|
||||||
once_control->inited = 1;
|
|
||||||
LeaveCriticalSection (&once_control->lock);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Undo last operation. */
|
|
||||||
InterlockedDecrement (&once_control->started);
|
|
||||||
/* Some other thread has already started the initialization.
|
|
||||||
Yield the CPU while waiting for the other thread to finish
|
|
||||||
initializing and taking the lock. */
|
|
||||||
while (once_control->inited < 0)
|
|
||||||
Sleep (0);
|
|
||||||
if (once_control->inited <= 0)
|
|
||||||
{
|
|
||||||
/* Take the lock. This blocks until the other thread has
|
|
||||||
finished calling the initfunction. */
|
|
||||||
EnterCriticalSection (&once_control->lock);
|
|
||||||
LeaveCriticalSection (&once_control->lock);
|
|
||||||
if (!(once_control->inited > 0))
|
|
||||||
abort ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ========================================================================= */
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,116 +0,0 @@
|
||||||
/* Log file output.
|
|
||||||
Copyright (C) 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it
|
|
||||||
under the terms of the GNU Library General Public License as published
|
|
||||||
by the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
any later version.
|
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
||||||
Library General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Library General Public
|
|
||||||
License along with this program; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
||||||
USA. */
|
|
||||||
|
|
||||||
/* Written by Bruno Haible <bruno@clisp.org>. */
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
# include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
/* Handle multi-threaded applications. */
|
|
||||||
#ifdef _LIBC
|
|
||||||
# include <bits/libc-lock.h>
|
|
||||||
#else
|
|
||||||
# include "lock.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Print an ASCII string with quotes and escape sequences where needed. */
|
|
||||||
static void
|
|
||||||
print_escaped (FILE *stream, const char *str)
|
|
||||||
{
|
|
||||||
putc ('"', stream);
|
|
||||||
for (; *str != '\0'; str++)
|
|
||||||
if (*str == '\n')
|
|
||||||
{
|
|
||||||
fputs ("\\n\"", stream);
|
|
||||||
if (str[1] == '\0')
|
|
||||||
return;
|
|
||||||
fputs ("\n\"", stream);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (*str == '"' || *str == '\\')
|
|
||||||
putc ('\\', stream);
|
|
||||||
putc (*str, stream);
|
|
||||||
}
|
|
||||||
putc ('"', stream);
|
|
||||||
}
|
|
||||||
|
|
||||||
static char *last_logfilename = NULL;
|
|
||||||
static FILE *last_logfile = NULL;
|
|
||||||
__libc_lock_define_initialized (static, lock)
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
_nl_log_untranslated_locked (const char *logfilename, const char *domainname,
|
|
||||||
const char *msgid1, const char *msgid2, int plural)
|
|
||||||
{
|
|
||||||
FILE *logfile;
|
|
||||||
|
|
||||||
/* Can we reuse the last opened logfile? */
|
|
||||||
if (last_logfilename == NULL || strcmp (logfilename, last_logfilename) != 0)
|
|
||||||
{
|
|
||||||
/* Close the last used logfile. */
|
|
||||||
if (last_logfilename != NULL)
|
|
||||||
{
|
|
||||||
if (last_logfile != NULL)
|
|
||||||
{
|
|
||||||
fclose (last_logfile);
|
|
||||||
last_logfile = NULL;
|
|
||||||
}
|
|
||||||
free (last_logfilename);
|
|
||||||
last_logfilename = NULL;
|
|
||||||
}
|
|
||||||
/* Open the logfile. */
|
|
||||||
last_logfilename = (char *) malloc (strlen (logfilename) + 1);
|
|
||||||
if (last_logfilename == NULL)
|
|
||||||
return;
|
|
||||||
strcpy (last_logfilename, logfilename);
|
|
||||||
last_logfile = fopen (logfilename, "a");
|
|
||||||
if (last_logfile == NULL)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
logfile = last_logfile;
|
|
||||||
|
|
||||||
fprintf (logfile, "domain ");
|
|
||||||
print_escaped (logfile, domainname);
|
|
||||||
fprintf (logfile, "\nmsgid ");
|
|
||||||
print_escaped (logfile, msgid1);
|
|
||||||
if (plural)
|
|
||||||
{
|
|
||||||
fprintf (logfile, "\nmsgid_plural ");
|
|
||||||
print_escaped (logfile, msgid2);
|
|
||||||
fprintf (logfile, "\nmsgstr[0] \"\"\n");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
fprintf (logfile, "\nmsgstr \"\"\n");
|
|
||||||
putc ('\n', logfile);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Add to the log file an entry denoting a failed translation. */
|
|
||||||
void
|
|
||||||
_nl_log_untranslated (const char *logfilename, const char *domainname,
|
|
||||||
const char *msgid1, const char *msgid2, int plural)
|
|
||||||
{
|
|
||||||
__libc_lock_lock (lock);
|
|
||||||
_nl_log_untranslated_locked (logfilename, domainname, msgid1, msgid2, plural);
|
|
||||||
__libc_lock_unlock (lock);
|
|
||||||
}
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue