#[allow(non_camel_case_types)]
///Auto-generated by `deno_ops`, i.e: `#[op]`
///
///Use `send_stdin::decl()` to get an op-declaration
///you can include in a `deno_core::Extension`.
pub struct send_stdin;
#[doc(hidden)]
impl send_stdin {
    pub fn name() -> &'static str {
        stringify!(send_stdin)
    }
    pub fn v8_fn_ptr<'scope>() -> deno_core::v8::FunctionCallback {
        use deno_core::v8::MapFnTo;
        Self::v8_func.map_fn_to()
    }
    pub fn decl<'scope>() -> deno_core::OpDecl {
        deno_core::OpDecl {
            name: Self::name(),
            v8_fn_ptr: Self::v8_fn_ptr(),
            enabled: true,
            fast_fn: None,
            is_async: true,
            is_unstable: false,
            is_v8: false,
            argc: 1usize,
        }
    }
    #[inline]
    #[allow(clippy::too_many_arguments)]
    async fn call(state: &mut OpState, cmd: String) -> Result<(), anyhow::Error> {
        let instance = state.borrow::<MinecraftInstance>().clone();
        instance.send_command(&cmd, CausedBy::Unknown).await?;
        Ok(())
    }
    pub fn v8_func<'scope>(
        scope: &mut deno_core::v8::HandleScope<'scope>,
        args: deno_core::v8::FunctionCallbackArguments,
        mut rv: deno_core::v8::ReturnValue,
    ) {
        use deno_core::futures::FutureExt;
        let ctx = unsafe {
            &*(deno_core::v8::Local::<deno_core::v8::External>::cast(args.data()).value()
                as *const deno_core::_ops::OpCtx)
        };
        let op_id = ctx.id;
        let promise_id = args.get(0);
        let promise_id = deno_core::v8::Local::<
            deno_core::v8::Integer,
        >::try_from(promise_id)
            .map(|l| l.value() as deno_core::PromiseId)
            .map_err(deno_core::anyhow::Error::from);
        let promise_id: deno_core::PromiseId = match promise_id {
            Ok(promise_id) => promise_id,
            Err(err) => {
                deno_core::_ops::throw_type_error(
                    scope,
                    format!("invalid promise id: {}", err),
                );
                return;
            }
        };
        let arg_0 = match deno_core::v8::Local::<
            deno_core::v8::String,
        >::try_from(args.get(1usize as i32)) {
            Ok(v8_string) => deno_core::serde_v8::to_utf8(v8_string, scope),
            Err(_) => {
                return deno_core::_ops::throw_type_error(
                    scope,
                    format!("Expected string at position {}", 1usize),
                );
            }
        };
        let get_class = {
            let state = ::std::cell::RefCell::borrow(&ctx.state);
            state.tracker.track_async(op_id);
            state.get_error_class_fn
        };
        deno_core::_ops::queue_async_op(
            ctx,
            scope,
            false,
            async move {
                let result = Self::call(
                        compile_error!("mutable opstate is not supported in async ops"),
                        arg_0,
                    )
                    .await;
                (promise_id, op_id, deno_core::_ops::to_op_result(get_class, result))
            },
        );
    }
}