这篇教程C++ BSTR函数代码示例写得很实用,希望能帮到您。
本文整理汇总了C++中BSTR函数的典型用法代码示例。如果您正苦于以下问题:C++ BSTR函数的具体用法?C++ BSTR怎么用?C++ BSTR使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。 在下文中一共展示了BSTR函数的29个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的C++代码示例。 示例1: handleRequestFromChildstatic void handleRequestFromChild(struct Admin* admin, uint8_t buffer[MAX_API_REQUEST_SIZE], size_t amount, struct Allocator* allocator){ String* txid = NULL; int skip = 0; if (!memcmp(buffer, "0123", 4)) { // out of band txid txid = &(String) { .len = 4, .bytes = (char*) buffer + 4 }; skip = 8; } struct Reader* reader = ArrayReader_new(buffer + skip, amount - skip, allocator); Dict message; if (List_getStandardBencSerializer()->parseDictionary(reader, allocator, &message)) { return; } String* query = Dict_getString(&message, CJDHTConstants_QUERY); if (!query) { return; } // If they're asking for a cookie then lets give them one. String* cookie = BSTR("cookie"); if (String_equals(query, cookie)) { Dict* d = Dict_new(allocator); char bytes[32]; snprintf(bytes, 32, "%u", (uint32_t) Time_currentTimeSeconds(admin->eventBase)); String* theCookie = &(String) { .len = strlen(bytes), .bytes = bytes }; Dict_putString(d, cookie, theCookie, allocator); Admin_sendMessage(d, txid, admin); return; } // If this is a permitted query, make sure the cookie is right. String* auth = BSTR("auth"); bool authed = false; if (String_equals(query, auth)) { if (!authValid(&message, buffer + skip, reader->bytesRead(reader), admin)) { Dict* d = Dict_new(allocator); Dict_putString(d, BSTR("error"), BSTR("Auth failed."), allocator); Admin_sendMessage(d, txid, admin); return; } query = Dict_getString(&message, BSTR("aq")); authed = true; } for (int i = 0; i < admin->functionCount; i++) { if (String_equals(query, admin->functions[i].name) && (authed || !admin->functions[i].needsAuth)) { admin->functions[i].call(&message, admin->functions[i].context, txid); } } return;}
开发者ID:bringhurst,项目名称:cjdns,代码行数:60,
示例2: AFX_MANAGE_STATE//------------------------------------------------------------------------------// This function determines the current project and calls StartCodeRover// with the appropriate arguments.//------------------------------------------------------------------------------STDMETHODIMP CCommands::CodeRoverBuildMethod() { AFX_MANAGE_STATE(AfxGetStaticModuleState()); /* VERIFY_OK(m_pApplication->EnableModeless(VARIANT_FALSE)); ::MessageBox(NULL, "VSAddIn Command invoked.", "VSAddIn", MB_OK | MB_ICONINFORMATION); VERIFY_OK(m_pApplication->EnableModeless(VARIANT_TRUE)); */ CComPtr<IDispatch> pProject; m_pApplication->get_ActiveProject(&pProject); if(pProject != NULL) { IGenericProject *p = NULL; pProject.QueryInterface(&p); CComBSTR bszProjectName(""); CComBSTR bszProjectFileName(""); p->get_Name(&bszProjectName); p->get_FullName(&bszProjectFileName); p->Release(); StartCodeRover(CString(BSTR(bszProjectName)), CString(BSTR(bszProjectFileName))); } else { StartCodeRover(NULL, NULL); } return S_OK;}
开发者ID:kit-transue,项目名称:software-emancipation-discover,代码行数:31,
示例3: authValidstatic inline bool authValid(Dict* message, uint8_t* buffer, uint32_t length, struct Admin* admin){ String* cookieStr = Dict_getString(message, BSTR("cookie")); uint32_t cookie = (cookieStr != NULL) ? strtoll(cookieStr->bytes, NULL, 10) : 0; uint64_t nowSecs = Time_currentTimeSeconds(admin->eventBase); String* submittedHash = Dict_getString(message, BSTR("hash")); if (cookie > nowSecs || cookie < nowSecs - 20 || !submittedHash || submittedHash->len != 64) { return false; } uint8_t* hashPtr = (uint8_t*) strstr((char*) buffer, submittedHash->bytes); if (!hashPtr || !admin->password) { return false; } uint8_t passAndCookie[64]; snprintf((char*) passAndCookie, 64, "%s%u", admin->password->bytes, cookie); uint8_t hash[32]; crypto_hash_sha256(hash, passAndCookie, strlen((char*) passAndCookie)); Hex_encode(hashPtr, 64, hash, 32); crypto_hash_sha256(hash, buffer, length); Hex_encode(hashPtr, 64, hash, 32); return memcmp(hashPtr, submittedHash->bytes, 64) == 0;}
开发者ID:bringhurst,项目名称:cjdns,代码行数:26,
示例4: check_incoming_control_channel_dowork/* * Handle incoming configuration * messages on the control channel. */voidcheck_incoming_control_channel_dowork (struct context *c){ const int len = tls_test_payload_len (c->c2.tls_multi); if (len) { struct gc_arena gc = gc_new (); struct buffer buf = alloc_buf_gc (len, &gc); if (tls_rec_payload (c->c2.tls_multi, &buf)) { /* force null termination of message */ buf_null_terminate (&buf); /* enforce character class restrictions */ string_mod (BSTR (&buf), CC_PRINT, CC_CRLF, 0); if (buf_string_match_head_str (&buf, "AUTH_FAILED")) receive_auth_failed (c, &buf); else if (buf_string_match_head_str (&buf, "PUSH_")) incoming_push_message (c, &buf); else if (buf_string_match_head_str (&buf, "RESTART")) server_pushed_signal (c, &buf, true, 7); else if (buf_string_match_head_str (&buf, "HALT")) server_pushed_signal (c, &buf, false, 4); else msg (D_PUSH_ERRORS, "WARNING: Received unknown control message: %s", BSTR (&buf)); } else { msg (D_PUSH_ERRORS, "WARNING: Receive control message failed"); } gc_free (&gc); }}
开发者ID:ThomasHabets,项目名称:openvpn,代码行数:39,
示例5: incoming_push_messagevoidincoming_push_message (struct context *c, const struct buffer *buffer){ struct gc_arena gc = gc_new (); unsigned int option_types_found = 0; int status; msg (D_PUSH, "PUSH: Received control message: '%s'", BSTR (buffer)); status = process_incoming_push_msg (c, buffer, c->options.pull, pull_permission_mask (c), &option_types_found); if (status == PUSH_MSG_ERROR) msg (D_PUSH_ERRORS, "WARNING: Received bad push/pull message: %s", BSTR (buffer)); else if (status == PUSH_MSG_REPLY || status == PUSH_MSG_CONTINUATION) { if (status == PUSH_MSG_REPLY) do_up (c, true, option_types_found); /* delay bringing tun/tap up until --push parms received from remote */ event_timeout_clear (&c->c2.push_request_interval); } gc_free (&gc);}
开发者ID:jjo,项目名称:openvpn-ipv6-legacy21,代码行数:26,
示例6: getcmdsstatic int getcmds(Dict* config){ uint8_t privateKey[32]; struct Address addr; parsePrivateKey(config, &addr, privateKey); uint8_t myIp[40]; Address_printIp(myIp, &addr); Dict* router = Dict_getDict(config, BSTR("router")); Dict* iface = Dict_getDict(router, BSTR("interface")); String* type = Dict_getString(iface, BSTR("type")); String* tunDevice = Dict_getString(iface, BSTR("tunDevice")); if (!String_equals(type, BSTR("TUNInterface"))) { fprintf(stderr, "router.interface.type is not recognized./n"); return -1; } char* tunDev = tunDevice ? tunDevice->bytes : "tun0"; if (strrchr(tunDev, '/') != NULL) { tunDev = strrchr(tunDev, '/') + 1; } printf("#!/bin/bash/n" "# Run these commands as root now and every time the system is rebooted/n" "# in order to get the interfaces setup properly./n/n"); printf("/sbin/ip addr add %s dev %s/n", myIp, tunDev); printf("/sbin/ip -6 route add fc00::/8 dev %s/n", tunDev); printf("/sbin/ip link set %s up/n", tunDev); return 0;}
开发者ID:avary,项目名称:cjdns,代码行数:31,
示例7: CComBSTRBOOL CVCAMetaParserMSXML::ParseCounts(){ // Find all the events CComBSTR bsTag; MSXML2::IXMLDOMNodePtr pNode, pSubNode, pSubSubNode, pSubSubSubNode; // Great names eh ;~) MSXML2::IXMLDOMNodeListPtr pNodeList, pSubNodeList; // See if we have any objects this time round bsTag = CComBSTR( _XML_VCA ) += CComBSTR("/") += CComBSTR( _XML_COUNTS ); pNode = m_pDOMDoc->selectSingleNode( bsTag.operator BSTR() ); if( pNode ) { // There are some event specified in this packet... take a look... //m_vcaCounts.clear(); m_vcaCounts.ulTotalCounter = 0; // Select all events bsTag = CComBSTR( _XML_COUNT ); pNodeList = pNode->selectNodes( bsTag.operator BSTR() ); pNode = pNodeList->nextNode(); while( pNode ) { VCA5_PACKET_COUNT vcaCount; memset( &vcaCount, 0, sizeof( vcaCount ) ); bsTag = CComBSTR( _XML_ID ); pSubNode = pNode->selectSingleNode( bsTag.operator BSTR() ); if( pSubNode ) { VarUI4FromStr( pSubNode->text, LCID_ENGLISH, LOCALE_NOUSEROVERRIDE, (unsigned long *)&vcaCount.ulId ); } bsTag = CComBSTR( _XML_VAL ); pSubNode = pNode->selectSingleNode( bsTag.operator BSTR() ); if( pSubNode ) { VarI4FromStr( pSubNode->text, LCID_ENGLISH, LOCALE_NOUSEROVERRIDE, (long *)&vcaCount.iVal ); } pNode = pNodeList->nextNode(); //m_vcaCounts.ph_back( vcaCount ); m_vcaCounts.Counters[m_vcaCounts.ulTotalCounter] = vcaCount; m_vcaCounts.ulTotalCounter++; } } return TRUE;}
开发者ID:anyboo,项目名称:UCADemo,代码行数:55,
示例8: ifconfig_pool_readvoidifconfig_pool_read(struct ifconfig_pool_persist *persist, struct ifconfig_pool *pool){ const int buf_size = 128; update_time(); if (persist && persist->file && pool) { struct gc_arena gc = gc_new(); struct buffer in = alloc_buf_gc(256, &gc); char *cn_buf; char *ip_buf; int line = 0; ALLOC_ARRAY_CLEAR_GC(cn_buf, char, buf_size, &gc); ALLOC_ARRAY_CLEAR_GC(ip_buf, char, buf_size, &gc); while (true) { ASSERT(buf_init(&in, 0)); if (!status_read(persist->file, &in)) { break; } ++line; if (BLEN(&in)) { int c = *BSTR(&in); if (c == '#' || c == ';') { continue; } msg( M_INFO, "ifconfig_pool_read(), in='%s', TODO: IPv6", BSTR(&in) ); if (buf_parse(&in, ',', cn_buf, buf_size) && buf_parse(&in, ',', ip_buf, buf_size)) { bool succeeded; const in_addr_t addr = getaddr(GETADDR_HOST_ORDER, ip_buf, 0, &succeeded, NULL); if (succeeded) { msg( M_INFO, "succeeded -> ifconfig_pool_set()"); ifconfig_pool_set(pool, cn_buf, addr, persist->fixed); } } } } ifconfig_pool_msg(pool, D_IFCONFIG_POOL); gc_free(&gc); }}
开发者ID:benjdag,项目名称:openvpn,代码行数:54,
示例9: DEBUG//=============================================================================// METHOD: SPELLvariableMonitor::retrieveLocalVariables()//=============================================================================void SPELLvariableMonitor::retrieveLocalVariables(std::vector<SPELLvarInfo>& vars){ DEBUG("[VM] Retrieve Locals"); /* * Bottom stack frame is discarded, * as globals and locals are the same dictionary */ if (m_frame->f_back == NULL) return; /* * Get the names defined in the current code, including arguments */ std::vector<std::string> varNames = retrieveNames(); /* * Iterate over the locals dictionary, retrieving the names contained in * varNames */ PyFrame_FastToLocals(m_frame); PyObject* dict = m_frame->f_locals; DEBUG("[VM] Frame: " + PYCREPR(m_frame)); for( unsigned int index = 0; index< varNames.size(); index++) { std::string varName = varNames[index]; PyObject* pyVarName = SSTRPY(varName); if (PyDict_Contains( dict, pyVarName )) { PyObject* object = PyDict_GetItem( dict, pyVarName ); if (!SPELLpythonHelper::instance().isInstance(object, "Database", "spell.lib.adapter.databases.database")) { if (PyCallable_Check(object)) continue; if (PyClass_Check(object)) continue; if (PyModule_Check(object)) continue; if (PyInstance_Check(object)) continue; } DEBUG("[VM] Processing " + varName); std::string type = PYSSTR( PyObject_Type(object) ); DEBUG("[VM] Type : " + type); std::string value = PYREPR( object ); DEBUG("[VM] Value : " + value); DEBUG("[VM] Global : " + BSTR(false)); DEBUG("[VM] Registered: " + BSTR(isRegistered(varName))); // Mark empty values (empty strings) as "<empty>" if (value == "") value = EMPTY_STRING; vars.push_back( SPELLvarInfo(varName, type, value, false, isRegistered(varName)) ); } } PyFrame_LocalsToFast(m_frame,0);}
开发者ID:seciltabur,项目名称:spell-sat,代码行数:56,
示例10: receive_auth_failed/* * Auth username/password * * Client received an authentication failed message from server. * Runs on client. */voidreceive_auth_failed(struct context *c, const struct buffer *buffer){ msg(M_VERB0, "AUTH: Received control message: %s", BSTR(buffer)); c->options.no_advance = true; if (c->options.pull) { switch (auth_retry_get()) { case AR_NONE: c->sig->signal_received = SIGTERM; /* SOFT-SIGTERM -- Auth failure error */ break; case AR_INTERACT: ssl_purge_auth(false); case AR_NOINTERACT: c->sig->signal_received = SIGUSR1; /* SOFT-SIGUSR1 -- Auth failure error */ break; default: ASSERT(0); } c->sig->signal_text = "auth-failure";#ifdef ENABLE_MANAGEMENT if (management) { const char *reason = NULL; struct buffer buf = *buffer; if (buf_string_compare_advance(&buf, "AUTH_FAILED,") && BLEN(&buf)) { reason = BSTR(&buf); } management_auth_failure(management, UP_TYPE_AUTH, reason); }#endif /* * Save the dynamic-challenge text even when management is defined */ {#ifdef ENABLE_CLIENT_CR struct buffer buf = *buffer; if (buf_string_match_head_str(&buf, "AUTH_FAILED,CRV1:") && BLEN(&buf)) { buf_advance(&buf, 12); /* Length of "AUTH_FAILED," substring */ ssl_put_auth_challenge(BSTR(&buf)); }#endif } }}
开发者ID:anlaneg,项目名称:openvpn,代码行数:58,
示例11: registerRouterstatic void registerRouter(Dict* config, uint8_t myPubKey[32], struct Context* context){ Dict* iface = Dict_getDict(config, BSTR("interface")); if (String_equals(Dict_getString(iface, BSTR("type")), BSTR("TUNInterface"))) { String* tunPath = Dict_getString(iface, BSTR("tunDevice")); context->routerIf = TUNInterface_new(tunPath, context->base, context->allocator); } context->routerModule = RouterModule_register(context->registry, context->allocator, myPubKey, context->base, context->logger, context->admin);}
开发者ID:Ralith,项目名称:cjdns,代码行数:14,
示例12: authorizedPasswordsstatic void authorizedPasswords(List* list, struct Context* ctx){ uint32_t count = List_size(list); for (uint32_t i = 0; i < count; i++) { Dict* d = List_getDict(list, i); if (!d) { fprintf(stderr, "authorizedPasswords[%u] is not a dictionary type./n", i); exit(-1); } String* passwd = Dict_getString(d, BSTR("password")); int64_t* authType = Dict_getInt(d, BSTR("authType")); int64_t* trust = Dict_getInt(d, BSTR("trust")); authorizedPassword(passwd, authType, trust, i, ctx); }}
开发者ID:Ralith,项目名称:cjdns,代码行数:15,
示例13: Admin_newstruct Admin* Admin_new(Dict* config, char* user, struct event_base* eventBase, struct ExceptionHandler* eh, struct Allocator* allocator){ errno = 0; int pipes[2][2]; if (pipe(pipes[0]) || pipe(pipes[1])) { eh->exception(__FILE__ " Failed to create pipes.", errno, eh); } int pgid = getpid(); int pid = fork(); if (pid < 0) { eh->exception(__FILE__ " Failed to fork()", errno, eh); } bool isChild = (pid == 0); int inFd = pipes[isChild][0]; close(pipes[!isChild][0]); int outFd = pipes[!isChild][1]; close(pipes[isChild][1]); if (isChild) { // Set the process group so that children will not // become orphaned if the parent gets signal 11 err um 9. setpgid(0, pgid); if (user) { Security_setUser(user, NULL, AbortHandler_INSTANCE); } struct ChildContext context; memset(&context, 0, sizeof(struct ChildContext)); context.inFd = inFd; context.outFd = outFd; context.allocator = allocator; event_reinit(eventBase); context.eventBase = eventBase; child(config, &context); exit(0); } setpgid(pid, pgid); struct Admin* admin = allocator->calloc(sizeof(struct Admin), 1, allocator); admin->inFd = inFd; admin->outFd = outFd; admin->allocator = allocator; admin->functionCount = 0; admin->eventBase = eventBase; admin->password = Dict_getString(config, BSTR("password")); admin->pipeEv = event_new(eventBase, inFd, EV_READ | EV_PERSIST, inFromChild, admin); event_add(admin->pipeEv, NULL); return admin;}
开发者ID:bringhurst,项目名称:cjdns,代码行数:60,
示例14: reliable_ack_print/* print a reliable ACK record coming off the wire */const char *reliable_ack_print (struct buffer *buf, bool verbose, struct gc_arena *gc){ int i; uint8_t n_ack; struct session_id sid_ack; packet_id_type pid; struct buffer out = alloc_buf_gc (256, gc); buf_printf (&out, "["); if (!buf_read (buf, &n_ack, sizeof (n_ack))) goto done; for (i = 0; i < n_ack; ++i) { if (!buf_read (buf, &pid, sizeof (pid))) goto done; pid = ntohpid (pid); buf_printf (&out, " " packet_id_format, (packet_id_print_type)pid); } if (n_ack) { if (!session_id_read (&sid_ack, buf)) goto done; if (verbose) buf_printf (&out, " sid=%s", session_id_print (&sid_ack, gc)); } done: buf_printf (&out, " ]"); return BSTR (&out);}
开发者ID:angelol,项目名称:iOpenVPN,代码行数:32,
示例15: send_auth_failed/* * Send auth failed message from server to client. */voidsend_auth_failed(struct context *c, const char *client_reason){ struct gc_arena gc = gc_new(); static const char auth_failed[] = "AUTH_FAILED"; size_t len; schedule_exit(c, c->options.scheduled_exit_interval, SIGTERM); len = (client_reason ? strlen(client_reason)+1 : 0) + sizeof(auth_failed); if (len > PUSH_BUNDLE_SIZE) { len = PUSH_BUNDLE_SIZE; } { struct buffer buf = alloc_buf_gc(len, &gc); buf_printf(&buf, auth_failed); if (client_reason) { buf_printf(&buf, ",%s", client_reason); } send_control_channel_string(c, BSTR(&buf), D_PUSH); } gc_free(&gc);}
开发者ID:anlaneg,项目名称:openvpn,代码行数:30,
示例16: AFX_MANAGE_STATE//1STDMETHODIMP CDirectSerialCSO::CollectParametersForNewCSO( /*[out]*/ BSTR *pbstrNameOut, /*[out]*/ VARIANT_BOOL *pvbHaveNewCSO){ AFX_MANAGE_STATE(AfxGetStaticModuleState()) CString csNameOut; bool bHaveNewCSO = m_pcomm->CollectParametersForNewCSO(csNameOut); if (bHaveNewCSO) { *pvbHaveNewCSO = VARIANT_TRUE; const char *string_in = LPCTSTR(csNameOut); BSTR bstr_out; Convert_Character_String_to_BSTR((char *)string_in, bstr_out); *pbstrNameOut = bstr_out; } else { *pvbHaveNewCSO = VARIANT_FALSE; *pbstrNameOut = BSTR(""); } return S_OK;}
开发者ID:hnordquist,项目名称:MIC,代码行数:26,
示例17: ND_TESTHRHRESULT XMLPaser::ND_hrOpenMemory( LPCTSTR strFile ){ try { ND_TESTHR( CoInitialize(NULL) ); ND_TESTHR( m_docPtr.CreateInstance("msxml2.domdocument") ); // load a document _variant_t varOut(true); // BOOL C++ BSWAP32函数代码示例 C++ BSP_TS_GetState函数代码示例
|