--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [22:53:43.749] Vidbot :: start() [22:53:43.750] Vidbot :: _next(), _stepIndex:0 of 4 [22:53:43.750] index :: _onStepStarted_vidbot(), step: 1 [22:53:43.751] Vidbot :: step[0], label:Initializing Core [22:53:43.760] index :: _onStepProgress_vidbot(), percent: 20 [22:53:43.760] Vidbot :: _parse() [22:53:43.761] index :: _onStepProgress_vidbot(), percent: 40 [22:53:43.762] Vidbot :: _validate() [22:53:43.762] index :: _onStepProgress_vidbot(), percent: 60 [22:53:43.763] Vidbot :: _fonts() [22:53:43.763] FabricFontManager :: add(), id: SourceSansPro-Bold [22:53:43.763] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [22:53:43.777] FabricFontManager :: add(), id: SourceSansPro-Light [22:53:43.777] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [22:53:43.778] FabricFontManager :: add(), id: DINOT-Bold [22:53:43.778] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [22:53:43.779] FabricFontManager :: add(), id: DINOT-Light [22:53:43.779] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [22:53:43.780] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [22:53:43.780] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [22:53:43.781] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [22:53:43.781] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [22:53:43.782] index :: _onStepProgress_vidbot(), percent: 80 [22:53:43.782] Vidbot :: _clips() [22:53:43.783] StreamManager :: add(), id:audio_vo, type:audio [22:53:43.783] AudioClip[audio_vo] :: constructor() [22:53:43.783] InputStream[audio_vo] :: constructor() [22:53:43.783] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [22:53:43.786] StreamManager :: add(), id:bg_music, type:audio [22:53:43.786] AudioClip[bg_music] :: constructor() [22:53:43.786] InputStream[bg_music] :: constructor() [22:53:43.786] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [22:53:43.787] StreamManager :: add(), id:simplefadedisplay, type:canvas [22:53:43.787] CanvasStream[canvas_993909974524] :: constructor() [22:53:43.787] InputStream[canvas_993909974524] :: constructor() [22:53:43.879] KenBurnsSlideshow[simplefadedisplay] :: constructor() [22:53:43.879] Overlay[simplefadedisplay] :: constructor() [22:53:43.879] CanvasClip[simplefadedisplay] :: constructor() [22:53:43.879] Clip[simplefadedisplay] :: constructor() [22:53:43.879] clip:"simplefadedisplay" added to stream:"canvas_993909974524" [22:53:43.879] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_993909974524', clipId: 'simplefadedisplay' } [22:53:43.880] StreamManager :: add(), id:caption, type:canvas [22:53:43.880] RenCaption[caption] :: constructor() [22:53:43.880] Ren[caption] :: constructor() [22:53:43.880] Overlay[caption] :: constructor() [22:53:43.880] CanvasClip[caption] :: constructor() [22:53:43.880] Clip[caption] :: constructor() [22:53:43.880] clip:"caption" added to stream:"canvas_993909974524" [22:53:43.880] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_993909974524', clipId: 'caption' } [22:53:43.881] all added... [22:53:43.881] Vidbot :: _next(), _stepIndex:1 of 4 [22:53:43.881] index :: _onStepCompleted_vidbot(), step: 1 [22:53:43.881] index :: _onStepStarted_vidbot(), step: 2 [22:53:43.882] Vidbot :: step[1], label:Initializing Input Streams [22:53:43.882] StreamManager :: init() [22:53:43.883] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [22:53:43.883] index :: _onStepProgress_vidbot(), percent: 33 [22:53:43.883] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [22:53:43.883] index :: _onStepProgress_vidbot(), percent: 67 [22:53:43.884] CanvasStream[canvas_993909974524] :: _init(), BEGIN [22:53:43.884] i:0, c.id:simplefadedisplay [22:53:43.884] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [22:53:43.885] KenBurnsSlideshow[simplefadedisplay] :: _validate() [22:53:43.885] KenBurnsSlideshow[undefined] :: _validateAnim() [22:53:43.886] KenBurnsSlideshow[undefined] :: _validateTheme() [22:53:43.887] i:1, c.id:caption [22:53:43.887] RenCaption[caption] :: _init() [22:53:43.887] RenCaption[caption] :: _validate() [22:53:43.889] KenBurnsSlideshow[simplefadedisplay] :: _build() [22:53:43.895] AnimatedImageFrame[aif] :: constructor() [22:53:43.896] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:43.896] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_1.jpg [22:53:43.909] RenCaption[caption] :: _build() [22:53:43.928] Overlay[caption] :: _animate() [22:53:43.931] CanvasStream[caption] :: _init(), p.then() [22:53:43.958] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:43.962] AnimatedImageFrame[aif] :: _init(), END [22:53:43.964] AnimatedImageFrame[aif] :: constructor() [22:53:43.964] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:43.964] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_2.jpg [22:53:43.988] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:43.990] AnimatedImageFrame[aif] :: _init(), END [22:53:43.990] AnimatedImageFrame[aif] :: constructor() [22:53:43.990] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:43.991] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_3.jpg [22:53:44.016] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.017] AnimatedImageFrame[aif] :: _init(), END [22:53:44.018] AnimatedImageFrame[aif] :: constructor() [22:53:44.018] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.018] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_4.jpg [22:53:44.038] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.039] AnimatedImageFrame[aif] :: _init(), END [22:53:44.040] AnimatedImageFrame[aif] :: constructor() [22:53:44.040] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.040] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_5.jpg [22:53:44.063] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.064] AnimatedImageFrame[aif] :: _init(), END [22:53:44.064] AnimatedImageFrame[aif] :: constructor() [22:53:44.064] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.064] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_6.jpg [22:53:44.085] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.086] AnimatedImageFrame[aif] :: _init(), END [22:53:44.086] AnimatedImageFrame[aif] :: constructor() [22:53:44.086] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.087] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_7.jpg [22:53:44.104] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.105] AnimatedImageFrame[aif] :: _init(), END [22:53:44.106] AnimatedImageFrame[aif] :: constructor() [22:53:44.106] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.106] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_8.jpg [22:53:44.125] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.126] AnimatedImageFrame[aif] :: _init(), END [22:53:44.127] AnimatedImageFrame[aif] :: constructor() [22:53:44.127] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.127] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_9.jpg [22:53:44.148] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.149] AnimatedImageFrame[aif] :: _init(), END [22:53:44.149] AnimatedImageFrame[aif] :: constructor() [22:53:44.150] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.150] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_10.jpg [22:53:44.170] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.171] AnimatedImageFrame[aif] :: _init(), END [22:53:44.171] AnimatedImageFrame[aif] :: constructor() [22:53:44.172] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.172] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_11.jpg [22:53:44.192] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.193] AnimatedImageFrame[aif] :: _init(), END [22:53:44.194] AnimatedImageFrame[aif] :: constructor() [22:53:44.194] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.194] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_12.jpg [22:53:44.216] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.217] AnimatedImageFrame[aif] :: _init(), END [22:53:44.218] AnimatedImageFrame[aif] :: constructor() [22:53:44.218] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.218] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_13.jpg [22:53:44.240] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.241] AnimatedImageFrame[aif] :: _init(), END [22:53:44.242] AnimatedImageFrame[aif] :: constructor() [22:53:44.242] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.242] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_14.jpg [22:53:44.262] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.263] AnimatedImageFrame[aif] :: _init(), END [22:53:44.263] AnimatedImageFrame[aif] :: constructor() [22:53:44.264] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.264] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_15.jpg [22:53:44.282] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.283] AnimatedImageFrame[aif] :: _init(), END [22:53:44.284] AnimatedImageFrame[aif] :: constructor() [22:53:44.284] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.284] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_16.jpg [22:53:44.307] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.308] AnimatedImageFrame[aif] :: _init(), END [22:53:44.309] AnimatedImageFrame[aif] :: constructor() [22:53:44.309] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.309] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_17.jpg [22:53:44.331] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.332] AnimatedImageFrame[aif] :: _init(), END [22:53:44.333] AnimatedImageFrame[aif] :: constructor() [22:53:44.333] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.333] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_18.jpg [22:53:44.356] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.357] AnimatedImageFrame[aif] :: _init(), END [22:53:44.358] AnimatedImageFrame[aif] :: constructor() [22:53:44.358] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.358] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_19.jpg [22:53:44.386] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.387] AnimatedImageFrame[aif] :: _init(), END [22:53:44.387] AnimatedImageFrame[aif] :: constructor() [22:53:44.387] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.388] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_20.jpg [22:53:44.414] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.415] AnimatedImageFrame[aif] :: _init(), END [22:53:44.415] AnimatedImageFrame[aif] :: constructor() [22:53:44.416] AnimatedImageFrame[aif] :: _init(), BEGIN [22:53:44.416] CanvasClip :: LoadImageWithPromise(), src: FDB206DF-9F7B-DE9F-0637-FD913036A8D2_1.jpg [22:53:44.439] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:53:44.440] AnimatedImageFrame[aif] :: _init(), END [22:53:44.441] Overlay[simplefadedisplay] :: _animate() [22:53:44.441] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [22:53:44.441] CanvasStream[simplefadedisplay] :: _init(), p.then() [22:53:44.442] CanvasStream[canvas_993909974524] :: _init(), promise.all.then() [22:53:44.444] CanvasStream[canvas_993909974524] :: _init(), END [22:53:44.444] StreamMangaer :: init(), stream[canvas_993909974524].then() [22:53:44.444] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_993909974524', progress: 1 } [22:53:44.444] index :: _onStepProgress_vidbot(), percent: 100 [22:53:44.444] StreamManager :: init(), promise.all.then... [22:53:44.444] Vidbot :: StreamMgr.on( 'INITED' ) [22:53:44.445] Vidbot :: _next(), _stepIndex:2 of 4 [22:53:44.445] index :: _onStepCompleted_vidbot(), step: 2 [22:53:44.445] index :: _onStepStarted_vidbot(), step: 3 [22:53:44.445] Vidbot :: step[2], label:Rendering Canvas Streams [22:53:44.445] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [22:53:44.445] StreamManager :: render() [22:53:44.446] CanvasStream[canvas_993909974524] :: render() [22:53:44.480] index :: _onStepProgress_vidbot(), percent: 0 [22:54:02.718] index :: _onStepProgress_vidbot(), percent: 5 [22:54:22.210] index :: _onStepProgress_vidbot(), percent: 10 [22:54:43.598] index :: _onStepProgress_vidbot(), percent: 15 [22:55:03.359] index :: _onStepProgress_vidbot(), percent: 20 [22:55:26.265] index :: _onStepProgress_vidbot(), percent: 25 [22:55:42.929] index :: _onStepProgress_vidbot(), percent: 30 [22:56:00.727] index :: _onStepProgress_vidbot(), percent: 35 [22:56:17.846] index :: _onStepProgress_vidbot(), percent: 40 [22:56:35.528] index :: _onStepProgress_vidbot(), percent: 45 [22:56:52.852] index :: _onStepProgress_vidbot(), percent: 50 [22:57:12.332] index :: _onStepProgress_vidbot(), percent: 55 [22:57:32.030] index :: _onStepProgress_vidbot(), percent: 60 [22:57:52.193] index :: _onStepProgress_vidbot(), percent: 65 [22:58:11.251] index :: _onStepProgress_vidbot(), percent: 70 [22:58:29.618] index :: _onStepProgress_vidbot(), percent: 75 [22:58:51.354] index :: _onStepProgress_vidbot(), percent: 80 [22:59:14.889] index :: _onStepProgress_vidbot(), percent: 85 [22:59:38.377] index :: _onStepProgress_vidbot(), percent: 90 [23:00:02.178] index :: _onStepProgress_vidbot(), percent: 95 [23:00:25.148] index :: _onStepProgress_vidbot(), percent: 100 [23:00:27.266] StreamManager :: render(), Promise.all.then... [23:00:27.267] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [23:00:27.267] Vidbot :: _next(), _stepIndex:3 of 4 [23:00:27.267] index :: _onStepCompleted_vidbot(), step: 3 [23:00:27.268] index :: _onStepStarted_vidbot(), step: 4 [23:00:27.269] Vidbot :: step[3], label:Encoding Media [23:00:27.271] CanvasFilters :: Overlay() [23:00:27.272] AudioStream[audio_vo] :: inputOptions() [23:00:27.272] AudioFilters :: Volume() [23:00:27.272] filter: [2:a]volume=1[2_vol] [23:00:27.273] AudioFilters :: Delay() [23:00:27.273] filter: [2_vol]adelay=0|0[2_del] [23:00:27.273] AudioStream[bg_music] :: inputOptions() [23:00:27.273] AudioFilters :: Volume() [23:00:27.273] filter: [3:a]volume=0.25[3_vol] [23:00:27.273] AudioFilters :: FadeOut() [23:00:27.273] filter: [3_vol]afade=t=out:st=61.35:d=1[3_fadeout] [23:00:27.273] AudioFilters :: Delay() [23:00:27.274] filter: [3_fadeout]adelay=0|0[3_del] [23:00:27.274] AudioFilters :: Mix() [23:00:27.274] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [23:00:27.274] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [23:00:27.277] hang.time: 60 [23:00:27.400] Vidbot :: ffmpeg.on( 'start' ) [23:00:27.400] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=61.35 -r 30 -i ./tmp/canvas_993909974524_%05d.png -to 00:01:01.350 -i file:///var/www/html/c [23:00:27.400] lients/10231/audio/FDB206DF-9F7B-DE9F-0637-FD913036A8D2.mp3 -to 00:01:01.350 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF12_Fu [23:00:27.401] nky_2.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 [23:00:27.401] :st=61.35: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 -ma [23:00:27.401] p [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/10231/video/FDB206DF-9F7B-DE [23:00:27.401] 9F-0637-FD913036A8D2.mp4 [23:00:27.557] index :: _onStepProgress_vidbot(), percent: -3385898056 [23:00:27.989] index :: _onStepProgress_vidbot(), percent: 1 [23:00:28.495] index :: _onStepProgress_vidbot(), percent: 5 [23:00:29.506] index :: _onStepProgress_vidbot(), percent: 11 [23:00:30.548] index :: _onStepProgress_vidbot(), percent: 17 [23:00:31.049] index :: _onStepProgress_vidbot(), percent: 20 [23:00:32.049] index :: _onStepProgress_vidbot(), percent: 25 [23:00:33.056] index :: _onStepProgress_vidbot(), percent: 31 [23:00:34.064] index :: _onStepProgress_vidbot(), percent: 37 [23:00:34.565] index :: _onStepProgress_vidbot(), percent: 40 [23:00:35.568] index :: _onStepProgress_vidbot(), percent: 46 [23:00:36.573] index :: _onStepProgress_vidbot(), percent: 51 [23:00:37.588] index :: _onStepProgress_vidbot(), percent: 56 [23:00:38.590] index :: _onStepProgress_vidbot(), percent: 61 [23:00:39.611] index :: _onStepProgress_vidbot(), percent: 66 [23:00:40.629] index :: _onStepProgress_vidbot(), percent: 70 [23:00:41.641] index :: _onStepProgress_vidbot(), percent: 76 [23:00:42.647] index :: _onStepProgress_vidbot(), percent: 83 [23:00:43.150] index :: _onStepProgress_vidbot(), percent: 87 [23:00:43.661] index :: _onStepProgress_vidbot(), percent: 90 [23:00:44.669] index :: _onStepProgress_vidbot(), percent: 96 [23:00:45.293] index :: _onStepProgress_vidbot(), percent: 100 [23:00:45.312] Vidbot :: ffmpeg.on( 'end' ), Done! [23:00:45.312] StreamManager :: dispose() [23:00:45.312] CanvasStream[canvas_993909974524] :: dispose() [23:00:45.330] Vidbot :: fflog.on( 'finish' ) [23:00:45.331] fflog.path: /var/www/html/clients/10231/video/FDB206DF-9F7B-DE9F-0637-FD913036A8D2.mp4.fflog [23:00:45.331] Vidbot :: _next(), _stepIndex:4 of 4 [23:00:45.331] index :: _onStepCompleted_vidbot(), step: 4 [23:00:45.331] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 421.6, output: '/var/www/html/clients/10231/video/FDB206DF-9F7B-DE9F-0637-FD913036A8D2.mp4', duration: 61.35 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/10231/video/FDB206DF-9F7B-DE9F-0637-FD913036A8D2.mp4 Media Duration : 00:01:01.350 Generation Time : 00:07:01.600 ---------------------------------------------------------------------------------------------------------------