Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
2331525a
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
2331525a
编写于
2月 24, 2022
作者:
S
Shengliang Guan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
timezone
上级
beae4899
变更
18
隐藏空白更改
内联
并排
Showing
18 changed file
with
275 addition
and
214 deletion
+275
-214
include/common/tglobal.h
include/common/tglobal.h
+0
-1
include/common/tmsg.h
include/common/tmsg.h
+3
-3
include/dnode/mgmt/dnode.h
include/dnode/mgmt/dnode.h
+3
-3
include/libs/config/config.h
include/libs/config/config.h
+1
-0
include/os/os.h
include/os/os.h
+1
-0
include/os/osEnv.h
include/os/osEnv.h
+13
-5
include/os/osSysinfo.h
include/os/osSysinfo.h
+4
-4
include/os/osTimezone.h
include/os/osTimezone.h
+30
-0
source/client/src/clientEnv.c
source/client/src/clientEnv.c
+7
-7
source/common/src/tglobal.c
source/common/src/tglobal.c
+0
-1
source/dnode/mgmt/daemon/src/dmnCfg.c
source/dnode/mgmt/daemon/src/dmnCfg.c
+9
-1
source/dnode/mgmt/impl/src/dndMgmt.c
source/dnode/mgmt/impl/src/dndMgmt.c
+3
-3
source/libs/parser/src/insertParser.c
source/libs/parser/src/insertParser.c
+1
-1
source/libs/parser/src/parserImpl.c
source/libs/parser/src/parserImpl.c
+1
-1
source/libs/parser/src/parserUtil.c
source/libs/parser/src/parserUtil.c
+1
-1
source/os/src/osEnv.c
source/os/src/osEnv.c
+32
-24
source/os/src/osSysinfo.c
source/os/src/osSysinfo.c
+8
-130
source/os/src/osTimeZone.c
source/os/src/osTimeZone.c
+158
-29
未找到文件。
include/common/tglobal.h
浏览文件 @
2331525a
...
@@ -23,7 +23,6 @@ extern "C" {
...
@@ -23,7 +23,6 @@ extern "C" {
#include "tdef.h"
#include "tdef.h"
// common
// common
extern
int8_t
tsDaylight
;
extern
int32_t
tsCompressMsgSize
;
extern
int32_t
tsCompressMsgSize
;
extern
int32_t
tsCompressColData
;
extern
int32_t
tsCompressColData
;
extern
int32_t
tsMaxNumOfDistinctResults
;
extern
int32_t
tsMaxNumOfDistinctResults
;
...
...
include/common/tmsg.h
浏览文件 @
2331525a
...
@@ -656,9 +656,9 @@ int32_t tDeserializeSRetrieveFuncRsp(void* buf, int32_t bufLen, SRetrieveFuncRsp
...
@@ -656,9 +656,9 @@ int32_t tDeserializeSRetrieveFuncRsp(void* buf, int32_t bufLen, SRetrieveFuncRsp
typedef
struct
{
typedef
struct
{
int32_t
statusInterval
;
int32_t
statusInterval
;
int64_t
checkTime
;
// 1970-01-01 00:00:00.000
int64_t
checkTime
;
// 1970-01-01 00:00:00.000
char
timezone
[
T
SDB
_TIMEZONE_LEN
];
// tsTimezone
char
timezone
[
T
D
_TIMEZONE_LEN
];
// tsTimezone
char
locale
[
T
SDB
_LOCALE_LEN
];
// tsLocale
char
locale
[
T
D
_LOCALE_LEN
];
// tsLocale
char
charset
[
T
SDB
_LOCALE_LEN
];
// tsCharset
char
charset
[
T
D
_LOCALE_LEN
];
// tsCharset
}
SClusterCfg
;
}
SClusterCfg
;
typedef
struct
{
typedef
struct
{
...
...
include/dnode/mgmt/dnode.h
浏览文件 @
2331525a
...
@@ -34,9 +34,9 @@ typedef struct {
...
@@ -34,9 +34,9 @@ typedef struct {
bool
printAuth
;
bool
printAuth
;
int32_t
rpcTimer
;
int32_t
rpcTimer
;
int32_t
rpcMaxTime
;
int32_t
rpcMaxTime
;
char
timezone
[
T
SDB
_TIMEZONE_LEN
];
char
timezone
[
T
D
_TIMEZONE_LEN
];
char
locale
[
T
SDB
_LOCALE_LEN
];
char
locale
[
T
D
_LOCALE_LEN
];
char
charset
[
T
SDB
_LOCALE_LEN
];
char
charset
[
T
D
_LOCALE_LEN
];
char
buildinfo
[
64
];
char
buildinfo
[
64
];
char
gitinfo
[
48
];
char
gitinfo
[
48
];
}
SDnodeEnvCfg
;
}
SDnodeEnvCfg
;
...
...
include/libs/config/config.h
浏览文件 @
2331525a
...
@@ -80,6 +80,7 @@ int32_t cfgGetSize(SConfig *pCfg);
...
@@ -80,6 +80,7 @@ int32_t cfgGetSize(SConfig *pCfg);
SConfigItem
*
cfgIterate
(
SConfig
*
pCfg
,
SConfigItem
*
pIter
);
SConfigItem
*
cfgIterate
(
SConfig
*
pCfg
,
SConfigItem
*
pIter
);
void
cfgCancelIterate
(
SConfig
*
pCfg
,
SConfigItem
*
pIter
);
void
cfgCancelIterate
(
SConfig
*
pCfg
,
SConfigItem
*
pIter
);
SConfigItem
*
cfgGetItem
(
SConfig
*
pCfg
,
const
char
*
name
);
SConfigItem
*
cfgGetItem
(
SConfig
*
pCfg
,
const
char
*
name
);
int32_t
cfgSetItem
(
SConfig
*
pCfg
,
const
char
*
name
,
const
char
*
value
,
ECfgSrcType
stype
);
int32_t
cfgAddBool
(
SConfig
*
pCfg
,
const
char
*
name
,
bool
defaultVal
);
int32_t
cfgAddBool
(
SConfig
*
pCfg
,
const
char
*
name
,
bool
defaultVal
);
int32_t
cfgAddInt32
(
SConfig
*
pCfg
,
const
char
*
name
,
int32_t
defaultVal
,
int64_t
minval
,
int64_t
maxval
);
int32_t
cfgAddInt32
(
SConfig
*
pCfg
,
const
char
*
name
,
int32_t
defaultVal
,
int64_t
minval
,
int64_t
maxval
);
...
...
include/os/os.h
浏览文件 @
2331525a
...
@@ -73,6 +73,7 @@ extern "C" {
...
@@ -73,6 +73,7 @@ extern "C" {
#include "osThread.h"
#include "osThread.h"
#include "osTime.h"
#include "osTime.h"
#include "osTimer.h"
#include "osTimer.h"
#include "osTimezone.h"
void
osInit
();
void
osInit
();
...
...
include/os/osEnv.h
浏览文件 @
2331525a
...
@@ -26,10 +26,14 @@ typedef struct SEnvVar {
...
@@ -26,10 +26,14 @@ typedef struct SEnvVar {
char
dataDir
[
PATH_MAX
];
char
dataDir
[
PATH_MAX
];
char
logDir
[
PATH_MAX
];
char
logDir
[
PATH_MAX
];
char
tempDir
[
PATH_MAX
];
char
tempDir
[
PATH_MAX
];
char
osName
[
16
];
SDiskSpace
dataSpace
;
SDiskSpace
dataSpace
;
SDiskSpace
logSpace
;
SDiskSpace
logSpace
;
SDiskSpace
tempSpace
;
SDiskSpace
tempSpace
;
char
osName
[
16
];
char
timezone
[
TD_TIMEZONE_LEN
];
char
locale
[
TD_LOCALE_LEN
];
char
charset
[
TD_CHARSET_LEN
];
int8_t
daylight
;
}
SEnvVar
;
}
SEnvVar
;
extern
char
configDir
[];
extern
char
configDir
[];
...
@@ -38,10 +42,14 @@ void osInit();
...
@@ -38,10 +42,14 @@ void osInit();
SEnvVar
*
osEnv
();
SEnvVar
*
osEnv
();
void
osUpdate
();
void
osUpdate
();
bool
osLogSpaceAvailable
();
bool
osLogSpaceAvailable
();
char
*
osLogDir
();
char
*
osLogDir
();
char
*
osTempDir
();
char
*
osTempDir
();
char
*
osDataDir
();
char
*
osDataDir
();
char
*
osName
();
char
*
osName
();
char
*
osTimezone
();
int8_t
osDaylight
();
void
osSetTimezone
(
const
char
*
timezone
);
#ifdef __cplusplus
#ifdef __cplusplus
}
}
...
...
include/os/osSysinfo.h
浏览文件 @
2331525a
...
@@ -21,9 +21,10 @@ extern "C" {
...
@@ -21,9 +21,10 @@ extern "C" {
#endif
#endif
#include "os.h"
#include "os.h"
#define TSDB_LOCALE_LEN 64
#define TD_LOCALE_LEN 64
#define TSDB_TIMEZONE_LEN 96
#define TD_CHARSET_LEN 64
#define TD_TIMEZONE_LEN 96
typedef
struct
{
typedef
struct
{
int64_t
total
;
int64_t
total
;
...
@@ -41,7 +42,6 @@ extern int64_t tsOpenMax;
...
@@ -41,7 +42,6 @@ extern int64_t tsOpenMax;
extern
int64_t
tsStreamMax
;
extern
int64_t
tsStreamMax
;
extern
int32_t
tsNumOfCores
;
extern
int32_t
tsNumOfCores
;
extern
int32_t
tsTotalMemoryMB
;
extern
int32_t
tsTotalMemoryMB
;
extern
char
tsTimezone
[];
extern
char
tsLocale
[];
extern
char
tsLocale
[];
extern
char
tsCharset
[];
// default encode string
extern
char
tsCharset
[];
// default encode string
...
...
include/os/osTimezone.h
0 → 100644
浏览文件 @
2331525a
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* 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.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _TD_OS_TIMEZONE_H_
#define _TD_OS_TIMEZONE_H_
#ifdef __cplusplus
extern
"C"
{
#endif
void
osGetSystemTimezone
(
char
*
outTimezone
);
void
osSetSystemTimezone
(
const
char
*
inTimezone
,
char
*
outTimezone
,
int8_t
*
outDaylight
);
#ifdef __cplusplus
}
#endif
#endif
/*_TD_OS_SOCKET_H_*/
source/client/src/clientEnv.c
浏览文件 @
2331525a
...
@@ -300,7 +300,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
...
@@ -300,7 +300,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
assert(cfg != NULL);
assert(cfg != NULL);
size_t len = strlen(str);
size_t len = strlen(str);
if (len == 0 || len > T
SDB
_LOCALE_LEN) {
if (len == 0 || len > T
D
_LOCALE_LEN) {
tscInfo("Invalid locale:%s, use default", str);
tscInfo("Invalid locale:%s, use default", str);
return -1;
return -1;
}
}
...
@@ -318,7 +318,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
...
@@ -318,7 +318,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
return -1;
return -1;
}
}
tstrncpy(tsLocale, defaultLocale, T
SDB
_LOCALE_LEN);
tstrncpy(tsLocale, defaultLocale, T
D
_LOCALE_LEN);
}
}
// set the user specified locale
// set the user specified locale
...
@@ -332,7 +332,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
...
@@ -332,7 +332,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
tscInfo("failed to set locale:%s, current locale:%s", str, tsLocale);
tscInfo("failed to set locale:%s, current locale:%s", str, tsLocale);
}
}
tstrncpy(tsLocale, locale, T
SDB
_LOCALE_LEN);
tstrncpy(tsLocale, locale, T
D
_LOCALE_LEN);
char *charset = strrchr(tsLocale, sep);
char *charset = strrchr(tsLocale, sep);
if (charset != NULL) {
if (charset != NULL) {
...
@@ -347,7 +347,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
...
@@ -347,7 +347,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
tscInfo("charset changed from %s to %s", tsCharset, charset);
tscInfo("charset changed from %s to %s", tsCharset, charset);
}
}
tstrncpy(tsCharset, charset, T
SDB
_LOCALE_LEN);
tstrncpy(tsCharset, charset, T
D
_LOCALE_LEN);
cfg->cfgStatus = TAOS_CFG_CSTATUS_OPTION;
cfg->cfgStatus = TAOS_CFG_CSTATUS_OPTION;
} else {
} else {
...
@@ -371,7 +371,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
...
@@ -371,7 +371,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
assert(cfg != NULL);
assert(cfg != NULL);
size_t len = strlen(str);
size_t len = strlen(str);
if (len == 0 || len > T
SDB
_LOCALE_LEN) {
if (len == 0 || len > T
D
_LOCALE_LEN) {
tscInfo("failed to set charset:%s", str);
tscInfo("failed to set charset:%s", str);
return -1;
return -1;
}
}
...
@@ -384,7 +384,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
...
@@ -384,7 +384,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
tscInfo("charset changed from %s to %s", tsCharset, str);
tscInfo("charset changed from %s to %s", tsCharset, str);
}
}
tstrncpy(tsCharset, str, T
SDB
_LOCALE_LEN);
tstrncpy(tsCharset, str, T
D
_LOCALE_LEN);
cfg->cfgStatus = TAOS_CFG_CSTATUS_OPTION;
cfg->cfgStatus = TAOS_CFG_CSTATUS_OPTION;
} else {
} else {
tscInfo("charset:%s not valid", str);
tscInfo("charset:%s not valid", str);
...
@@ -402,7 +402,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
...
@@ -402,7 +402,7 @@ int taos_options_imp(TSDB_OPTION option, const char *str) {
assert(cfg != NULL);
assert(cfg != NULL);
if (cfg->cfgStatus <= TAOS_CFG_CSTATUS_OPTION) {
if (cfg->cfgStatus <= TAOS_CFG_CSTATUS_OPTION) {
tstrncpy(tsTimezone, str, T
SDB
_TIMEZONE_LEN);
tstrncpy(tsTimezone, str, T
D
_TIMEZONE_LEN);
tsSetTimeZone();
tsSetTimeZone();
cfg->cfgStatus = TAOS_CFG_CSTATUS_OPTION;
cfg->cfgStatus = TAOS_CFG_CSTATUS_OPTION;
tscDebug("timezone set:%s, input:%s by taos_options", tsTimezone, str);
tscDebug("timezone set:%s, input:%s by taos_options", tsTimezone, str);
...
...
source/common/src/tglobal.c
浏览文件 @
2331525a
...
@@ -29,7 +29,6 @@
...
@@ -29,7 +29,6 @@
// common
// common
int8_t
tsDaylight
=
0
;
int32_t
tsMaxBinaryDisplayWidth
=
30
;
int32_t
tsMaxBinaryDisplayWidth
=
30
;
int8_t
tsEnableSlaveQuery
=
1
;
int8_t
tsEnableSlaveQuery
=
1
;
int8_t
tsEnableAdjustMaster
=
1
;
int8_t
tsEnableAdjustMaster
=
1
;
...
...
source/dnode/mgmt/daemon/src/dmnCfg.c
浏览文件 @
2331525a
...
@@ -87,17 +87,25 @@ static int32_t dmnAddDnodeCfg(SConfig *pCfg) {
...
@@ -87,17 +87,25 @@ static int32_t dmnAddDnodeCfg(SConfig *pCfg) {
return
0
;
return
0
;
}
}
static
void
dmnSetDnodeCfg
(
SConfig
*
pCfg
)
{
SConfigItem
*
pItem
=
cfgGetItem
(
pCfg
,
"timezone"
);
osSetTimezone
(
pItem
->
str
);
uDebug
(
"timezone format changed from %s to %s"
,
pItem
->
str
,
osTimezone
());
cfgSetItem
(
pCfg
,
"timezone"
,
osTimezone
(),
pItem
->
stype
);
}
static
int32_t
dmnCheckCfg
(
SConfig
*
pCfg
)
{
static
int32_t
dmnCheckCfg
(
SConfig
*
pCfg
)
{
bool
enableCore
=
cfgGetItem
(
pCfg
,
"enableCoreFile"
)
->
bval
;
bool
enableCore
=
cfgGetItem
(
pCfg
,
"enableCoreFile"
)
->
bval
;
taosSetCoreDump
(
enableCore
);
taosSetCoreDump
(
enableCore
);
dmnSetDnodeCfg
(
pCfg
);
if
(
dmnCheckDirCfg
(
pCfg
)
!=
0
)
{
if
(
dmnCheckDirCfg
(
pCfg
)
!=
0
)
{
return
-
1
;
return
-
1
;
}
}
taosGetSystemInfo
();
taosGetSystemInfo
();
tsSetTimeZone
();
tsSetLocale
();
tsSetLocale
();
if
(
tsNumOfCores
<=
0
)
{
if
(
tsNumOfCores
<=
0
)
{
...
...
source/dnode/mgmt/impl/src/dndMgmt.c
浏览文件 @
2331525a
...
@@ -371,9 +371,9 @@ void dndSendStatusReq(SDnode *pDnode) {
...
@@ -371,9 +371,9 @@ void dndSendStatusReq(SDnode *pDnode) {
req
.
clusterCfg
.
checkTime
=
0
;
req
.
clusterCfg
.
checkTime
=
0
;
char
timestr
[
32
]
=
"1970-01-01 00:00:00.00"
;
char
timestr
[
32
]
=
"1970-01-01 00:00:00.00"
;
(
void
)
taosParseTime
(
timestr
,
&
req
.
clusterCfg
.
checkTime
,
(
int32_t
)
strlen
(
timestr
),
TSDB_TIME_PRECISION_MILLI
,
0
);
(
void
)
taosParseTime
(
timestr
,
&
req
.
clusterCfg
.
checkTime
,
(
int32_t
)
strlen
(
timestr
),
TSDB_TIME_PRECISION_MILLI
,
0
);
memcpy
(
req
.
clusterCfg
.
timezone
,
pDnode
->
env
.
timezone
,
T
SDB
_TIMEZONE_LEN
);
memcpy
(
req
.
clusterCfg
.
timezone
,
pDnode
->
env
.
timezone
,
T
D
_TIMEZONE_LEN
);
memcpy
(
req
.
clusterCfg
.
locale
,
pDnode
->
env
.
locale
,
T
SDB
_LOCALE_LEN
);
memcpy
(
req
.
clusterCfg
.
locale
,
pDnode
->
env
.
locale
,
T
D
_LOCALE_LEN
);
memcpy
(
req
.
clusterCfg
.
charset
,
pDnode
->
env
.
charset
,
T
SDB
_LOCALE_LEN
);
memcpy
(
req
.
clusterCfg
.
charset
,
pDnode
->
env
.
charset
,
T
D
_LOCALE_LEN
);
taosRUnLockLatch
(
&
pMgmt
->
latch
);
taosRUnLockLatch
(
&
pMgmt
->
latch
);
req
.
pVloads
=
taosArrayInit
(
TSDB_MAX_VNODES
,
sizeof
(
SVnodeLoad
));
req
.
pVloads
=
taosArrayInit
(
TSDB_MAX_VNODES
,
sizeof
(
SVnodeLoad
));
...
...
source/libs/parser/src/insertParser.c
浏览文件 @
2331525a
...
@@ -204,7 +204,7 @@ static int parseTime(char **end, SToken *pToken, int16_t timePrec, int64_t *time
...
@@ -204,7 +204,7 @@ static int parseTime(char **end, SToken *pToken, int16_t timePrec, int64_t *time
bool
isSigned
=
false
;
bool
isSigned
=
false
;
toInteger
(
pToken
->
z
,
pToken
->
n
,
10
,
&
ts
,
&
isSigned
);
toInteger
(
pToken
->
z
,
pToken
->
n
,
10
,
&
ts
,
&
isSigned
);
}
else
{
// parse the RFC-3339/ISO-8601 timestamp format string
}
else
{
// parse the RFC-3339/ISO-8601 timestamp format string
if
(
taosParseTime
(
pToken
->
z
,
time
,
pToken
->
n
,
timePrec
,
tsDaylight
)
!=
TSDB_CODE_SUCCESS
)
{
if
(
taosParseTime
(
pToken
->
z
,
time
,
pToken
->
n
,
timePrec
,
osDaylight
()
)
!=
TSDB_CODE_SUCCESS
)
{
return
buildSyntaxErrMsg
(
pMsgBuf
,
"invalid timestamp format"
,
pToken
->
z
);
return
buildSyntaxErrMsg
(
pMsgBuf
,
"invalid timestamp format"
,
pToken
->
z
);
}
}
...
...
source/libs/parser/src/parserImpl.c
浏览文件 @
2331525a
...
@@ -578,7 +578,7 @@ static EDealRes translateValue(STranslateContext* pCxt, SValueNode* pVal) {
...
@@ -578,7 +578,7 @@ static EDealRes translateValue(STranslateContext* pCxt, SValueNode* pVal) {
return
DEAL_RES_ERROR
;
return
DEAL_RES_ERROR
;
}
}
int32_t
len
=
trimStringCopy
(
pVal
->
literal
,
n
,
tmp
);
int32_t
len
=
trimStringCopy
(
pVal
->
literal
,
n
,
tmp
);
if
(
taosParseTime
(
tmp
,
&
pVal
->
datum
.
i
,
len
,
pVal
->
node
.
resType
.
precision
,
tsDaylight
)
!=
TSDB_CODE_SUCCESS
)
{
if
(
taosParseTime
(
tmp
,
&
pVal
->
datum
.
i
,
len
,
pVal
->
node
.
resType
.
precision
,
osDaylight
()
)
!=
TSDB_CODE_SUCCESS
)
{
tfree
(
tmp
);
tfree
(
tmp
);
generateSyntaxErrMsg
(
pCxt
,
TSDB_CODE_PAR_WRONG_VALUE_TYPE
,
pVal
->
literal
);
generateSyntaxErrMsg
(
pCxt
,
TSDB_CODE_PAR_WRONG_VALUE_TYPE
,
pVal
->
literal
);
return
DEAL_RES_ERROR
;
return
DEAL_RES_ERROR
;
...
...
source/libs/parser/src/parserUtil.c
浏览文件 @
2331525a
...
@@ -1639,7 +1639,7 @@ static int parseTime(char **end, SToken *pToken, int16_t timePrec, int64_t *time
...
@@ -1639,7 +1639,7 @@ static int parseTime(char **end, SToken *pToken, int16_t timePrec, int64_t *time
bool
isSigned
=
false
;
bool
isSigned
=
false
;
toInteger
(
pToken
->
z
,
pToken
->
n
,
10
,
&
ts
,
&
isSigned
);
toInteger
(
pToken
->
z
,
pToken
->
n
,
10
,
&
ts
,
&
isSigned
);
}
else
{
// parse the RFC-3339/ISO-8601 timestamp format string
}
else
{
// parse the RFC-3339/ISO-8601 timestamp format string
if
(
taosParseTime
(
pToken
->
z
,
time
,
pToken
->
n
,
timePrec
,
tsDaylight
)
!=
TSDB_CODE_SUCCESS
)
{
if
(
taosParseTime
(
pToken
->
z
,
time
,
pToken
->
n
,
timePrec
,
osDaylight
()
)
!=
TSDB_CODE_SUCCESS
)
{
return
buildSyntaxErrMsg
(
pMsgBuf
,
"invalid timestamp format"
,
pToken
->
z
);
return
buildSyntaxErrMsg
(
pMsgBuf
,
"invalid timestamp format"
,
pToken
->
z
);
}
}
...
...
source/os/src/osEnv.c
浏览文件 @
2331525a
...
@@ -15,12 +15,41 @@
...
@@ -15,12 +15,41 @@
#define _DEFAULT_SOURCE
#define _DEFAULT_SOURCE
#include "osEnv.h"
#include "osEnv.h"
#include "os.h"
#include "osSysinfo.h"
SEnvVar
env
=
{
0
};
SEnvVar
env
=
{
0
};
char
configDir
[
PATH_MAX
]
=
{
0
};
char
configDir
[
PATH_MAX
]
=
{
0
};
SEnvVar
*
osEnv
()
{
return
&
env
;
}
void
osInitImp
()
{
osGetSystemTimezone
(
env
.
timezone
);
osSetTimezone
(
env
.
timezone
);
}
void
osUpdate
()
{
if
(
env
.
logDir
[
0
]
!=
0
)
{
taosGetDiskSize
(
env
.
logDir
,
&
env
.
logSpace
.
size
);
}
if
(
env
.
dataDir
[
0
]
!=
0
)
{
taosGetDiskSize
(
env
.
dataDir
,
&
env
.
dataSpace
.
size
);
}
if
(
env
.
tempDir
[
0
]
!=
0
)
{
taosGetDiskSize
(
env
.
tempDir
,
&
env
.
tempSpace
.
size
);
}
}
bool
osLogSpaceAvailable
()
{
return
env
.
logSpace
.
reserved
<
env
.
logSpace
.
size
.
avail
;
}
char
*
osLogDir
()
{
return
env
.
logDir
;
}
char
*
osTempDir
()
{
return
env
.
tempDir
;
}
char
*
osDataDir
()
{
return
env
.
dataDir
;
}
char
*
osName
()
{
return
env
.
osName
;
}
char
*
osTimezone
()
{
return
env
.
timezone
;
}
int8_t
osDaylight
()
{
return
env
.
daylight
;
}
void
osSetTimezone
(
const
char
*
timezone
)
{
osSetSystemTimezone
(
timezone
,
env
.
timezone
,
&
env
.
daylight
);
}
#if defined(_TD_WINDOWS_64) || defined(_TD_WINDOWS_32)
#if defined(_TD_WINDOWS_64) || defined(_TD_WINDOWS_32)
extern
taosWinSocketInit
();
extern
taosWinSocketInit
();
...
@@ -65,25 +94,4 @@ void osInit() {
...
@@ -65,25 +94,4 @@ void osInit() {
strcpy
(
env
.
osName
,
"Linux"
);
strcpy
(
env
.
osName
,
"Linux"
);
}
}
#endif
#endif
\ No newline at end of file
SEnvVar
*
osEnv
()
{
return
&
env
;
}
void
osUpdate
()
{
if
(
env
.
logDir
[
0
]
!=
0
)
{
taosGetDiskSize
(
env
.
logDir
,
&
env
.
logSpace
.
size
);
}
if
(
env
.
dataDir
[
0
]
!=
0
)
{
taosGetDiskSize
(
env
.
dataDir
,
&
env
.
dataSpace
.
size
);
}
if
(
env
.
tempDir
[
0
]
!=
0
)
{
taosGetDiskSize
(
env
.
tempDir
,
&
env
.
tempSpace
.
size
);
}
}
bool
osLogSpaceAvailable
()
{
return
env
.
logSpace
.
reserved
<
env
.
logSpace
.
size
.
avail
;
}
char
*
osLogDir
()
{
return
env
.
logDir
;
}
char
*
osTempDir
()
{
return
env
.
tempDir
;
}
char
*
osDataDir
()
{
return
env
.
dataDir
;
}
char
*
osName
()
{
return
env
.
osName
;
}
source/os/src/osSysinfo.c
浏览文件 @
2331525a
...
@@ -21,9 +21,8 @@ int64_t tsPageSize = 0;
...
@@ -21,9 +21,8 @@ int64_t tsPageSize = 0;
int64_t
tsOpenMax
=
0
;
int64_t
tsOpenMax
=
0
;
int64_t
tsStreamMax
=
0
;
int64_t
tsStreamMax
=
0
;
int32_t
tsNumOfCores
=
1
;
int32_t
tsNumOfCores
=
1
;
char
tsTimezone
[
TSDB_TIMEZONE_LEN
]
=
{
0
};
char
tsLocale
[
TD_LOCALE_LEN
]
=
{
0
};
char
tsLocale
[
TSDB_LOCALE_LEN
]
=
{
0
};
char
tsCharset
[
TD_LOCALE_LEN
]
=
{
0
};
// default encode string
char
tsCharset
[
TSDB_LOCALE_LEN
]
=
{
0
};
// default encode string
#if defined(_TD_WINDOWS_64) || defined(_TD_WINDOWS_32)
#if defined(_TD_WINDOWS_64) || defined(_TD_WINDOWS_32)
...
@@ -89,21 +88,13 @@ bool taosGetProcMemory(float *memoryUsedMB) {
...
@@ -89,21 +88,13 @@ bool taosGetProcMemory(float *memoryUsedMB) {
return
true
;
return
true
;
}
}
static
void
taosGetSystemTimezone
()
{
// get and set default timezone
char
*
tz
=
getenv
(
"TZ"
);
if
(
tz
==
NULL
||
strlen
(
tz
)
==
0
)
{
strcpy
(
tsTimezone
,
"not configured"
);
}
else
{
strcpy
(
tsTimezone
,
tz
);
}
}
static
void
taosGetSystemLocale
()
{
static
void
taosGetSystemLocale
()
{
// get and set default locale
// get and set default locale
char
*
locale
=
setlocale
(
LC_CTYPE
,
"chs"
);
char
*
locale
=
setlocale
(
LC_CTYPE
,
"chs"
);
if
(
locale
!=
NULL
)
{
if
(
locale
!=
NULL
)
{
tstrncpy
(
tsLocale
,
locale
,
T
SDB
_LOCALE_LEN
);
tstrncpy
(
tsLocale
,
locale
,
T
D
_LOCALE_LEN
);
}
}
strcpy
(
tsCharset
,
"cp936"
);
strcpy
(
tsCharset
,
"cp936"
);
...
@@ -200,7 +191,6 @@ void taosGetSystemInfo() {
...
@@ -200,7 +191,6 @@ void taosGetSystemInfo() {
taosGetCpuUsage
(
&
tmp1
,
&
tmp2
);
taosGetCpuUsage
(
&
tmp1
,
&
tmp2
);
taosGetProcIO
(
&
tmp1
,
&
tmp2
);
taosGetProcIO
(
&
tmp1
,
&
tmp2
);
taosGetSystemTimezone
();
taosGetSystemLocale
();
taosGetSystemLocale
();
}
}
...
@@ -273,57 +263,6 @@ char *taosGetCmdlineByPID(int pid) { return ""; }
...
@@ -273,57 +263,6 @@ char *taosGetCmdlineByPID(int pid) { return ""; }
#include <errno.h>
#include <errno.h>
#include <libproc.h>
#include <libproc.h>
static
void
taosGetSystemTimezone
()
{
/* load time zone string from /etc/localtime */
char
buf
[
4096
];
char
*
tz
=
NULL
;
{
int
n
=
readlink
(
"/etc/localtime"
,
buf
,
sizeof
(
buf
));
if
(
n
<
0
)
{
//printf("read /etc/localtime error, reason:%s", strerror(errno));
return
;
}
buf
[
n
]
=
'\0'
;
for
(
int
i
=
n
-
1
;
i
>=
0
;
--
i
)
{
if
(
buf
[
i
]
==
'/'
)
{
if
(
tz
)
{
tz
=
buf
+
i
+
1
;
break
;
}
tz
=
buf
+
i
+
1
;
}
}
if
(
!
tz
||
0
==
strchr
(
tz
,
'/'
))
{
//printf("parsing /etc/localtime failed");
return
;
}
setenv
(
"TZ"
,
tz
,
1
);
tzset
();
}
/*
* NOTE: do not remove it.
* Enforce set the correct daylight saving time(DST) flag according
* to current time
*/
time_t
tx1
=
time
(
NULL
);
struct
tm
tm1
;
localtime_r
(
&
tx1
,
&
tm1
);
/*
* format example:
*
* Asia/Shanghai (CST, +0800)
* Europe/London (BST, +0100)
*/
snprintf
(
tsTimezone
,
TSDB_TIMEZONE_LEN
,
"%s (%s, %+03ld00)"
,
tz
,
tm1
.
tm_isdst
?
tzname
[
daylight
]
:
tzname
[
0
],
-
timezone
/
3600
);
// cfg_timezone->cfgStatus = TAOS_CFG_CSTATUS_DEFAULT;
//printf("timezone not configured, set to system default:%s", tsTimezone);
}
/*
/*
* originally from src/os/src/detail/osSysinfo.c
* originally from src/os/src/detail/osSysinfo.c
* POSIX format locale string:
* POSIX format locale string:
...
@@ -351,7 +290,7 @@ static void taosGetSystemLocale() { // get and set default locale
...
@@ -351,7 +290,7 @@ static void taosGetSystemLocale() { // get and set default locale
//printf("can't get locale from system, set it to en_US.UTF-8 since error:%d:%s", errno, strerror(errno));
//printf("can't get locale from system, set it to en_US.UTF-8 since error:%d:%s", errno, strerror(errno));
strcpy
(
tsLocale
,
"en_US.UTF-8"
);
strcpy
(
tsLocale
,
"en_US.UTF-8"
);
}
else
{
}
else
{
tstrncpy
(
tsLocale
,
locale
,
T
SDB
_LOCALE_LEN
);
tstrncpy
(
tsLocale
,
locale
,
T
D
_LOCALE_LEN
);
//printf("locale not configured, set to system default:%s", tsLocale);
//printf("locale not configured, set to system default:%s", tsLocale);
}
}
...
@@ -361,7 +300,7 @@ static void taosGetSystemLocale() { // get and set default locale
...
@@ -361,7 +300,7 @@ static void taosGetSystemLocale() { // get and set default locale
str
++
;
str
++
;
char
*
revisedCharset
=
taosCharsetReplace
(
str
);
char
*
revisedCharset
=
taosCharsetReplace
(
str
);
tstrncpy
(
tsCharset
,
revisedCharset
,
T
SDB
_LOCALE_LEN
);
tstrncpy
(
tsCharset
,
revisedCharset
,
T
D
_LOCALE_LEN
);
free
(
revisedCharset
);
free
(
revisedCharset
);
//printf("charset not configured, set to system default:%s", tsCharset);
//printf("charset not configured, set to system default:%s", tsCharset);
...
@@ -387,7 +326,6 @@ void taosGetSystemInfo() {
...
@@ -387,7 +326,6 @@ void taosGetSystemInfo() {
tsTotalMemoryMB
=
physical_pages
*
page_size
/
(
1024
*
1024
);
tsTotalMemoryMB
=
physical_pages
*
page_size
/
(
1024
*
1024
);
tsPageSize
=
page_size
;
tsPageSize
=
page_size
;
taosGetSystemTimezone
();
taosGetSystemLocale
();
taosGetSystemLocale
();
}
}
...
@@ -625,65 +563,6 @@ static bool taosGetProcCpuInfo(ProcCpuInfo *cpuInfo) {
...
@@ -625,65 +563,6 @@ static bool taosGetProcCpuInfo(ProcCpuInfo *cpuInfo) {
return
true
;
return
true
;
}
}
static
void
taosGetSystemTimezone
()
{
/*
* NOTE: do not remove it.
* Enforce set the correct daylight saving time(DST) flag according
* to current time
*/
time_t
tx1
=
time
(
NULL
);
struct
tm
tm1
;
localtime_r
(
&
tx1
,
&
tm1
);
/* load time zone string from /etc/timezone */
FILE
*
f
=
fopen
(
"/etc/timezone"
,
"r"
);
char
buf
[
68
]
=
{
0
};
if
(
f
!=
NULL
)
{
int
len
=
fread
(
buf
,
64
,
1
,
f
);
if
(
len
<
64
&&
ferror
(
f
))
{
fclose
(
f
);
//printf("read /etc/timezone error, reason:%s", strerror(errno));
return
;
}
fclose
(
f
);
buf
[
sizeof
(
buf
)
-
1
]
=
0
;
char
*
lineEnd
=
strstr
(
buf
,
"
\n
"
);
if
(
lineEnd
!=
NULL
)
{
*
lineEnd
=
0
;
}
// for CentOS system, /etc/timezone does not exist. Ignore the TZ environment variables
if
(
strlen
(
buf
)
>
0
)
{
setenv
(
"TZ"
,
buf
,
1
);
}
}
// get and set default timezone
tzset
();
/*
* get CURRENT time zone.
* system current time zone is affected by daylight saving time(DST)
*
* e.g., the local time zone of London in DST is GMT+01:00,
* otherwise is GMT+00:00
*/
int32_t
tz
=
(
-
timezone
*
MILLISECOND_PER_SECOND
)
/
MILLISECOND_PER_HOUR
;
tz
+=
daylight
;
/*
* format example:
*
* Asia/Shanghai (CST, +0800)
* Europe/London (BST, +0100)
*/
snprintf
(
tsTimezone
,
TSDB_TIMEZONE_LEN
,
"%s (%s, %s%02d00)"
,
buf
,
tzname
[
daylight
],
tz
>=
0
?
"+"
:
"-"
,
abs
(
tz
));
// cfg_timezone->cfgStatus = TAOS_CFG_CSTATUS_DEFAULT;
//printf("timezone not configured, set to system default:%s", tsTimezone);
}
/*
/*
* POSIX format locale string:
* POSIX format locale string:
* (Language Strings)_(Country/Region Strings).(code_page)
* (Language Strings)_(Country/Region Strings).(code_page)
...
@@ -710,7 +589,7 @@ static void taosGetSystemLocale() { // get and set default locale
...
@@ -710,7 +589,7 @@ static void taosGetSystemLocale() { // get and set default locale
//printf("can't get locale from system, set it to en_US.UTF-8 since error:%d:%s", errno, strerror(errno));
//printf("can't get locale from system, set it to en_US.UTF-8 since error:%d:%s", errno, strerror(errno));
strcpy
(
tsLocale
,
"en_US.UTF-8"
);
strcpy
(
tsLocale
,
"en_US.UTF-8"
);
}
else
{
}
else
{
tstrncpy
(
tsLocale
,
locale
,
T
SDB
_LOCALE_LEN
);
tstrncpy
(
tsLocale
,
locale
,
T
D
_LOCALE_LEN
);
//printf("locale not configured, set to system default:%s", tsLocale);
//printf("locale not configured, set to system default:%s", tsLocale);
}
}
...
@@ -720,7 +599,7 @@ static void taosGetSystemLocale() { // get and set default locale
...
@@ -720,7 +599,7 @@ static void taosGetSystemLocale() { // get and set default locale
str
++
;
str
++
;
char
*
revisedCharset
=
taosCharsetReplace
(
str
);
char
*
revisedCharset
=
taosCharsetReplace
(
str
);
tstrncpy
(
tsCharset
,
revisedCharset
,
T
SDB
_LOCALE_LEN
);
tstrncpy
(
tsCharset
,
revisedCharset
,
T
D
_LOCALE_LEN
);
free
(
revisedCharset
);
free
(
revisedCharset
);
//printf("charset not configured, set to system default:%s", tsCharset);
//printf("charset not configured, set to system default:%s", tsCharset);
...
@@ -957,7 +836,6 @@ void taosGetSystemInfo() {
...
@@ -957,7 +836,6 @@ void taosGetSystemInfo() {
taosGetCpuUsage
(
&
tmp1
,
&
tmp2
);
taosGetCpuUsage
(
&
tmp1
,
&
tmp2
);
taosGetProcIO
(
&
tmp1
,
&
tmp2
);
taosGetProcIO
(
&
tmp1
,
&
tmp2
);
taosGetSystemTimezone
();
taosGetSystemLocale
();
taosGetSystemLocale
();
}
}
...
...
source/os/src/osTimeZone.c
浏览文件 @
2331525a
...
@@ -15,40 +15,59 @@
...
@@ -15,40 +15,59 @@
#define _DEFAULT_SOURCE
#define _DEFAULT_SOURCE
#include "os.h"
#include "os.h"
// #include "ulog.h"
// #include "tglobal.h"
// #include "tutil.h"
// TODO refactor to set the tz value through parameter
void
tsSetTimeZone
()
{
#if 0
SGlobalCfg *cfg_timezone = taosGetConfigOption("timezone");
if (cfg_timezone != NULL) {
uInfo("timezone is set to %s by %s", tsTimezone, tsCfgStatusStr[cfg_timezone->cfgStatus]);
}
#if defined(_TD_WINDOWS_64) || defined(_TD_WINDOWS_32)
#if (_WIN64)
#include <iphlpapi.h>
#include <mswsock.h>
#include <psapi.h>
#include <stdio.h>
#include <windows.h>
#include <ws2tcpip.h>
#pragma comment(lib, "Mswsock.lib ")
#endif
#include <objbase.h>
#pragma warning(push)
#pragma warning(disable : 4091)
#include <DbgHelp.h>
#pragma warning(pop)
#elif defined(_TD_DARWIN_64)
#include <errno.h>
#include <libproc.h>
#else
#include <argp.h>
#include <linux/sysctl.h>
#include <sys/file.h>
#include <sys/resource.h>
#include <sys/statvfs.h>
#include <sys/syscall.h>
#include <sys/utsname.h>
#include <unistd.h>
#endif
void
osSetSystemTimezone
(
const
char
*
inTimezone
,
char
*
outTimezone
,
int8_t
*
outDaylight
)
{
#ifdef WINDOWS
#ifdef WINDOWS
char winStr[T
SDB
_LOCALE_LEN * 2];
char
winStr
[
T
D
_LOCALE_LEN
*
2
];
sprintf(winStr, "TZ=%s",
ts
Timezone);
sprintf
(
winStr
,
"TZ=%s"
,
in
Timezone
);
putenv
(
winStr
);
putenv
(
winStr
);
#else
#else
setenv("TZ",
ts
Timezone, 1);
setenv
(
"TZ"
,
in
Timezone
,
1
);
#endif
#endif
tzset
();
tzset
();
/*
/*
* get CURRENT time zone.
* get CURRENT time zone.
* system current time zone is affected by daylight saving time(DST)
* system current time zone is affected by daylight saving time(DST)
*
*
* e.g., the local time zone of London in DST is GMT+01:00,
* e.g., the local time zone of London in DST is GMT+01:00,
* otherwise is GMT+00:00
* otherwise is GMT+00:00
*/
*/
#ifdef _MSC_VER
#ifdef _MSC_VER
#if _MSC_VER >= 1900
#if _MSC_VER >= 1900
// see https://docs.microsoft.com/en-us/cpp/c-runtime-library/daylight-dstbias-timezone-and-tzname?view=vs-2019
// see https://docs.microsoft.com/en-us/cpp/c-runtime-library/daylight-dstbias-timezone-and-tzname?view=vs-2019
int64_t
timezone
=
_timezone
;
int64_t
timezone
=
_timezone
;
int32_t
daylight
=
_daylight
;
int32_t
daylight
=
_daylight
;
char
**
tzname
=
_tzname
;
char
**
tzname
=
_tzname
;
#endif
#endif
#endif
#endif
...
@@ -56,14 +75,124 @@ void tsSetTimeZone() {
...
@@ -56,14 +75,124 @@ void tsSetTimeZone() {
tz
+=
daylight
;
tz
+=
daylight
;
/*
/*
* format:
* format:
* (CST, +0800)
* (CST, +0800)
* (BST, +0100)
* (BST, +0100)
*/
*/
sprintf
(
tsTimezone
,
"(%s, %s%02d00)"
,
tzname
[
daylight
],
tz
>=
0
?
"+"
:
"-"
,
abs
(
tz
));
tsDaylight
=
daylight
;
sprintf
(
outTimezone
,
"(%s, %s%02d00)"
,
tzname
[
daylight
],
tz
>=
0
?
"+"
:
"-"
,
abs
(
tz
));
*
outDaylight
=
daylight
;
}
void
osGetSystemTimezone
(
char
*
outTimezone
)
{
#if defined(_TD_WINDOWS_64) || defined(_TD_WINDOWS_32)
char
*
tz
=
getenv
(
"TZ"
);
if
(
tz
==
NULL
||
strlen
(
tz
)
==
0
)
{
strcpy
(
outTimezone
,
"not configured"
);
}
else
{
strcpy
(
outTimezone
,
tz
);
}
#elif defined(_TD_DARWIN_64)
char
buf
[
4096
]
=
{
0
};
char
*
tz
=
NULL
;
{
int
n
=
readlink
(
"/etc/localtime"
,
buf
,
sizeof
(
buf
));
if
(
n
<
0
)
{
printf
(
"read /etc/localtime error, reason:%s"
,
strerror
(
errno
));
return
;
}
buf
[
n
]
=
'\0'
;
for
(
int
i
=
n
-
1
;
i
>=
0
;
--
i
)
{
if
(
buf
[
i
]
==
'/'
)
{
if
(
tz
)
{
tz
=
buf
+
i
+
1
;
break
;
}
tz
=
buf
+
i
+
1
;
}
}
if
(
!
tz
||
0
==
strchr
(
tz
,
'/'
))
{
printf
(
"parsing /etc/localtime failed"
);
return
;
}
setenv
(
"TZ"
,
tz
,
1
);
tzset
();
}
/*
* NOTE: do not remove it.
* Enforce set the correct daylight saving time(DST) flag according
* to current time
*/
time_t
tx1
=
time
(
NULL
);
struct
tm
tm1
;
localtime_r
(
&
tx1
,
&
tm1
);
/*
* format example:
*
* Asia/Shanghai (CST, +0800)
* Europe/London (BST, +0100)
*/
snprintf
(
outTimezone
,
TD_TIMEZONE_LEN
,
"%s (%s, %+03ld00)"
,
tz
,
tm1
.
tm_isdst
?
tzname
[
daylight
]
:
tzname
[
0
],
-
timezone
/
3600
);
#else
/*
* NOTE: do not remove it.
* Enforce set the correct daylight saving time(DST) flag according
* to current time
*/
time_t
tx1
=
time
(
NULL
);
struct
tm
tm1
;
localtime_r
(
&
tx1
,
&
tm1
);
uInfo
(
"timezone format changed to %s"
,
tsTimezone
);
/* load time zone string from /etc/timezone */
FILE
*
f
=
fopen
(
"/etc/timezone"
,
"r"
);
char
buf
[
68
]
=
{
0
};
if
(
f
!=
NULL
)
{
int
len
=
fread
(
buf
,
64
,
1
,
f
);
if
(
len
<
64
&&
ferror
(
f
))
{
fclose
(
f
);
// printf("read /etc/timezone error, reason:%s", strerror(errno));
return
;
}
#endif
fclose
(
f
);
buf
[
sizeof
(
buf
)
-
1
]
=
0
;
char
*
lineEnd
=
strstr
(
buf
,
"
\n
"
);
if
(
lineEnd
!=
NULL
)
{
*
lineEnd
=
0
;
}
// for CentOS system, /etc/timezone does not exist. Ignore the TZ environment variables
if
(
strlen
(
buf
)
>
0
)
{
setenv
(
"TZ"
,
buf
,
1
);
}
}
// get and set default timezone
tzset
();
/*
* get CURRENT time zone.
* system current time zone is affected by daylight saving time(DST)
*
* e.g., the local time zone of London in DST is GMT+01:00,
* otherwise is GMT+00:00
*/
int32_t
tz
=
(
-
timezone
*
MILLISECOND_PER_SECOND
)
/
MILLISECOND_PER_HOUR
;
tz
+=
daylight
;
/*
* format example:
*
* Asia/Shanghai (CST, +0800)
* Europe/London (BST, +0100)
*/
snprintf
(
outTimezone
,
TD_TIMEZONE_LEN
,
"%s (%s, %s%02d00)"
,
buf
,
tzname
[
daylight
],
tz
>=
0
?
"+"
:
"-"
,
abs
(
tz
));
#endif
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录