--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [12:50:07.165] Vidbot :: start() [12:50:07.166] Vidbot :: _next(), _stepIndex:0 of 4 [12:50:07.166] index :: _onStepStarted_vidbot(), step: 1 [12:50:07.168] Vidbot :: step[0], label:Initializing Core [12:50:07.177] index :: _onStepProgress_vidbot(), percent: 20 [12:50:07.177] Vidbot :: _parse() [12:50:07.179] index :: _onStepProgress_vidbot(), percent: 40 [12:50:07.179] Vidbot :: _validate() [12:50:07.180] index :: _onStepProgress_vidbot(), percent: 60 [12:50:07.180] Vidbot :: _fonts() [12:50:07.180] FabricFontManager :: add(), id: SourceSansPro-Bold [12:50:07.180] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [12:50:07.189] FabricFontManager :: add(), id: SourceSansPro-Light [12:50:07.189] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [12:50:07.190] FabricFontManager :: add(), id: DINOT-Bold [12:50:07.190] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [12:50:07.191] FabricFontManager :: add(), id: DINOT-Light [12:50:07.191] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [12:50:07.192] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [12:50:07.192] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [12:50:07.192] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [12:50:07.193] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [12:50:07.194] index :: _onStepProgress_vidbot(), percent: 80 [12:50:07.194] Vidbot :: _clips() [12:50:07.194] StreamManager :: add(), id:audio_vo, type:audio [12:50:07.195] AudioClip[audio_vo] :: constructor() [12:50:07.195] InputStream[audio_vo] :: constructor() [12:50:07.195] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [12:50:07.198] StreamManager :: add(), id:bg_music, type:audio [12:50:07.198] AudioClip[bg_music] :: constructor() [12:50:07.198] InputStream[bg_music] :: constructor() [12:50:07.198] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [12:50:07.198] StreamManager :: add(), id:simplefadedisplay, type:canvas [12:50:07.199] CanvasStream[canvas_354101272162] :: constructor() [12:50:07.199] InputStream[canvas_354101272162] :: constructor() [12:50:07.281] KenBurnsSlideshow[simplefadedisplay] :: constructor() [12:50:07.281] Overlay[simplefadedisplay] :: constructor() [12:50:07.282] CanvasClip[simplefadedisplay] :: constructor() [12:50:07.282] Clip[simplefadedisplay] :: constructor() [12:50:07.282] clip:"simplefadedisplay" added to stream:"canvas_354101272162" [12:50:07.282] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_354101272162', clipId: 'simplefadedisplay' } [12:50:07.282] StreamManager :: add(), id:caption, type:canvas [12:50:07.282] RenCaption[caption] :: constructor() [12:50:07.282] Ren[caption] :: constructor() [12:50:07.283] Overlay[caption] :: constructor() [12:50:07.283] CanvasClip[caption] :: constructor() [12:50:07.283] Clip[caption] :: constructor() [12:50:07.283] clip:"caption" added to stream:"canvas_354101272162" [12:50:07.283] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_354101272162', clipId: 'caption' } [12:50:07.283] all added... [12:50:07.283] Vidbot :: _next(), _stepIndex:1 of 4 [12:50:07.283] index :: _onStepCompleted_vidbot(), step: 1 [12:50:07.284] index :: _onStepStarted_vidbot(), step: 2 [12:50:07.284] Vidbot :: step[1], label:Initializing Input Streams [12:50:07.284] StreamManager :: init() [12:50:07.285] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [12:50:07.285] index :: _onStepProgress_vidbot(), percent: 33 [12:50:07.285] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [12:50:07.285] index :: _onStepProgress_vidbot(), percent: 67 [12:50:07.286] CanvasStream[canvas_354101272162] :: _init(), BEGIN [12:50:07.286] i:0, c.id:simplefadedisplay [12:50:07.286] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [12:50:07.286] KenBurnsSlideshow[simplefadedisplay] :: _validate() [12:50:07.287] KenBurnsSlideshow[undefined] :: _validateAnim() [12:50:07.287] KenBurnsSlideshow[undefined] :: _validateTheme() [12:50:07.288] i:1, c.id:caption [12:50:07.289] RenCaption[caption] :: _init() [12:50:07.289] RenCaption[caption] :: _validate() [12:50:07.290] KenBurnsSlideshow[simplefadedisplay] :: _build() [12:50:07.297] AnimatedImageFrame[aif] :: constructor() [12:50:07.298] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.298] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_1.jpg [12:50:07.311] RenCaption[caption] :: _build() [12:50:07.328] Overlay[caption] :: _animate() [12:50:07.331] CanvasStream[caption] :: _init(), p.then() [12:50:07.355] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.359] AnimatedImageFrame[aif] :: _init(), END [12:50:07.361] AnimatedImageFrame[aif] :: constructor() [12:50:07.361] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.362] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_2.jpg [12:50:07.381] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.382] AnimatedImageFrame[aif] :: _init(), END [12:50:07.383] AnimatedImageFrame[aif] :: constructor() [12:50:07.383] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.383] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_3.jpg [12:50:07.411] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.413] AnimatedImageFrame[aif] :: _init(), END [12:50:07.413] AnimatedImageFrame[aif] :: constructor() [12:50:07.414] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.414] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_4.jpg [12:50:07.432] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.433] AnimatedImageFrame[aif] :: _init(), END [12:50:07.434] AnimatedImageFrame[aif] :: constructor() [12:50:07.434] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.434] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_5.jpg [12:50:07.452] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.453] AnimatedImageFrame[aif] :: _init(), END [12:50:07.453] AnimatedImageFrame[aif] :: constructor() [12:50:07.453] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.454] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_6.jpg [12:50:07.471] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.472] AnimatedImageFrame[aif] :: _init(), END [12:50:07.473] AnimatedImageFrame[aif] :: constructor() [12:50:07.473] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.473] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_7.jpg [12:50:07.491] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.492] AnimatedImageFrame[aif] :: _init(), END [12:50:07.493] AnimatedImageFrame[aif] :: constructor() [12:50:07.493] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.493] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_8.jpg [12:50:07.511] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.512] AnimatedImageFrame[aif] :: _init(), END [12:50:07.512] AnimatedImageFrame[aif] :: constructor() [12:50:07.513] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.513] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_9.jpg [12:50:07.530] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.532] AnimatedImageFrame[aif] :: _init(), END [12:50:07.532] AnimatedImageFrame[aif] :: constructor() [12:50:07.532] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.532] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_10.jpg [12:50:07.553] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.554] AnimatedImageFrame[aif] :: _init(), END [12:50:07.554] AnimatedImageFrame[aif] :: constructor() [12:50:07.555] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.555] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_11.jpg [12:50:07.575] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.576] AnimatedImageFrame[aif] :: _init(), END [12:50:07.576] AnimatedImageFrame[aif] :: constructor() [12:50:07.576] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.576] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_12.jpg [12:50:07.594] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.595] AnimatedImageFrame[aif] :: _init(), END [12:50:07.596] AnimatedImageFrame[aif] :: constructor() [12:50:07.596] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.596] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_13.jpg [12:50:07.614] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.615] AnimatedImageFrame[aif] :: _init(), END [12:50:07.615] AnimatedImageFrame[aif] :: constructor() [12:50:07.616] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.616] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_14.jpg [12:50:07.637] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.638] AnimatedImageFrame[aif] :: _init(), END [12:50:07.639] AnimatedImageFrame[aif] :: constructor() [12:50:07.639] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.639] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_15.jpg [12:50:07.657] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.658] AnimatedImageFrame[aif] :: _init(), END [12:50:07.658] AnimatedImageFrame[aif] :: constructor() [12:50:07.658] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.658] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_16.jpg [12:50:07.675] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.676] AnimatedImageFrame[aif] :: _init(), END [12:50:07.677] AnimatedImageFrame[aif] :: constructor() [12:50:07.677] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.677] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_17.jpg [12:50:07.696] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.697] AnimatedImageFrame[aif] :: _init(), END [12:50:07.697] AnimatedImageFrame[aif] :: constructor() [12:50:07.697] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.697] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_18.jpg [12:50:07.715] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.716] AnimatedImageFrame[aif] :: _init(), END [12:50:07.716] AnimatedImageFrame[aif] :: constructor() [12:50:07.716] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.716] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_19.jpg [12:50:07.739] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.741] AnimatedImageFrame[aif] :: _init(), END [12:50:07.741] AnimatedImageFrame[aif] :: constructor() [12:50:07.741] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.741] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_20.jpg [12:50:07.760] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.761] AnimatedImageFrame[aif] :: _init(), END [12:50:07.761] AnimatedImageFrame[aif] :: constructor() [12:50:07.761] AnimatedImageFrame[aif] :: _init(), BEGIN [12:50:07.761] CanvasClip :: LoadImageWithPromise(), src: F9936A09-1C5D-BA33-7D8D-6D60EDD29270_1.jpg [12:50:07.779] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [12:50:07.780] AnimatedImageFrame[aif] :: _init(), END [12:50:07.780] Overlay[simplefadedisplay] :: _animate() [12:50:07.781] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [12:50:07.781] CanvasStream[simplefadedisplay] :: _init(), p.then() [12:50:07.781] CanvasStream[canvas_354101272162] :: _init(), promise.all.then() [12:50:07.783] CanvasStream[canvas_354101272162] :: _init(), END [12:50:07.783] StreamMangaer :: init(), stream[canvas_354101272162].then() [12:50:07.783] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_354101272162', progress: 1 } [12:50:07.784] index :: _onStepProgress_vidbot(), percent: 100 [12:50:07.784] StreamManager :: init(), promise.all.then... [12:50:07.784] Vidbot :: StreamMgr.on( 'INITED' ) [12:50:07.784] Vidbot :: _next(), _stepIndex:2 of 4 [12:50:07.784] index :: _onStepCompleted_vidbot(), step: 2 [12:50:07.784] index :: _onStepStarted_vidbot(), step: 3 [12:50:07.785] Vidbot :: step[2], label:Rendering Canvas Streams [12:50:07.785] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [12:50:07.785] StreamManager :: render() [12:50:07.786] CanvasStream[canvas_354101272162] :: render() [12:50:07.823] index :: _onStepProgress_vidbot(), percent: 0 [12:50:22.719] index :: _onStepProgress_vidbot(), percent: 5 [12:50:35.827] index :: _onStepProgress_vidbot(), percent: 10 [12:50:48.668] index :: _onStepProgress_vidbot(), percent: 15 [12:51:01.457] index :: _onStepProgress_vidbot(), percent: 20 [12:51:14.663] index :: _onStepProgress_vidbot(), percent: 25 [12:51:28.284] index :: _onStepProgress_vidbot(), percent: 30 [12:51:43.089] index :: _onStepProgress_vidbot(), percent: 35 [12:51:57.850] index :: _onStepProgress_vidbot(), percent: 40 [12:52:11.697] index :: _onStepProgress_vidbot(), percent: 45 [12:52:28.096] index :: _onStepProgress_vidbot(), percent: 50 [12:52:46.490] index :: _onStepProgress_vidbot(), percent: 55 [12:53:03.242] index :: _onStepProgress_vidbot(), percent: 60 [12:53:20.013] index :: _onStepProgress_vidbot(), percent: 65 [12:53:37.634] index :: _onStepProgress_vidbot(), percent: 70 [12:53:52.741] index :: _onStepProgress_vidbot(), percent: 75 [12:54:08.002] index :: _onStepProgress_vidbot(), percent: 80 [12:54:25.369] index :: _onStepProgress_vidbot(), percent: 85 [12:54:41.353] index :: _onStepProgress_vidbot(), percent: 90 [12:54:59.948] index :: _onStepProgress_vidbot(), percent: 95 [12:55:18.854] index :: _onStepProgress_vidbot(), percent: 100 [12:55:20.558] StreamManager :: render(), Promise.all.then... [12:55:20.559] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [12:55:20.559] Vidbot :: _next(), _stepIndex:3 of 4 [12:55:20.559] index :: _onStepCompleted_vidbot(), step: 3 [12:55:20.560] index :: _onStepStarted_vidbot(), step: 4 [12:55:20.561] Vidbot :: step[3], label:Encoding Media [12:55:20.564] CanvasFilters :: Overlay() [12:55:20.565] AudioStream[audio_vo] :: inputOptions() [12:55:20.565] AudioFilters :: Volume() [12:55:20.565] filter: [2:a]volume=1[2_vol] [12:55:20.565] AudioFilters :: Delay() [12:55:20.565] filter: [2_vol]adelay=0|0[2_del] [12:55:20.565] AudioStream[bg_music] :: inputOptions() [12:55:20.566] AudioFilters :: Volume() [12:55:20.566] filter: [3:a]volume=0.25[3_vol] [12:55:20.566] AudioFilters :: FadeOut() [12:55:20.567] filter: [3_vol]afade=t=out:st=61.75:d=1[3_fadeout] [12:55:20.567] AudioFilters :: Delay() [12:55:20.567] filter: [3_fadeout]adelay=0|0[3_del] [12:55:20.567] AudioFilters :: Mix() [12:55:20.567] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [12:55:20.567] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [12:55:20.570] hang.time: 60 [12:55:20.676] Vidbot :: ffmpeg.on( 'start' ) [12:55:20.677] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=61.75 -r 30 -i ./tmp/canvas_354101272162_%05d.png -to 00:01:01.750 -i file:///var/www/html/c [12:55:20.677] lients/5260/audio/F9936A09-1C5D-BA33-7D8D-6D60EDD29270.mp3 -to 00:01:01.750 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Concept9 [12:55:20.677] .mp3 -y -filter_complex [0:v][1:v]overlay=x=0:y=0[1_out];[2:a]volume=1[2_vol];[2_vol]adelay=0|0[2_del];[3:a]volume=0.25[3_vol];[3_vol]afade=t=out:st=6 [12:55:20.677] 1.75:d=1[3_fadeout];[3_fadeout]adelay=0|0[3_del];[2_del][3_del]amix=inputs=2:duration=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_ [12:55:20.677] out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/5260/video/F9936A09-1C5D-BA33-7D8 [12:55:20.677] D-6D60EDD29270.mp4 [12:55:20.825] index :: _onStepProgress_vidbot(), percent: -3363965113 [12:55:21.264] index :: _onStepProgress_vidbot(), percent: 1 [12:55:22.273] index :: _onStepProgress_vidbot(), percent: 7 [12:55:22.780] index :: _onStepProgress_vidbot(), percent: 10 [12:55:23.792] index :: _onStepProgress_vidbot(), percent: 16 [12:55:24.811] index :: _onStepProgress_vidbot(), percent: 21 [12:55:25.824] index :: _onStepProgress_vidbot(), percent: 26 [12:55:26.830] index :: _onStepProgress_vidbot(), percent: 31 [12:55:27.841] index :: _onStepProgress_vidbot(), percent: 37 [12:55:28.352] index :: _onStepProgress_vidbot(), percent: 40 [12:55:29.352] index :: _onStepProgress_vidbot(), percent: 45 [12:55:30.371] index :: _onStepProgress_vidbot(), percent: 50 [12:55:31.379] index :: _onStepProgress_vidbot(), percent: 56 [12:55:32.390] index :: _onStepProgress_vidbot(), percent: 62 [12:55:32.891] index :: _onStepProgress_vidbot(), percent: 65 [12:55:33.891] index :: _onStepProgress_vidbot(), percent: 71 [12:55:34.896] index :: _onStepProgress_vidbot(), percent: 77 [12:55:35.897] index :: _onStepProgress_vidbot(), percent: 82 [12:55:36.403] index :: _onStepProgress_vidbot(), percent: 85 [12:55:37.418] index :: _onStepProgress_vidbot(), percent: 90 [12:55:38.420] index :: _onStepProgress_vidbot(), percent: 95 [12:55:39.130] index :: _onStepProgress_vidbot(), percent: 100 [12:55:39.162] Vidbot :: ffmpeg.on( 'end' ), Done! [12:55:39.162] StreamManager :: dispose() [12:55:39.163] CanvasStream[canvas_354101272162] :: dispose() [12:55:39.168] Vidbot :: fflog.on( 'finish' ) [12:55:39.168] fflog.path: /var/www/html/clients/5260/video/F9936A09-1C5D-BA33-7D8D-6D60EDD29270.mp4.fflog [12:55:39.168] Vidbot :: _next(), _stepIndex:4 of 4 [12:55:39.168] index :: _onStepCompleted_vidbot(), step: 4 [12:55:39.169] index :: _onComplete_vidbot(), data: { stepTime: 0.001, appTime: 332.025, output: '/var/www/html/clients/5260/video/F9936A09-1C5D-BA33-7D8D-6D60EDD29270.mp4', duration: 61.75 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/5260/video/F9936A09-1C5D-BA33-7D8D-6D60EDD29270.mp4 Media Duration : 00:01:01.750 Generation Time : 00:05:32.024 ---------------------------------------------------------------------------------------------------------------