OSDN Git Service

Add a missing return statement.
[mingw/wtklite.git] / strres.cpp
1 /*
2  * strres.cpp
3  *
4  * ---------------------------------------------------------------------------
5  *
6  * Implementation of a minimal C++ class framework for use with the
7  * Microsoft Windows Application Programming Interface.
8  *
9  * $Id$
10  *
11  * This file provides the implementation of the constructor for the
12  * StringResource class.
13  *
14  * Written by Keith Marshall <keithmarshall@users.sourceforge.net>
15  * Copyright (C) 2012, MinGW.org Project.
16  *
17  * ---------------------------------------------------------------------------
18  *
19  * Permission is hereby granted, free of charge, to any person obtaining a
20  * copy of this software and associated documentation files (the "Software"),
21  * to deal in the Software without restriction, including without limitation
22  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
23  * and/or sell copies of the Software, and to permit persons to whom the
24  * Software is furnished to do so, subject to the following conditions:
25  *
26  * The above copyright notice, this permission notice, and the following
27  * disclaimer shall be included in all copies or substantial portions of
28  * the Software.
29  *
30  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
31  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
32  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
33  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
34  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
35  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
36  * DEALINGS IN THE SOFTWARE.
37  *
38  * ---------------------------------------------------------------------------
39  *
40  */
41 #define WIN32_LEAN_AND_MEAN
42
43 #include "wtklite.h"
44 #include <string.h>
45 #include <stdio.h>
46
47 /* MSDN says that the maximum length of any one string resource
48  * is 4097 characters; it isn't clear if this limit includes the
49  * terminating NUL, so we'll assume we may need one more.
50  */
51 #define WTK_STRING_RESOURCE_MAX  4098
52
53 WTK::StringResource::StringResource( HINSTANCE inst, unsigned int id )
54 {
55   /* First, allocate a temporary buffer, of sufficient size to
56    * accommodate a copy of the longest possible string resource.
57    */
58   char *tmp; value = NULL;
59   if( (tmp = (char *)(malloc( WTK_STRING_RESOURCE_MAX ))) == NULL )
60     throw( runtime_error( "Insufficient memory" ) );
61
62   /* Attempt to load the specified resource into this buffer...
63    */
64   if( ! LoadString( inst, id, tmp, WTK_STRING_RESOURCE_MAX ) )
65   {
66     /* ...but if that fails, release the temporary buffer
67      * to avoid leaking memory...
68      */
69     free( (void *)(tmp) );
70
71     /* ...and bail out, with a suitable diagnostic message.
72      */
73     throw( runtime_error( error_text( "String resource #%u not found", id )) );
74   }
75
76   /* Having successfully loaded the resource, adjust the memory
77    * allocation to fit, without wastage...
78    */
79   if( (value = (char *)(realloc( tmp, 1 + strlen( tmp ) ))) == NULL )
80     /*
81      * ...making the temporary buffer reference permanent, in
82      * the event that the reallocation should fail.
83      */
84     value = tmp;
85 }
86
87 /* $RCSfile$: end of file */