--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [15:49:29.805] Vidbot :: start() [15:49:29.805] Vidbot :: _next(), _stepIndex:0 of 4 [15:49:29.806] index :: _onStepStarted_vidbot(), step: 1 [15:49:29.807] Vidbot :: step[0], label:Initializing Core [15:49:29.819] index :: _onStepProgress_vidbot(), percent: 20 [15:49:29.819] Vidbot :: _parse() [15:49:29.820] index :: _onStepProgress_vidbot(), percent: 40 [15:49:29.820] Vidbot :: _validate() [15:49:29.821] index :: _onStepProgress_vidbot(), percent: 60 [15:49:29.821] Vidbot :: _fonts() [15:49:29.822] FabricFontManager :: add(), id: SourceSansPro-Bold [15:49:29.822] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [15:49:29.831] FabricFontManager :: add(), id: SourceSansPro-Light [15:49:29.831] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [15:49:29.832] FabricFontManager :: add(), id: DINOT-Bold [15:49:29.832] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [15:49:29.833] FabricFontManager :: add(), id: DINOT-Light [15:49:29.833] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [15:49:29.834] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [15:49:29.834] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [15:49:29.834] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [15:49:29.835] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [15:49:29.836] index :: _onStepProgress_vidbot(), percent: 80 [15:49:29.836] Vidbot :: _clips() [15:49:29.837] StreamManager :: add(), id:audio_vo, type:audio [15:49:29.837] AudioClip[audio_vo] :: constructor() [15:49:29.837] InputStream[audio_vo] :: constructor() [15:49:29.837] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [15:49:29.840] StreamManager :: add(), id:bg_music, type:audio [15:49:29.840] AudioClip[bg_music] :: constructor() [15:49:29.840] InputStream[bg_music] :: constructor() [15:49:29.840] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [15:49:29.840] StreamManager :: add(), id:simplefadedisplay, type:canvas [15:49:29.841] CanvasStream[canvas_493370682708] :: constructor() [15:49:29.841] InputStream[canvas_493370682708] :: constructor() [15:49:29.916] KenBurnsSlideshow[simplefadedisplay] :: constructor() [15:49:29.916] Overlay[simplefadedisplay] :: constructor() [15:49:29.916] CanvasClip[simplefadedisplay] :: constructor() [15:49:29.916] Clip[simplefadedisplay] :: constructor() [15:49:29.916] clip:"simplefadedisplay" added to stream:"canvas_493370682708" [15:49:29.917] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_493370682708', clipId: 'simplefadedisplay' } [15:49:29.917] StreamManager :: add(), id:caption, type:canvas [15:49:29.917] RenCaption[caption] :: constructor() [15:49:29.917] Ren[caption] :: constructor() [15:49:29.917] Overlay[caption] :: constructor() [15:49:29.917] CanvasClip[caption] :: constructor() [15:49:29.917] Clip[caption] :: constructor() [15:49:29.917] clip:"caption" added to stream:"canvas_493370682708" [15:49:29.917] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_493370682708', clipId: 'caption' } [15:49:29.918] all added... [15:49:29.918] Vidbot :: _next(), _stepIndex:1 of 4 [15:49:29.918] index :: _onStepCompleted_vidbot(), step: 1 [15:49:29.918] index :: _onStepStarted_vidbot(), step: 2 [15:49:29.918] Vidbot :: step[1], label:Initializing Input Streams [15:49:29.919] StreamManager :: init() [15:49:29.919] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [15:49:29.919] index :: _onStepProgress_vidbot(), percent: 33 [15:49:29.919] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [15:49:29.920] index :: _onStepProgress_vidbot(), percent: 67 [15:49:29.920] CanvasStream[canvas_493370682708] :: _init(), BEGIN [15:49:29.920] i:0, c.id:simplefadedisplay [15:49:29.920] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [15:49:29.921] KenBurnsSlideshow[simplefadedisplay] :: _validate() [15:49:29.921] KenBurnsSlideshow[undefined] :: _validateAnim() [15:49:29.922] KenBurnsSlideshow[undefined] :: _validateTheme() [15:49:29.923] i:1, c.id:caption [15:49:29.923] RenCaption[caption] :: _init() [15:49:29.923] RenCaption[caption] :: _validate() [15:49:29.925] KenBurnsSlideshow[simplefadedisplay] :: _build() [15:49:29.930] AnimatedImageFrame[aif] :: constructor() [15:49:29.932] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:29.932] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_1.jpg [15:49:29.944] RenCaption[caption] :: _build() [15:49:29.962] Overlay[caption] :: _animate() [15:49:29.965] CanvasStream[caption] :: _init(), p.then() [15:49:29.989] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:29.993] AnimatedImageFrame[aif] :: _init(), END [15:49:29.995] AnimatedImageFrame[aif] :: constructor() [15:49:29.995] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:29.995] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_2.jpg [15:49:30.034] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.035] AnimatedImageFrame[aif] :: _init(), END [15:49:30.036] AnimatedImageFrame[aif] :: constructor() [15:49:30.036] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.036] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_3.jpg [15:49:30.071] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.072] AnimatedImageFrame[aif] :: _init(), END [15:49:30.073] AnimatedImageFrame[aif] :: constructor() [15:49:30.073] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.073] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_4.jpg [15:49:30.098] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.099] AnimatedImageFrame[aif] :: _init(), END [15:49:30.100] AnimatedImageFrame[aif] :: constructor() [15:49:30.100] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.100] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_5.jpg [15:49:30.117] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.118] AnimatedImageFrame[aif] :: _init(), END [15:49:30.118] AnimatedImageFrame[aif] :: constructor() [15:49:30.119] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.119] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_6.jpg [15:49:30.133] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.134] AnimatedImageFrame[aif] :: _init(), END [15:49:30.134] AnimatedImageFrame[aif] :: constructor() [15:49:30.134] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.135] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_7.jpg [15:49:30.150] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.151] AnimatedImageFrame[aif] :: _init(), END [15:49:30.151] AnimatedImageFrame[aif] :: constructor() [15:49:30.151] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.151] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_8.jpg [15:49:30.167] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.168] AnimatedImageFrame[aif] :: _init(), END [15:49:30.168] AnimatedImageFrame[aif] :: constructor() [15:49:30.168] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.168] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_9.jpg [15:49:30.187] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.188] AnimatedImageFrame[aif] :: _init(), END [15:49:30.188] AnimatedImageFrame[aif] :: constructor() [15:49:30.188] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.188] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_10.jpg [15:49:30.213] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.214] AnimatedImageFrame[aif] :: _init(), END [15:49:30.215] AnimatedImageFrame[aif] :: constructor() [15:49:30.215] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.215] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_11.jpg [15:49:30.236] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.237] AnimatedImageFrame[aif] :: _init(), END [15:49:30.237] AnimatedImageFrame[aif] :: constructor() [15:49:30.237] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.237] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_12.jpg [15:49:30.259] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.260] AnimatedImageFrame[aif] :: _init(), END [15:49:30.261] AnimatedImageFrame[aif] :: constructor() [15:49:30.261] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.261] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_13.jpg [15:49:30.278] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.279] AnimatedImageFrame[aif] :: _init(), END [15:49:30.279] AnimatedImageFrame[aif] :: constructor() [15:49:30.279] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.279] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_14.jpg [15:49:30.304] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.305] AnimatedImageFrame[aif] :: _init(), END [15:49:30.305] AnimatedImageFrame[aif] :: constructor() [15:49:30.305] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.305] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_15.jpg [15:49:30.325] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.326] AnimatedImageFrame[aif] :: _init(), END [15:49:30.326] AnimatedImageFrame[aif] :: constructor() [15:49:30.327] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.327] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_16.jpg [15:49:30.346] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.347] AnimatedImageFrame[aif] :: _init(), END [15:49:30.348] AnimatedImageFrame[aif] :: constructor() [15:49:30.348] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.348] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_17.jpg [15:49:30.367] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.368] AnimatedImageFrame[aif] :: _init(), END [15:49:30.369] AnimatedImageFrame[aif] :: constructor() [15:49:30.369] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.369] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_18.jpg [15:49:30.381] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.382] AnimatedImageFrame[aif] :: _init(), END [15:49:30.383] AnimatedImageFrame[aif] :: constructor() [15:49:30.383] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.383] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_19.jpg [15:49:30.406] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.407] AnimatedImageFrame[aif] :: _init(), END [15:49:30.408] AnimatedImageFrame[aif] :: constructor() [15:49:30.408] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.408] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_20.jpg [15:49:30.426] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.427] AnimatedImageFrame[aif] :: _init(), END [15:49:30.427] AnimatedImageFrame[aif] :: constructor() [15:49:30.428] AnimatedImageFrame[aif] :: _init(), BEGIN [15:49:30.428] CanvasClip :: LoadImageWithPromise(), src: 4A6A677D-D431-9700-44A9-2BB83AEB9C10_1.jpg [15:49:30.471] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:49:30.472] AnimatedImageFrame[aif] :: _init(), END [15:49:30.472] Overlay[simplefadedisplay] :: _animate() [15:49:30.473] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [15:49:30.473] CanvasStream[simplefadedisplay] :: _init(), p.then() [15:49:30.473] CanvasStream[canvas_493370682708] :: _init(), promise.all.then() [15:49:30.475] CanvasStream[canvas_493370682708] :: _init(), END [15:49:30.476] StreamMangaer :: init(), stream[canvas_493370682708].then() [15:49:30.476] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_493370682708', progress: 1 } [15:49:30.476] index :: _onStepProgress_vidbot(), percent: 100 [15:49:30.476] StreamManager :: init(), promise.all.then... [15:49:30.476] Vidbot :: StreamMgr.on( 'INITED' ) [15:49:30.476] Vidbot :: _next(), _stepIndex:2 of 4 [15:49:30.476] index :: _onStepCompleted_vidbot(), step: 2 [15:49:30.476] index :: _onStepStarted_vidbot(), step: 3 [15:49:30.477] Vidbot :: step[2], label:Rendering Canvas Streams [15:49:30.477] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [15:49:30.477] StreamManager :: render() [15:49:30.478] CanvasStream[canvas_493370682708] :: render() [15:49:30.508] index :: _onStepProgress_vidbot(), percent: 0 [15:49:46.959] index :: _onStepProgress_vidbot(), percent: 5 [15:50:00.147] index :: _onStepProgress_vidbot(), percent: 10 [15:50:16.233] index :: _onStepProgress_vidbot(), percent: 15 [15:50:29.922] index :: _onStepProgress_vidbot(), percent: 20 [15:50:47.963] index :: _onStepProgress_vidbot(), percent: 25 [15:51:02.614] index :: _onStepProgress_vidbot(), percent: 30 [15:51:17.776] index :: _onStepProgress_vidbot(), percent: 35 [15:51:33.475] index :: _onStepProgress_vidbot(), percent: 40 [15:51:46.030] index :: _onStepProgress_vidbot(), percent: 45 [15:52:03.820] index :: _onStepProgress_vidbot(), percent: 50 [15:52:23.295] index :: _onStepProgress_vidbot(), percent: 55 [15:52:41.727] index :: _onStepProgress_vidbot(), percent: 60 [15:53:02.192] index :: _onStepProgress_vidbot(), percent: 65 [15:53:24.212] index :: _onStepProgress_vidbot(), percent: 70 [15:53:48.171] index :: _onStepProgress_vidbot(), percent: 75 [15:54:08.450] index :: _onStepProgress_vidbot(), percent: 80 [15:54:23.689] index :: _onStepProgress_vidbot(), percent: 85 [15:54:40.792] index :: _onStepProgress_vidbot(), percent: 90 [15:55:02.572] index :: _onStepProgress_vidbot(), percent: 95 [15:55:20.202] index :: _onStepProgress_vidbot(), percent: 100 [15:55:22.040] StreamManager :: render(), Promise.all.then... [15:55:22.040] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [15:55:22.040] Vidbot :: _next(), _stepIndex:3 of 4 [15:55:22.041] index :: _onStepCompleted_vidbot(), step: 3 [15:55:22.041] index :: _onStepStarted_vidbot(), step: 4 [15:55:22.042] Vidbot :: step[3], label:Encoding Media [15:55:22.045] CanvasFilters :: Overlay() [15:55:22.046] AudioStream[audio_vo] :: inputOptions() [15:55:22.046] AudioFilters :: Volume() [15:55:22.046] filter: [2:a]volume=1[2_vol] [15:55:22.046] AudioFilters :: Delay() [15:55:22.046] filter: [2_vol]adelay=0|0[2_del] [15:55:22.046] AudioStream[bg_music] :: inputOptions() [15:55:22.046] AudioFilters :: Volume() [15:55:22.047] filter: [3:a]volume=0.25[3_vol] [15:55:22.047] AudioFilters :: FadeOut() [15:55:22.047] filter: [3_vol]afade=t=out:st=62.81:d=1[3_fadeout] [15:55:22.047] AudioFilters :: Delay() [15:55:22.047] filter: [3_fadeout]adelay=0|0[3_del] [15:55:22.047] AudioFilters :: Mix() [15:55:22.047] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:55:22.047] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:55:22.050] hang.time: 60 [15:55:22.150] Vidbot :: ffmpeg.on( 'start' ) [15:55:22.151] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=62.81 -r 30 -i ./tmp/canvas_493370682708_%05d.png -to 00:01:02.810 -i file:///var/www/html/c [15:55:22.151] lients/1380/audio/4A6A677D-D431-9700-44A9-2BB83AEB9C10.mp3 -to 00:01:02.810 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/bgmusic. [15:55:22.151] 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=62 [15:55:22.151] .81: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_o [15:55:22.151] ut] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/1380/video/4A6A677D-D431-9700-44A9 [15:55:22.151] -2BB83AEB9C10.mp4 [15:55:22.311] index :: _onStepProgress_vidbot(), percent: -3307193850 [15:55:22.720] index :: _onStepProgress_vidbot(), percent: 1 [15:55:23.733] index :: _onStepProgress_vidbot(), percent: 5 [15:55:24.737] index :: _onStepProgress_vidbot(), percent: 10 [15:55:25.740] index :: _onStepProgress_vidbot(), percent: 15 [15:55:26.754] index :: _onStepProgress_vidbot(), percent: 20 [15:55:27.759] index :: _onStepProgress_vidbot(), percent: 25 [15:55:28.763] index :: _onStepProgress_vidbot(), percent: 31 [15:55:29.765] index :: _onStepProgress_vidbot(), percent: 38 [15:55:30.267] index :: _onStepProgress_vidbot(), percent: 41 [15:55:31.304] index :: _onStepProgress_vidbot(), percent: 46 [15:55:32.307] index :: _onStepProgress_vidbot(), percent: 52 [15:55:32.808] index :: _onStepProgress_vidbot(), percent: 55 [15:55:34.326] index :: _onStepProgress_vidbot(), percent: 62 [15:55:35.337] index :: _onStepProgress_vidbot(), percent: 67 [15:55:35.845] index :: _onStepProgress_vidbot(), percent: 70 [15:55:36.862] index :: _onStepProgress_vidbot(), percent: 77 [15:55:37.363] index :: _onStepProgress_vidbot(), percent: 80 [15:55:38.367] index :: _onStepProgress_vidbot(), percent: 86 [15:55:39.369] index :: _onStepProgress_vidbot(), percent: 92 [15:55:39.875] index :: _onStepProgress_vidbot(), percent: 95 [15:55:40.609] index :: _onStepProgress_vidbot(), percent: 100 [15:55:40.642] Vidbot :: ffmpeg.on( 'end' ), Done! [15:55:40.642] StreamManager :: dispose() [15:55:40.643] CanvasStream[canvas_493370682708] :: dispose() [15:55:40.648] Vidbot :: fflog.on( 'finish' ) [15:55:40.648] fflog.path: /var/www/html/clients/1380/video/4A6A677D-D431-9700-44A9-2BB83AEB9C10.mp4.fflog [15:55:40.648] Vidbot :: _next(), _stepIndex:4 of 4 [15:55:40.648] index :: _onStepCompleted_vidbot(), step: 4 [15:55:40.649] index :: _onComplete_vidbot(), data: { stepTime: 0.001, appTime: 370.862, output: '/var/www/html/clients/1380/video/4A6A677D-D431-9700-44A9-2BB83AEB9C10.mp4', duration: 62.81 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/1380/video/4A6A677D-D431-9700-44A9-2BB83AEB9C10.mp4 Media Duration : 00:01:02.810 Generation Time : 00:06:10.862 ---------------------------------------------------------------------------------------------------------------